在實(shí)際項(xiàng)目中,可能需要用戶從相冊中選擇圖片然后進(jìn)行相應(yīng)的處理。但是不知道大家有沒有發(fā)現(xiàn)這樣一種情況,就是手機(jī)里看是豎著的,但是上傳到微博或者哪里的時(shí)候確實(shí)橫著的。一種情況是你拿手機(jī)豎著拍照得話,照片就是橫著的,雖然在手機(jī)里看是豎著的。(可能有點(diǎn)抽象,遇到此情況的同學(xué)應(yīng)該深有感觸)
那么我們在客戶端中應(yīng)該如何處理這種情況呢?一種想法是獲取圖片的角度,如果是90°,就把照片翻轉(zhuǎn)過來,再進(jìn)行相應(yīng)的操作。那這樣就涉及到2個(gè)問題
1. 如何獲取相冊中照片的角度
2. 如何翻轉(zhuǎn)已有的照片(流、或者Bitmap或者WriteableBitmap)
查看了系統(tǒng)的API,并沒有對(duì)相片的角度提供支持,但是我們可以使用ExifLib開源庫去做。
下述的方法就是獲取選取圖片的角度的
/// <summary> /// get angle of photo /// </summary> /// <param name="stream">photo stream</param> /// <param name="filename">photo name</param> /// <returns>angle of the photo</returns> public static int GetAngle(Stream stream, string filename) { ExifLib.ExifOrientation _orientation; int _angle = 0; stream.Position = 0; JpegInfo info = ExifReader.ReadJpeg(stream, filename); if (info!=null) { _orientation = info.Orientation; switch (info.Orientation) { case ExifOrientation.TopLeft: case ExifOrientation.Undefined: _angle = 0; break; case ExifOrientation.TopRight: _angle = 90; break; case ExifOrientation.BottomRight: _angle = 180; break; case ExifOrientation.BottomLeft: _angle = 270; break; } } return _angle; }
獲取到角度后,如果角度是90°,即是反的,我們需要將其糾正過來,可以使用如下的方法:
private Stream RotateStream(Stream stream, int angle) { stream.Position = 0; if (angle % 90 != 0 || angle < 0) throw new ArgumentException(); if (angle % 360 == 0) return stream; BitmapImage bitmap = new BitmapImage(); bitmap.SetSource(stream); WriteableBitmap wbSource = new WriteableBitmap(bitmap); WriteableBitmap wbTarget = null; if (angle % 180 == 0) { wbTarget = new WriteableBitmap(wbSource.PixelWidth, wbSource.PixelHeight); } else { wbTarget = new WriteableBitmap(wbSource.PixelHeight, wbSource.PixelWidth); } for (int x = 0; x < wbSource.PixelWidth; x++) { for (int y = 0; y < wbSource.PixelHeight; y++) { switch (angle % 360) { case 90: wbTarget.Pixels[(wbSource.PixelHeight - y - 1) + x * wbTarget.PixelWidth] = wbSource.Pixels[x + y * wbSource.PixelWidth]; break; case 180: wbTarget.Pixels[(wbSource.PixelWidth - x - 1) + (wbSource.PixelHeight - y - 1) * wbSource.PixelWidth] = wbSource.Pixels[x + y * wbSource.PixelWidth]; break; case 270: wbTarget.Pixels[y + (wbSource.PixelWidth - x - 1) * wbTarget.PixelWidth] = wbSource.Pixels[x + y * wbSource.PixelWidth]; break; } } } MemoryStream targetStream = new MemoryStream(); wbTarget.SaveJpeg(targetStream, wbTarget.PixelWidth, wbTarget.PixelHeight, 0, 100); return targetStream; }