输入文件的图像方向(Reactjs)

时间:2019-02-06 12:53:02

标签: reactjs file input orientation exif

我正在使用输入accept="image/",但是每次在手机上拍照时,照片都会旋转。

        <input
          accept='image/*'
          style={this.styles.uploadInput as any}
          id='raised-button-file'
          onChange={this.onFileChange}
          type='file'
        />

这是我的FileAPI:

 // - Get file Extension
 const getExtension = (fileName: string) => {
 let re: RegExp = /(?:\.([^.]+))?$/
 return re.exec(fileName)![1]
 }

 // Converts image to canvas returns new canvas element
 const convertImageToCanvas = (image: HTMLImageElement | HTMLCanvasElement | 
 HTMLVideoElement | ImageBitmap) => {
 let canvas = document.createElement('canvas')
 canvas.width = image.width
 canvas.height = image.height
 canvas.getContext('2d')!.drawImage(image, 0, 0)

 return canvas
 }

 /**
 * Constraint image size
 * @param {file} file
 * @param {number} maxWidth
 * @param {number} maxHeight
 */
  const constraintImage = (file: File,fileName: string, maxWidth?: number, 
  maxHeight?: number) => {
   // Ensure it's an image
   if (file.type.match(/image.*/)) {
    // Load the image
   let reader = new FileReader()
   reader.onload = (readerEvent: any) => {
   let image = new Image()
   image.onload = (imageEvent: Event) => {

            // Resize the image
    let canvas: HTMLCanvasElement = document.createElement('canvas')
    let maxSize: number = 986// TODO : pull max size from a site config
    let width: number = image.width
    let height: number = image.height
    if (width > height) {
      if (width > maxSize) {
        height *= maxSize / width
        width = maxSize
      }
    } else {
      if (height > maxSize) {
        width *= maxSize / height
        height = maxSize
      }
    }
    canvas.width = width
    canvas.height = height
    canvas.getContext('2d')!.drawImage(image, 0, 0, width, height)
    let dataUrl = canvas.toDataURL()
    let resizedImage = dataURLToBlob(dataUrl)
    let evt = new CustomEvent('onSendResizedImage', { detail: 
    {resizedImage,fileName} })
    window.dispatchEvent(evt)

  }
  image.src = readerEvent.target.result
}
reader.readAsDataURL(file)
}
}

/**
* Convert data URL to blob
* @param {object} dataURL
*/
const dataURLToBlob = (dataURL: string) => {

let BASE64_MARKER = 'base64,'
if (dataURL.indexOf(BASE64_MARKER) === -1) {
let parts = dataURL.split(',')
let contentType = parts[0].split(':')[1]
let raw = parts[1]

return new Blob([raw], {type: contentType})
}

let parts = dataURL.split(BASE64_MARKER)
let contentType = parts[0].split(':')[1]
let raw = window.atob(parts[1])
let rawLength = raw.length

let uInt8Array = new Uint8Array(rawLength)

for (let i = 0 ;i < rawLength; ++i) {
 uInt8Array[i] = raw.charCodeAt(i)
 }

  return new Blob([uInt8Array], {type: contentType})
 }

 export default {
 dataURLToBlob,
 convertImageToCanvas,
 getExtension,
 constraintImage

 }

我读到它与文件的EXIF数据有关,但是我无法解决这个问题。从手机上传已经存在的图像可以正常工作,仅使用相机拍摄的图像会造成麻烦...

enter image description here

我尝试了本教程,但我不知道在代码中的何处实现此代码段:

how-to-automatically-rotate-an-image

您对我的代码有什么建议吗?

亲切的问候

0 个答案:

没有答案