解决android有的手机拍照后上传图片被旋转的问题

news/2024/11/29 16:31:50/

需求:做仿新浪发微博的项目,能够上传图片还有两外一个项目用到手机拍摄图片,这两个都需要把图片上传到服务器

遇到问题:有的手机拍摄的图片旋转90度,有的图片旋转了180度,有的手机是正常的,服务器要求的是正的,这样问题就来了,不能用户发个照片在微博上看到的是被旋转了的啊,另外一个项目里旋转了的图片直接匹配出现问题,这个更严重。

解决:开始的时候在网上没有找到很好的解决办法,谷歌百度的搜了一通,想到第一种解决方式,当手机拍照结束,在返回结果处理里面立即跳转到一个新的页面,在新的页面里让用户自己手动去旋转图片,然后点击确定。就可以上传到服务器正着的图片了;第二种解决方式,这是在论坛里发现的一个方法,可以获取图片的属性,读取图片的旋转角度。

第一种方式代码:

在onActivityResult里面处理跳转

[java]  view plain copy
  1. <span style="font-size:18px;">      Intent intent = new Intent(SendMicoBlog.this, RotaingActivity.class);  
  2.         MyApp myApp = (MyApp)getApplication();  
  3.         myApp.setName(bitmap);//修改之后的名称  
  4.         myApp.setPhoto(isPhoto);  
  5.         startActivityForResult(intent, 1);</span>  

在RotaingActivity里面就可以作相应的旋转处理了

[java]  view plain copy
  1. <span style="font-size:18px;">      //获取bitmap  
  2.         MyApp myApp = (MyApp)getApplication();  
  3.         bitmap = myApp.getName();  
  4.         System.out.println("RotaingActivity w = " + bitmap.getWidth() + "H = " + bitmap.getHeight());  
  5.         myBitmap = bitmap;  
  6.         myWidth = bitmap.getWidth();  
  7.         myHeight = bitmap.getHeight();  
  8.           
  9.         // 创建操作图片用的matrix对象  
  10.         matrix = new Matrix();  
  11.         Drawable drawable = ImageDispose.bitmapToDrawable(bitmap);  
  12.         imageView.setBackgroundDrawable(drawable);  
  13.           
  14.           
  15.         btnCancel.setOnClickListener(new OnClickListener() {  
  16.               
  17.             @Override  
  18.             public void onClick(View v) {  
  19.                   
  20.                 RotaingActivity.this.finish();  
  21.             }  
  22.         });  
  23.           
  24.         btnRightRotaing.setOnClickListener(new OnClickListener() {  
  25.               
  26.             @Override  
  27.             public void onClick(View v) {  
  28.                 myBitmap = rotaingImageView(-90);  
  29.             }  
  30.         });  
  31.           
  32.         btnLeftRotaing.setOnClickListener(new OnClickListener() {  
  33.               
  34.             @Override  
  35.             public void onClick(View v) {  
  36.                 myBitmap =  rotaingImageView(+90);  
  37.             }  
  38.         });  
  39.           
  40.         btnOK.setOnClickListener(new OnClickListener() {  
  41.               
  42.             @Override  
  43.             public void onClick(View v) {  
  44.                 MyApp myApp = (MyApp)getApplication();  
  45.                 myApp.setName(myBitmap);//修改之后  
  46.                 System.out.println("OK resultcoder");  
  47.                 Intent intent = new Intent(RotaingActivity.this, SendMicoBlog.class);  
  48.                 setResult(6, intent);  
  49.                 RotaingActivity.this.finish();  
  50.             }  
  51.         });  
  52.     }  
  53.     private  Bitmap rotaingImageView(int angle2) {  
  54.         //旋转图片 动作  
  55.         matrix.postRotate(angle2);  
  56.         System.out.println("angle2=" + angle2);  
  57.         // 创建新的图片  
  58.         Bitmap resizedBitmap = Bitmap.createBitmap(bitmap, 00,  
  59.                 myWidth, myHeight, matrix, true);  
  60.         Drawable drawable = ImageDispose.bitmapToDrawable(resizedBitmap);  
  61.         imageView.setBackgroundDrawable(drawable);        
  62.         return resizedBitmap;  
  63.     }</span>  

第二种方式:就简单多了,直接自己出偷着把照片给处理了,不需要用户的操作,这样体验会更好一点。

在onActivityResult里面处理

[java]  view plain copy
  1. BitmapFactory.Options bitmapOptions = new BitmapFactory.Options();  
  2. bitmapOptions.inSampleSize = 8;  
  3. File file = new File(SD_CARD_TEMP_DIR);  
  4. /** 
  5.  * 获取图片的旋转角度,有些系统把拍照的图片旋转了,有的没有旋转 
  6.  */  
  7. int degree = ImageDispose.readPictureDegree(file.getAbsolutePath());  



 

[java]  view plain copy
  1. <span style="font-size:18px;">Bitmap cameraBitmap = BitmapFactory.decodeFile(SD_CARD_TEMP_DIR, bitmapOptions);  
  2. bitmap = cameraBitmap;  
  3. /** 
  4.  * 把图片旋转为正的方向 
  5.  */  
  6. bitmap = ImageDispose.rotaingImageView(degree, bitmap);  
  7. upload(bitmap);</span>  

[java]  view plain copy
  1. <span style="font-size:18px;">  /** 
  2.      * 旋转图片 
  3.      * @param angle 
  4.      * @param bitmap 
  5.      * @return Bitmap 
  6.      */  
  7.     public static Bitmap rotaingImageView(int angle , Bitmap bitmap) {  
  8.         //旋转图片 动作  
  9.         Matrix matrix = new Matrix();;  
  10.         matrix.postRotate(angle);  
  11.         System.out.println("angle2=" + angle);  
  12.         // 创建新的图片  
  13.         Bitmap resizedBitmap = Bitmap.createBitmap(bitmap, 00,  
  14.                 bitmap.getWidth(), bitmap.getHeight(), matrix, true);  
  15.         return resizedBitmap;  
  16.     }</span>  


 

[java]  view plain copy
  1. /** 
  2.  * 读取图片属性:旋转的角度 
  3.  * @param path 图片绝对路径 
  4.  * @return degree旋转的角度 
  5.  */  
  6.    public static int readPictureDegree(String path) {  
  7.        int degree  = 0;  
  8.        try {  
  9.                ExifInterface exifInterface = new ExifInterface(path);  
  10.                int orientation = exifInterface.getAttributeInt(ExifInterface.TAG_ORIENTATION, ExifInterface.ORIENTATION_NORMAL);  
  11.                switch (orientation) {  
  12.                case ExifInterface.ORIENTATION_ROTATE_90:  
  13.                        degree = 90;  
  14.                        break;  
  15.                case ExifInterface.ORIENTATION_ROTATE_180:  
  16.                        degree = 180;  
  17.                        break;  
  18.                case ExifInterface.ORIENTATION_ROTATE_270:  
  19.                        degree = 270;  
  20.                        break;  
  21.                }  
  22.        } catch (IOException e) {  
  23.                e.printStackTrace();  
  24.        }  
  25.        return degree;  
  26.    }  

http://www.ppmy.cn/news/706327.html

相关文章

v-for中的索引问题及图片的src绑定问题

vue.js中v-for的将索引作为点击函数的参数及图片的src属性的绑定问题 将v-for中的索引作为点击函数的参数传递到vue对象的函数中。 在表格中循环输出list集合中的内容&#xff0c;list里有多少数据有多少行。注意点击函数&#xff1a;click“decrease(index)”&#xff0c;要…

基础业务:图片懒加载

背景 大部分场景下我们对懒加载的定义实际上是对于图片而言的&#xff0c;对于图片进入可视区域之后去请求图片资源的这种情况、这种case实际上就是一个典型的懒加载的case。这些资源虽然是HTML DOM上的&#xff0c;但是这些资源没有进入可视区域之前&#xff0c;这些图片资源并…

【krpano】可拖拽相框遮罩

无意中从网上看到一组图片,突然萌生了做一个相框遮罩的想法,但是通过用基本的拖拽图层是无法实现,所以就想出了另外一种实现方法 1、用ps做一个半透明的图层,

个人界面 头像 图像添加,其他颜色的边框(内外都可以)

github也有这样的框架:https://github.com/vinc3m1/RoundedImageView 效果如下 请看效果图:(如此的丑是为了方便你们观察效果) *这个控件不同于之前介绍过的那个框架&#xff0c;这个仅仅能过将图片裁剪为圆形&#xff0c;没能弄成椭圆&#xff0c;也没有android:scaleType属…

利用selenium 实现对百度图片搜索中的图片的抓取

1. 前言 我们一直非常希望可以抓取百度图片上的图片&#xff0c; 自打我们接触了 python的urllib 库之后&#xff0c; 我们就非常想爬些图片下来&#xff0c; 尤其是从百度图片上面&#xff0c; 在很久之前&#xff0c; 百度图片上的图片是不加密的&#xff0c; 分析他的静态网…

BeatSaber节奏光剑双手柄MR教程

一、物料准备&#xff1a; 1 显卡1060及以上的PC主机 2 HTC VIVE头盔一套&#xff08;头盔直插显卡上的HDMI接口&#xff09; 3 1080P摄像头一个&#xff08;插USB3.0&#xff09; 4 绿幕一套&#xff0c;能覆盖整个摄像头的可拍摄范围即可&#xff08;绿色的布就行&#xff09…

vue中,前端压缩图片上传服务器

效果&#xff1a; 上传前&#xff1a; 上传后&#xff1a; 压缩效果一览&#xff1a; 代码&#xff1a; 这个文件封装的是图片压缩方法&#xff1a;取名api.js //base64转码&#xff08;压缩完成后的图片为base64编码&#xff0c;这个方法可以将base64编码转回file文件&am…

联邦学习哪家强,中国山东找saber

ERROR&#xff1a;本文要素过多&#xff0c;包含开车、粗鄙之语、魔法、表情包等。但不包含联邦学习的具体说明&#xff0c;相关内容&#xff0c;文末给出传送门&#xff0c;请自行参阅。 0. 先吐槽 人呐就都不知道&#xff0c;自己不可以预料&#xff0c;一个人的职业发展啊…