Android开发实践:自己动手编写图片剪裁应用(2)

简介:

其实Android系统本身也提供了图片剪裁的模块,我们可以直接通过Intent来调用系统的图片剪裁功能,本文我们就先了解一下系统自带的图片剪裁功能是如何调用的吧。


  1. 得到被剪裁图片的URL地址


既然是图片剪裁,就一定要有被剪裁的图片,由于图片数据一般很大,为了防止内存溢出,普通APP与Android系统图片剪裁应用之间是通过URL来传递图片地址的。这个URL与我们常说见的网络URL不一样,它并不是HTTP开头,而是以file或者content开头的字符串,例如:


1
2
3
“file: ///sdcard/test.jpg”
 
“content: //media/external/images/media/21936”

这里,我们首先介绍获取图片URL的方法:


(1) 从SDCard中得到图片的URL


假设知道图片存放的路径位于“/sdcard/test.jpg”,那么,可以通过下面这种方式来得到URL:


1
Uri imageUri = Uri.fromFile( new  File( "/sdcard/test.jpg" ));

当然,如果图片是从网络获取的,并不存在于sdcard中,则可以先保存一份临时文件到sdcard中,再通过上述方法得到URL。


注:通过这种方式得到的URL,一般以“file://”开头。


(2) 从多媒体数据库中得到图片的URL


Android系统会在后台定期扫描存储在系统中的多媒体文件,如:音乐、图片和视频等,相关的信息会存放在系统的多媒体数据库中,位于/data/data/com.android.providers.media/databases中,我们可以通过检索该数据库得到图片的URL(例如:通过检索数据库得到系统最后一次添加/修改的照片URL),也可以通过Intent.ACTION_PICK来调用系统的图片选择器来选择一张图片,图片选择器会将图片的URL地址放入Intent的data中返回。


后者的应用更多一些,我们主要介绍一下后者,即通过Intent.ACTION_PICK来得到图片URL地址,方法如下:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public  void  pickImage() {
     Intent intent =  new  Intent(Intent.ACTION_PICK);
     intent.setType( "image/*" );
     startActivityForResult(intent,REQUEST_CODE_PICK_IMAGE);
}
 
@Override
protected  void  onActivityResult( int  requestCode,  int  resultCode, Intent data) {
     if  (resultCode != RESULT_OK) {
         return ;
     }
     if ( requestCode == REQUEST_CODE_PICK_IMAGE ) {
         Uri imageUri = data.getData();
         //......
     }
}


注:通过这种方式得到的URL,一般以“content://media”开头。


(3) 调用系统的相机拍一张照片


当然,被剪裁的图片也可以是通过Camera拍摄的一张照片,方法如下:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Uri pictureURL = Uri.fromFile( new  File( "/sdcard/temp.jpg" ));
 
public  void  takenPicture() {
     Intent intent =  new  Intent(MediaStore.ACTION_IMAGE_CAPTURE);
     intent.putExtra(MediaStore.EXTRA_OUTPUT,pictureURL );
     startActivityForResult(intent,REQUEST_CODE_TAKEN_PICTURE);
}
 
@Override
protected  void  onActivityResult( int  requestCode,  int  resultCode, Intent data) {
     if  (resultCode != RESULT_OK) {
         return ;
     }
     if ( requestCode == REQUEST_CODE_TAKEN_PICTURE ) {
         Uri imageUri = pictureURL;
         //......
     }
}


通过代码你可能已经注意到了,其实这种方式得到的图片URL,与第一种方式是一样的,通过图片的存储路径转化过来的,只不过传递给了系统Camera应用中。


2. 通过Intent调用系统的图片剪裁功能


有了图片的URL,调用系统的图片剪裁就很简单了,只需要构建一个Intent对象,并设置相关参数即可,用法示例如下:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
public  void  test( Uri imageUri ) {
     Uri croppedUri = Uri.fromFile( new  File( "/sdcard/cropped.jpg" ));
     startSystemCropImage(imageUri,croppedUri);
}
 
public  void  startSystemCropImage( Uri src, Uri dst ) {
 
     Intent intent =  new  Intent( "com.android.camera.action.CROP" );      
     intent.putExtra( "crop" "true" );    
 
     // 设置剪裁图片的源/目的地址URL
     intent.setDataAndType(src, "image/*" );
     intent.putExtra(MediaStore.EXTRA_OUTPUT,dst);
 
     // 设置剪裁图片的宽高比
     //intent.putExtra("aspectX", 2);   
     //intent.putExtra("aspectY", 1);
     
     // 固定剪裁图片的宽高值
     //intent.putExtra("outputX", 680); 
     //intent.putExtra("outputY", 480);    
     
     // 为了防止内存限制以及各个厂商返回的数据不统一,建议不要直接使用这个返回的数据,而是数据返回的URL
     intent.putExtra( "return-data" false );
     
     startActivityForResult(intent, REQUEST_CODE_SYSTEM_CROPPER);
}
 
@Override
protected  void  onActivityResult( int  requestCode,  int  resultCode, Intent data) {
 
     if  (resultCode != RESULT_OK) {
         return ;
     }
 
     if ( requestCode == REQUEST_CODE_IMAGE_CROPPER ) {
             
         Uri croppedUri = data.getExtras().getParcelable(MediaStore.EXTRA_OUTPUT);
     
         InputStream in =  null ;
         try  {
             in = getContentResolver().openInputStream(croppedUri);
             Bitmap b = BitmapFactory.decodeStream(in);
             mImageView.setImageBitmap(b);            
        
         catch  (FileNotFoundException e) {
             e.printStackTrace();
         }          
     }
     super .onActivityResult(requestCode, resultCode, data);
}


3. 小结


注意添加读写SDCard的权限:


1
<uses-permission android:name= "android.permission.WRITE_EXTERNAL_STORAGE"  />



本文转自 Jhuster 51CTO博客,原文链接:http://blog.51cto.com/ticktick/1602611,如需转载请自行联系原作者
相关文章
|
10月前
|
存储 Android开发
如何查看Flutter应用在Android设备上已被撤销的权限?
如何查看Flutter应用在Android设备上已被撤销的权限?
524 64
|
4月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
715 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
4月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
588 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
4月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
914 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
5月前
|
开发工具 Android开发
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
692 11
X Android SDK file not found: adb.安卓开发常见问题-Android SDK 缺少 `adb`(Android Debug Bridge)-优雅草卓伊凡
|
4月前
|
移动开发 Android开发
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
267 0
|
5月前
|
Java 开发工具 Maven
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
【01】完整的安卓二次商业实战-详细的初级步骤同步项目和gradle配置以及开发思路-优雅草伊凡
534 6
|
7月前
|
安全 数据库 Android开发
在Android开发中实现两个Intent跳转及数据交换的方法
总结上述内容,在Android开发中,Intent不仅是活动跳转的桥梁,也是两个活动之间进行数据交换的媒介。运用Intent传递数据时需注意数据类型、传输大小限制以及安全性问题的处理,以确保应用的健壯性和安全性。
524 11
|
11月前
|
JavaScript Linux 网络安全
Termux安卓终端美化与开发实战:从下载到插件优化,小白也能玩转Linux
Termux是一款安卓平台上的开源终端模拟器,支持apt包管理、SSH连接及Python/Node.js/C++开发环境搭建,被誉为“手机上的Linux系统”。其特点包括零ROOT权限、跨平台开发和强大扩展性。本文详细介绍其安装准备、基础与高级环境配置、必备插件推荐、常见问题解决方法以及延伸学习资源,帮助用户充分利用Termux进行开发与学习。适用于Android 7+设备,原创内容转载请注明来源。
3188 77
|
7月前
|
移动开发 Java 编译器
Kotlin与Jetpack Compose:Android开发生态的演进与架构思考
本文从资深Android工程师视角深入分析Kotlin与Jetpack Compose在Android系统中的技术定位。Kotlin通过空安全、协程等特性解决了Java在移动开发中的痛点,成为Android官方首选语言。Jetpack Compose则引入声明式UI范式,通过重组机制实现高效UI更新。两者结合不仅提升开发效率,更为跨平台战略和现代架构模式提供技术基础,代表了Android开发生态的根本性演进。
338 0

热门文章

最新文章