可使用exif.js插件获得图片的EXIF信息
直接引用 http://cdn.muops.cn/js/exif.js
然后使用一下代码可以获取Orientation信息,并纠正Orientation带来的图片旋转问题
// @param {Obj} file 图片file对象 // @param {string} ImgObj img标签对象 function saveImg(file, ImgObj) { var orientation; //EXIF js 可以读取图片的元信息 EXIF.getData(file, function () { orientation = EXIF.getTag(this, 'Orientation');//获取Orientation信息 var reader = new FileReader(); reader.onload = function (e) { getImgData(this.result, orientation, function (data) { //这里可以使用校正后的图片data了 ImgObj.src = data; }); } reader.readAsDataURL(file); }); } // @param {string} img 图片的base64 // @param {int} dir exif获取的方向信息 // @param {function} next 回调方法,返回校正方向后的base64 function getImgData(img, dir, next) { var image = new Image(); image.onload = function () { var degree = 0, drawWidth, drawHeight, width, height; drawWidth = this.naturalWidth; drawHeight = this.naturalHeight; //以下改变一下图片大小 var maxSide = Math.max(drawWidth, drawHeight); if (maxSide > 1024) { var minSide = Math.min(drawWidth, drawHeight); minSide = minSide / maxSide * 1024; maxSide = 1024; if (drawWidth > drawHeight) { drawWidth = maxSide; drawHeight = minSide; } else { drawWidth = minSide; drawHeight = maxSide; } } var canvas = document.createElement('canvas'); canvas.width = width = drawWidth; canvas.height = height = drawHeight; var context = canvas.getContext('2d'); //判断图片方向,重置canvas大小,确定旋转角度,iphone默认的是home键在右方的横屏拍摄方式 switch (dir) { //iphone横屏拍摄,此时home键在左侧 case 3: degree = 180; drawWidth = -width; drawHeight = -height; break; //iphone竖屏拍摄,此时home键在下方(正常拿手机的方向) case 6: canvas.width = height; canvas.height = width; degree = 90; drawWidth = width; drawHeight = -height; break; //iphone竖屏拍摄,此时home键在上方 case 8: canvas.width = height; canvas.height = width; degree = 270; drawWidth = -width; drawHeight = height; break; } //使用canvas旋转校正 context.rotate(degree * Math.PI / 180); context.drawImage(this, 0, 0, drawWidth, drawHeight); //返回校正图片 next(canvas.toDataURL("image/png")); } image.src = img; }
附上Exif.js的API
名称 | 说明 |
---|---|
EXIF.getData(img, callback) | 获取图像的数据
能兼容尚未支持提供 EXIF 数据的浏览器获取到元数据。 |
EXIF.getTag(img, tag) | 获取图像的某个数据 |
EXIF.getAllTags(img) | 获取图像的全部数据,值以对象的方式返回 |
EXIF.pretty(img) | 获取图像的全部数据,值以字符串的方式返回 |
EXIF 标识
名称 | 说明 |
---|---|
ExifVersion | Exif 版本 |
FlashPixVersion | FlashPix 版本 |
ColorSpace | 色域、色彩空间 |
PixelXDimension | 图像的有效宽度 |
PixelYDimension | 图像的有效高度 |
ComponentsConfiguration | 图像构造 |
CompressedBitsPerPixel | 压缩时每像素色彩位 |
MakerNote | 制造商设置的信息 |
UserComment | 用户评论 |
RelatedSoundFile | 关联的声音文件 |
DateTimeOriginal | 创建时间 |
DateTimeDigitized | 数字化创建时间 |
SubsecTime | 日期时间(秒) |
SubsecTimeOriginal | 原始日期时间(秒) |
SubsecTimeDigitized | 原始日期时间数字化(秒) |
ExposureTime | 曝光时间 |
FNumber | 光圈值 |
ExposureProgram | 曝光程序 |
SpectralSensitivity | 光谱灵敏度 |
ISOSpeedRatings | 感光度 |
OECF | 光电转换功能 |
ShutterSpeedValue | 快门速度 |
ApertureValue | 镜头光圈 |
BrightnessValue | 亮度 |
ExposureBiasValue | 曝光补偿 |
MaxApertureValue | 最大光圈 |
SubjectDistance | 物距 |
MeteringMode | 测光方式 |
Lightsource | 光源 |
Flash | 闪光灯 |
SubjectArea | 主体区域 |
FocalLength | 焦距 |
FlashEnergy | 闪光灯强度 |
SpatialFrequencyResponse | 空间频率反应 |
FocalPlaneXResolution | 焦距平面X轴解析度 |
FocalPlaneYResolution | 焦距平面Y轴解析度 |
FocalPlaneResolutionUnit | 焦距平面解析度单位 |
SubjectLocation | 主体位置 |
ExposureIndex | 曝光指数 |
SensingMethod | 图像传感器类型 |
FileSource | 源文件 |
SceneType | 场景类型(1 == 直接拍摄) |
CFAPattern | CFA 模式 |
CustomRendered | 自定义图像处理 |
ExposureMode | 曝光模式 |
WhiteBalance | 白平衡(1 == 自动,2 == 手动) |
DigitalZoomRation | 数字变焦 |
FocalLengthIn35mmFilm | 35毫米胶片焦距 |
SceneCaptureType | 场景拍摄类型 |
GainControl | 场景控制 |
Contrast | 对比度 |
Saturation | 饱和度 |
Sharpness | 锐度 |
DeviceSettingDescription | 设备设定描述 |
SubjectDistanceRange | 主体距离范围 |
InteroperabilityIFDPointer | |
ImageUniqueID | 图像唯一ID |
名称 | 说明 |
---|---|
ImageWidth | 图像宽度 |
ImageHeight | 图像高度 |
BitsPerSample | 比特采样率 |
Compression | 压缩方法 |
PhotometricInterpretation | 像素合成 |
Orientation | 拍摄方向 |
SamplesPerPixel | 像素数 |
PlanarConfiguration | 数据排列 |
YCbCrSubSampling | 色相抽样比率 |
YCbCrPositioning | 色相配置 |
XResolution | X方向分辨率 |
YResolution | Y方向分辨率 |
ResolutionUnit | 分辨率单位 |
StripOffsets | 图像资料位置 |
RowsPerStrip | 每带行数 |
StripByteCounts | 每压缩带比特数 |
JPEGInterchangeFormat | JPEG SOI 偏移量 |
JPEGInterchangeFormatLength | JPEG 比特数 |
TransferFunction | 转移功能 |
WhitePoint | 白点色度 |
PrimaryChromaticities | 主要色度 |
YCbCrCoefficients | 颜色空间转换矩阵系数 |
ReferenceBlackWhite | 黑白参照值 |
DateTime | 日期和时间 |
ImageDescription | 图像描述、来源 |
Make | 生产者 |
Model | 型号 |
Software | 软件 |
Artist | 作者 |
Copyright | 版权信息 |
名称 | 说明 |
---|---|
GPSVersionID | GPS 版本 |
GPSLatitudeRef | 南北纬 |
GPSLatitude | 纬度 |
GPSLongitudeRef | 东西经 |
GPSLongitude | 经度 |
GPSAltitudeRef | 海拔参照值 |
GPSAltitude | 海拔 |
GPSTimeStamp | GPS 时间戳 |
GPSSatellites | 测量的卫星 |
GPSStatus | 接收器状态 |
GPSMeasureMode | 测量模式 |
GPSDOP | 测量精度 |
GPSSpeedRef | 速度单位 |
GPSSpeed | GPS 接收器速度 |
GPSTrackRef | 移动方位参照 |
GPSTrack | 移动方位 |
GPSImgDirectionRef | 图像方位参照 |
GPSImgDirection | 图像方位 |
GPSMapDatum | 地理测量资料 |
GPSDestLatitudeRef | 目标纬度参照 |
GPSDestLatitude | 目标纬度 |
GPSDestLongitudeRef | 目标经度参照 |
GPSDestLongitude | 目标经度 |
GPSDestBearingRef | 目标方位参照 |
GPSDestBearing | 目标方位 |
GPSDestDistanceRef | 目标距离参照 |
GPSDestDistance | 目标距离 |
GPSProcessingMethod | GPS 处理方法名 |
GPSAreaInformation | GPS 区功能变数名 |
GPSDateStamp | GPS 日期 |
GPSDifferential | GPS 修正 |