萨龙网络
登录
首页-WordPress文章-WordPress-正文

WordPress附件函数wp_get_attachment_metadata简码获取照片EXIF信息

萨龙龙萨龙龙
WordPress
10年前
0
0
1.29W
wordpress附件函数wp_get_attachment_metadata简码获取照片EXIF信息 自动获取照片的EXIF信息,很多大型的摄影论坛都有这个功能,对于摄影爱好者来说是一个很实用的功能。萨龙龙开发的Deephoto主题Neatimg主题中就添加了些功能,通过简码很方便的获取了照片的EXIF信息。 [infobox]首先我们了解下什么是EXIF:[/infobox]Exif是一种图像文件格式,它的数据存储与JPEG格式是完全相同的。实际上Exif格式就是在JPEG格式头部插入了数码照片的信息,包括拍摄时的光圈、快门、白平衡、ISO、焦距、日期时间等各种和拍摄条件以及相机品牌、型号、色彩编码、拍摄时录制的声音以及GPS全球定位系统数据、缩略图等。你可以利用任何可以查看JPEG文件的看图软件浏览Exif格式的照片,但并不是所有的图形程序都能处理Exif信息。 [successbox]Wordpress附件函数wp_get_attachment_metadata[/successbox]本文是使用Wordpress附件函数wp_get_attachment_metadata来获取照片的EXIF信息,通过附件的ID来读取EXIF信息,所以要获取照片的EXIF信息,是必须把照片上传到媒体中,将EXIF信息存储在数据库中,这样函数才能读取。在导出照片时需要注意,很多软件默认会清除一些EXIF信息,选择保留所有EXIF信息(元数据)。 国内暂时没有看到其它主题有获取照片EXIF信息功能,国外也很罕见,有也是通过Exifography插件来实现,但获取的EXIF信息并不全,很多也获取不了,因为Exifography插件就是通过wp_get_attachment_metadata来获取,所以下面的代码也同样是获取不全照片的EXIF。 以下代码添加到functions.php文件中(添加曝光补偿单位与转换快门时间代码来源Exifography插件),在编辑文章时使用简码:[exif id=""],来获取照片的EXIF信息(一个简码只能添加一个照片ID):
  1. //获取媒体图片EXIF信息
  2. function sl_exif($atts$content = null) {
  3.     extract(shortcode_atts(array(
  4.         "id" => ''
  5.     ), $atts));
  6.     $imgmeta = wp_get_attachment_metadata($id);
  7.     //添加曝光补偿单位
  8.     $exposure_bias_parts = explode("/"$imgmeta['image_meta']['exposure_bias']);
  9.     if ($exposure_bias_parts[0] == "0")
  10.         $exif = '';
  11.     else {
  12.         $float = intval($exposure_bias_parts[0]) / intval($exposure_bias_parts[1]);
  13.         if (is_int($float))
  14.             $exif = sprintf("%+d%s"$float, __('EV','exifography'));
  15.         elseif ($float <= -1 || $float >= 1)
  16.             $exif = sprintf("%+.1f%s"$float, __('EV','exifography'));
  17.         else
  18.             $exif = sprintf("%+d%s%d%s"intval($exposure_bias_parts[0]), "/"intval($exposure_bias_parts[1]), __('EV','exifography'));
  19.     }
  20.     //转换快门时间
  21.     if (isset($imgmeta['image_meta']['shutter_speed'])) {
  22.         if ((1 / $imgmeta['image_meta']['shutter_speed']) > 1) {
  23.             $speed = "1/";
  24.             if ((number_format((1 / $imgmeta['image_meta']['shutter_speed']), 1)) == 1.3
  25.                 or number_format((1 / $imgmeta['image_meta']['shutter_speed']), 1) == 1.5
  26.      or number_format((1 / $imgmeta['image_meta']['shutter_speed']), 1) == 1.6
  27.                 or number_format((1 / $imgmeta['image_meta']['shutter_speed']), 1) == 2.5) {
  28.                 $speed .= number_format((1 / $imgmeta['image_meta']['shutter_speed']), 1, '.''') . "s";
  29.             }
  30.             else
  31.                 $speed .= number_format((1 / $imgmeta['image_meta']['shutter_speed']), 0, '.''') . "s";
  32.         }
  33.         else
  34.             $speed = $imgmeta['image_meta']['shutter_speed']."s";
  35.     }
  36.     $shortcode.= '<ul>';
  37.     $shortcode.= '<li class="image-meta"><span>'.__( '型号:', 'salong' ).'</span>'.$imgmeta['image_meta']['camera'].'</li>';
  38.     $shortcode.= '<li class="image-meta"><span>'.__( '镜头:', 'salong' ).'</span>'.$imgmeta['image_meta']['lens'].'</li>';
  39.     $shortcode.= '<li class="image-meta"><span>'.__( '光圈:', 'salong' ).'</span>f/'.$imgmeta['image_meta']['aperture'].'</li>';
  40.     $shortcode.= '<li class="image-meta"><span>'.__( '快门:', 'salong' ).'</span>'.$speed.'</li>';
  41.     $shortcode.= '<li class="image-meta"><span>'.__( '焦距:', 'salong' ).'</span>'.$imgmeta['image_meta']['focal_length'].'mm</li>';
  42.     $shortcode.= '<li class="image-meta"><span>'.__( 'ISO:', 'salong' ).'</span>'.$imgmeta['image_meta']['iso'].'</li>';
  43.     $shortcode.= '<li class="image-meta"><span>'.__( '曝光补偿:', 'salong' ).'</span>'.$exif.'</li>';
  44.     $shortcode.= '<li class="image-meta"><span>'.__( '曝光程序:', 'salong' ).'</span>'.$imgmeta['image_meta']['exposure_program'].'</li>';
  45.     $shortcode.= '<li class="image-meta"><span>'.__( '白平衡:', 'salong' ).'</span>'.$imgmeta['image_meta']['white_balance'].'</li>';
  46.     $shortcode.= '<li class="image-meta"><span>'.__( '闪光灯:', 'salong' ).'</span>'.$imgmeta['image_meta']['flash'].'</li>';
  47.     $shortcode.= '<li class="image-meta"><span>'.__( '分辨率:', 'salong' ).'</span>'.$imgmeta['image_meta']['resolutionUnit'].'</li>';
  48.     $shortcode.= '<li class="image-meta"><span>'.__( '软件:', 'salong' ).'</span>'.$imgmeta['image_meta']['software'].'</li>';
  49.     $shortcode.= '<li class="image-meta"><span>'.__( '尺寸:', 'salong' ).'</span>'.$imgmeta['width'].'*'.$imgmeta['height'].'px</li>';
  50.     $shortcode.= '<li class="image-meta"><span>'.__( '位置:', 'salong' ).'</span>'.$imgmeta['image_meta']['location'].'</li>';
  51.     $shortcode.= '<li class="image-meta"><span>'.__( '时间:', 'salong' ).'</span>'.date_i18n('Y-m-j G:i:s a',$imgmeta['image_meta']['created_timestamp']).'</li>';
  52.     $shortcode.= '<li class="image-meta"><span>'.__( '版权:', 'salong' ).'</span>'.$imgmeta['image_meta']['credit'].'</li>';
  53.     $shortcode.= '</ul> ';
  54.     return $shortcode;
  55. }
  56. add_shortcode("exif""sl_exif");
  57. //简码:[exif id=""]
[successbox]这次只是介绍通过Wordpress附件函数来获取照片的EXIF信息(虽然不全),之后再写一些通过PHP函数获取所有EXIF信息的文章。[/successbox]
标签:
本文原创,作者:萨龙龙,其版权均为萨龙网络所有。
如需转载,请注明出处:https://salongweb.com/wp-get-attachment-metadata-exif.html
萨龙龙

萨龙龙

侠客
一个平平常常的人,热爱生活、旅行和摄影,骑行去过西藏,一直计划再去。14年从江西骑行来到大理,现栖居于洱海边,食人间烟火,过简单生活,做简约设计!
1342.11M346.30W3.40W
分享:
CSS3 background-attachment:fixed实现滚动视差效果
CSS3 background-attachment:fixed实现滚动视差效果上一篇
Linux VPS云主机使用SSH安装PHP EXIF模块下一篇
Linux VPS云主机使用SSH安装PHP EXIF模块
相关文章
总数:107

WordPress 最简便的边栏调用方法与提示

WordPress主题文章类型较多,想实现不同的文章类型页面调用不同的边栏,一般的方法是将代码写在主题根目录下的sidebar.php文件…
萨龙龙萨龙龙
WordPress
7年前
0
0
1.11W
0

WordPress 主题选项框架 Codestar Framework Pro 2.0专业版使用

萨龙网络在2018年9月份就写了一篇《WordPress简约实用的主题选项框架CodestarFramework》文章来介绍Codest…
萨龙龙萨龙龙
WordPress
6年前
0
0
2.53W
0

WordPress 一键数据库初始化重置插件:WordPress Reset

在开发WordPress主题中,需要N多次测试,这样就需要多次重装测试网站,这样相当的麻烦。今天了解到一款数据库初始化插件:WordPr…
萨龙龙萨龙龙
WordPress
7年前
0
0
1.51W
0

WordPress MU多站点解决Timthumb.php不显示缩略图

最近在开发Perimg图片主题,用户想要用Timthumb.php插件来实现缩略图,缩略图的顺序是自定义域、文章第一张图片与默认缩略图,而萨龙龙…
萨龙龙萨龙龙
WordPress
9年前
0
0
1.12W
0

CSS3 background-attachment:fixed实现滚动视差效果

一直都想设计一个有滚动视差效果的主题,而网上所有的介绍和有视差效果的主题都是使用jQuery来实现,而且由于视差背景图是一张满屏的大小,所以一直…
萨龙龙萨龙龙
WordPress
10年前
0
0
1.47W
0

WooCommerce 商城插件的条件式标签

可以在模板文件中使用WooCommerce和WordPress的条件式标签,以根据匹配页面的条件来显示的特定内容。例如,您可能想要在商店页面上方…
萨龙龙萨龙龙
WooCommerce
8年前
0
0
1.23W
0

解决网站嵌入优酷视频堆叠顺序的问题

很多网站都会插入优酷或其它网站的在线视频到自己的网站中,默认情况下优酷视频的堆叠顺序并不受CSS样式z-index属性的影响,在视频页面有滚动、…
萨龙龙萨龙龙
WordPress
9年前
0
0
1.24W
0

WordPress 主题 Slearn Pro 课程插件之编辑课程选项

课程插件功能已经能满足绝大多数在线教育培训课程网站的需求,选项功能也众多,「即将推出」功能还在开发中。…
萨龙龙萨龙龙
WordPress
2年前
0
0
2.06W
0

萨龙网络集成Buddypress+Bbpress社区论坛功能

前段时间已经发布Purity2.0主题更新的文章,主题已经集成了作品展示、商城,通过半个来月的时间把Buddypress+Bbpress社区论坛…
萨龙龙萨龙龙
Bbpress, Buddypress
10年前
0
0
1.71W
0

WooCommerce 商城首页排除指定分类

WooCommerce是WordPress中最强大的商城插件,没有之一。在Slearn主题的开发过程中,需要将课程和商城结合,课程使用…
萨龙龙萨龙龙
WooCommerce
6年前
0
0
9.88K
0

Woocommerce一个很漂亮的购物系统

Woocommerce,一个wordpress的电子商务扩展插件,一个很漂亮的可以帮你卖任何东西的工具,这是插件在wordpress后台插件中的…
萨龙龙萨龙龙
WooCommerce
11年前
0
0
1.47W
0

WooCommerce 通过woocommerce_cart_item_thumbnail钩子修改购物车缩略图

在开发基于WooCommerce的商城主题时,我们一般会将模板文件添加到主题中来进行修改,对于有钩子或接口的地方,就没有必要再修改模板代码了…
萨龙龙萨龙龙
WooCommerce
5年前
0
0
1.55W
0
评论表单游客 您好,欢迎参与讨论。
请输入昵称
请输入邮箱
请输入网址
0 / 100
评论列表
总数:0
萨龙网络
暂无评论,第一个评论下?