蘋果手機拍照上傳后圖片會旋轉,如何獲取拍照方向埂淮?

最近在做一個H5姑隅,需要實現的功能是,手機拍照獲得一張照片倔撞,把照片通過FormData對象發(fā)送到后臺讲仰,返回新的圖片。在這個過程中遇到了一個坑痪蝇,就是iphone蘋果手機拍照之后上傳鄙陡,得到的照片旋轉了90度。
具體原因無需深究躏啰,通過一番google后找到解決辦法趁矾!

以下代碼是獲取手機拍照的方向的代碼:

// 該函數返回照片方向的代碼
function getOrientation(file, callback) {
  var reader = new FileReader();
  reader.onload = function(e) {

    var view = new DataView(e.target.result);
    if (view.getUint16(0, false) != 0xFFD8) return callback(-2);
    var length = view.byteLength, offset = 2;
    while (offset < length) {
      var marker = view.getUint16(offset, false);
      offset += 2;
      if (marker == 0xFFE1) {
        if (view.getUint32(offset += 2, false) != 0x45786966) return callback(-1);
        var little = view.getUint16(offset += 6, false) == 0x4949;
        offset += view.getUint32(offset + 4, little);
        var tags = view.getUint16(offset, little);
        offset += 2;
        for (var i = 0; i < tags; i++)
          if (view.getUint16(offset + (i * 12), little) == 0x0112)
            return callback(view.getUint16(offset + (i * 12) + 8, little));
      }
      else if ((marker & 0xFF00) != 0xFF00) break;
      else offset += view.getUint16(offset, false);
    }
    return callback(-1);
  };
  reader.readAsArrayBuffer(file);
}

用法:

var input = document.getElementById('input');
input.onchange = function(e) {
    getOrientation(input.files[0], function(orientation) {
        // code here!
  });
}

那么,如何通過方向代碼來知道圖片是怎么旋轉的呢给僵?下面這張圖就是答案:

image.png

例如毫捣,返回的代碼是3详拙,我們得到的圖片是順時針旋轉了180度之后的圖片,所以我們需要對這張圖片逆時針旋轉180度即可得到原圖蔓同。
另外饶辙,返回-2代碼代表圖片不是jpg格式,返回-1代表未定義斑粱。

參考資料:
https://stackoverflow.com/questions/7584794/accessing-jpeg-exif-rotation-data-in-javascript-on-the-client-side

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末弃揽,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子则北,更是在濱河造成了極大的恐慌矿微,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咒锻,死亡現場離奇詭異冷冗,居然都是意外死亡守屉,警方通過查閱死者的電腦和手機惑艇,發(fā)現死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拇泛,“玉大人滨巴,你說我怎么就攤上這事“嘲龋” “怎么了恭取?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長熄守。 經常有香客問我蜈垮,道長,這世上最難降的妖魔是什么裕照? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任攒发,我火速辦了婚禮,結果婚禮上晋南,老公的妹妹穿的比我還像新娘惠猿。我一直安慰自己,他們只是感情好负间,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布偶妖。 她就那樣靜靜地躺著,像睡著了一般政溃。 火紅的嫁衣襯著肌膚如雪趾访。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天董虱,我揣著相機與錄音扼鞋,去河邊找鬼。 笑死,一個胖子當著我的面吹牛藏鹊,可吹牛的內容都是我干的润讥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼盘寡,長吁一口氣:“原來是場噩夢啊……” “哼楚殿!你這毒婦竟也來了?” 一聲冷哼從身側響起竿痰,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤脆粥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后影涉,有當地人在樹林里發(fā)現了一具尸體变隔,經...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年蟹倾,在試婚紗的時候發(fā)現自己被綠了匣缘。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡鲜棠,死狀恐怖肌厨,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情豁陆,我是刑警寧澤柑爸,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站盒音,受9級特大地震影響表鳍,放射性物質發(fā)生泄漏。R本人自食惡果不足惜祥诽,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一譬圣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧原押,春花似錦胁镐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至笨农,卻和暖如春就缆,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谒亦。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工竭宰, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留空郊,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓切揭,卻偏偏與公主長得像狞甚,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子廓旬,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348

推薦閱讀更多精彩內容