Android实现拍照、选择相册图片并裁剪功能

通过拍照或相册中获取图片,并进行裁剪操作,然后把图片显示到ImageView上。
 当然也可以上传到服务器(项目中绝大部分情况是上传到服务器),参考网上资料及结合项目实际情况,
 测试了多款手机暂时没有发现严重问题。代码有注释,直接贴代码:

public class UploadPicActivity extends Activity implements View.OnClickListener { private Button take_photo_btn; private Button select_photo_btn; private ImageView photo_iv; //使用照相机拍照获取图片 public static final int TAKE_PHOTO_CODE = 1; //使用相册中的图片 public static final int SELECT_PIC_CODE = 2; //图片裁剪 private static final int PHOTO_CROP_CODE = 3; //定义图片的Uri private Uri photoUri; //图片文件路径 private String picPath; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_upload_pic); initViews(); } private void initViews() { this.take_photo_btn = (Button) findViewById(R.id.take_photo_btn); this.take_photo_btn.setOnClickListener(this); this.select_photo_btn = (Button) findViewById(R.id.select_photo_btn); this.select_photo_btn.setOnClickListener(this); this.photo_iv = (ImageView) findViewById(R.id.photo_iv); } @Override public void onClick(View view) { switch (view.getId()) { //拍照 case R.id.take_photo_btn: picTyTakePhoto(); break; //选择图库 case R.id.select_photo_btn: pickPhoto(); break; } } /** * 拍照获取图片 */ private void picTyTakePhoto() { //判断SD卡是否存在 String SDState = Environment.getExternalStorageState(); if (SDState.equals(Environment.MEDIA_MOUNTED)) { Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);//"android.media.action.IMAGE_CAPTURE" /*** * 使用照相机拍照,拍照后的图片会存放在相册中。使用这种方式好处就是:获取的图片是拍照后的原图, * 如果不实用ContentValues存放照片路径的话,拍照后获取的图片为缩略图有可能不清晰 */ ContentValues values = new ContentValues(); photoUri = getContentResolver().insert(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values); intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, photoUri); startActivityForResult(intent, TAKE_PHOTO_CODE); } else { Toast.makeText(this, "内存卡不存在", Toast.LENGTH_LONG).show(); } } /*** * 从相册中取图片 */ private void pickPhoto() { Intent intent = new Intent(Intent.ACTION_PICK, null); intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*"); startActivityForResult(intent, SELECT_PIC_CODE); } @Override public void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (resultCode == Activity.RESULT_OK) { //从相册取图片,有些手机有异常情况,请注意 if (requestCode == SELECT_PIC_CODE) { if (null != data && null != data.getData()) { photoUri = data.getData(); picPath = uriToFilePath(photoUri); startPhotoZoom(photoUri, PHOTO_CROP_CODE); } else { Toast.makeText(this, "图片选择失败", Toast.LENGTH_LONG).show(); } } else if (requestCode == TAKE_PHOTO_CODE) { String[] pojo = {MediaStore.Images.Media.DATA}; Cursor cursor = managedQuery(photoUri, pojo, null, null, null); if (cursor != null) { int columnIndex = cursor.getColumnIndexOrThrow(pojo[0]); cursor.moveToFirst(); picPath = cursor.getString(columnIndex); if (Build.VERSION.SDK_INT < 14) { cursor.close(); } } if (picPath != null) { photoUri = Uri.fromFile(new File(picPath)); startPhotoZoom(photoUri, PHOTO_CROP_CODE); } else { Toast.makeText(this, "图片选择失败", Toast.LENGTH_LONG).show(); } } else if (requestCode == PHOTO_CROP_CODE) { if (photoUri != null) { Bitmap bitmap = BitmapFactory.decodeFile(picPath); if (bitmap != null) { //这里可以把图片进行上传到服务器操作 photo_iv.setImageBitmap(bitmap); } } } } } /** * @param * @description 裁剪图片 * @author ldm * @time 2016/11/30 15:19 */ private void startPhotoZoom(Uri uri, int REQUE_CODE_CROP) { Intent intent = new Intent("com.android.camera.action.CROP"); intent.setDataAndType(uri, "image/*"); // crop=true是设置在开启的Intent中设置显示的VIEW可裁剪 intent.putExtra("crop", "true"); // 去黑边 intent.putExtra("scale", true); intent.putExtra("scaleUpIfNeeded", true); // aspectX aspectY 是宽高的比例,根据自己情况修改 intent.putExtra("aspectX", 3); intent.putExtra("aspectY", 2); // outputX outputY 是裁剪图片宽高像素 intent.putExtra("outputX", 600); intent.putExtra("outputY", 400); intent.putExtra("outputFormat", Bitmap.CompressFormat.JPEG.toString()); //取消人脸识别功能 intent.putExtra("noFaceDetection", true); //设置返回的uri intent.putExtra(MediaStore.EXTRA_OUTPUT, uri); //设置为不返回数据 intent.putExtra("return-data", false); startActivityForResult(intent, REQUE_CODE_CROP); } /** * @param * @description 把Uri转换为文件路径 * @author ldm * @time 2016/11/30 15:22 */ private String uriToFilePath(Uri uri) { //获取图片数据 String[] proj = {MediaStore.Images.Media.DATA}; //查询 Cursor cursor = managedQuery(uri, proj, null, null, null); //获得用户选择的图片的索引值 int image_index = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA); cursor.moveToFirst(); //返回图片路径 return cursor.getString(image_index); } }

布局文件长这样:

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:padding="16dp"> <Button android:id="@+id/take_photo_btn" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:gravity="center" android:text="拍照" android:textSize="16sp"/> <Button android:id="@+id/select_photo_btn" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:gravity="center" android:text="选择图片" android:textSize="16sp"/> <ImageView android:id="@+id/photo_iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_horizontal" android:layout_marginTop="20dp"/> </LinearLayout>

最后不要忘记在AndroidManifest.xml中添加UploadPicActivity及权限:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

时间: 2024-09-16 02:41:30

Android实现拍照、选择相册图片并裁剪功能的相关文章

Android实现拍照、选择相册图片并裁剪功能_Android

通过拍照或相册中获取图片,并进行裁剪操作,然后把图片显示到ImageView上.  当然也可以上传到服务器(项目中绝大部分情况是上传到服务器),参考网上资料及结合项目实际情况,  测试了多款手机暂时没有发现严重问题.代码有注释,直接贴代码: public class UploadPicActivity extends Activity implements View.OnClickListener { private Button take_photo_btn; private Button s

Android仿微信QQ设置图形头像裁剪功能_Android

最近在做毕业设计,想有一个功能和QQ一样可以裁剪头像并设置圆形头像,额,这是设计狮的一种潮流. 而纵观现在主流的APP,只要有用户系统这个功能,这个需求一般都是在(bu)劫(de)难(bu)逃(xue)! 图片裁剪实现方式有两种,一种是利用系统自带的裁剪工具,一种是使用开源工具Cropper.本节就为大家带来如何使用系统自带的裁剪工具进行图片裁剪~ 还是先来个简单的运行图. 额,简单说下,我待会会把代码写成小demo分享给大家,在文章末尾会附上github链接,需要的可以自行下载~ 下面来简单分

Android仿微信QQ设置图形头像裁剪功能

最近在做毕业设计,想有一个功能和QQ一样可以裁剪头像并设置圆形头像,额,这是设计狮的一种潮流. 而纵观现在主流的APP,只要有用户系统这个功能,这个需求一般都是在(bu)劫(de)难(bu)逃(xue)! 图片裁剪实现方式有两种,一种是利用系统自带的裁剪工具,一种是使用开源工具Cropper.本节就为大家带来如何使用系统自带的裁剪工具进行图片裁剪~ 还是先来个简单的运行图. 额,简单说下,我待会会把代码写成小demo分享给大家,在文章末尾会附上github链接,需要的可以自行下载~ 下面来简单分

Android启动相机拍照并返回图片_Android

具体实现过程请看下面代码: 简单的调用了一下系统的拍照功能 代码如下所示: //拍照的方法 private void openTakePhoto(){ /** * 在启动拍照之前最好先判断一下sdcard是否可用 */ String state = Environment.getExternalStorageState(); //拿到sdcard是否可用的状态码 if (state.equals(Environment.MEDIA_MOUNTED)){ //如果可用 Intent intent

Asp.Net平台下的图片在线裁剪功能的实现代码(源码打包)_实用技巧

1.前台展现实现 网上找到这个jquery.Jcrop,稍看了下,发现它提供的效果完全能满足项目需求. 官方网址:http://deepliquid.com/content/Jcrop.html,感兴趣的朋友可去看看. 页面先引用相关样式和脚本: 复制代码 代码如下: <link href="Styles/jquery.Jcrop.css" rel="stylesheet" type="text/css" /> <script

Android开发使用Handler实现图片轮播功能示例

本文实例讲述了Android使用Handler实现图片轮播功能.分享给大家供大家参考,具体如下: 提前定义好一个Runnable接口,然后用handler调用. Mainactivity代码如下: package com.example.handle_01; import android.os.Handler; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import android.wid

Android二级缓存加载图片实现照片墙功能

实现二级缓存加载图片的功能,在使用DiskLruCache时,需先在工程中添加名为libcore.io的包,并将DiskLruCache.Java文件放进去.DiskLruCache直接百度下载即可. 在GridView的适配器中,为ImageView添加图片时,先从内存缓存中加载,内存中无缓存的话则在磁盘缓存中加载,磁盘缓存也没有的话开启线程下载,然后将下载的图片缓存到磁盘,内存中.下载的图片最好先进行压缩,文章最后给出了压缩代码,但本例中并未实现压缩. /*二级缓存实现图片墙功能,先在内存中

Android设置拍照或者上传本地图片的示例_Android

前几天,我们客户端这边收到了市场部的一个需求,需要在我们订单成交后,我们的客户端有一个上传交易凭证的功能,那么如何在Android实现上传图片的这个功能呢?在我进行编码之前,我先问自己几个问题. 第一, 图片是直接选择图库里的,还是需要拍照和选择图片两个选项? 因为在选择图片的时候,会有一个拍照的按钮,也可以实现拍照的功能. 第二, 需不需要本地缓存? 本地缓存值得是,在我们的图片上传后,是否在下次直接显示,而不是从服务器读取. 第三,图片是否需要压缩? 众所周知,图片这种资源,因为体积较大,在

Android优化查询加载大数量的本地相册图片_Android

一.概述 讲解优化查询相册图片之前,我们先来看下PM提出的需求,PM的需求很简单,就是要做一个类似微信的本地相册图片查询控件,主要包含两个两部分: 进入图片选择页面就要显示出手机中所有的照片,包括系统相册图片和其他目录下的所有图片,并按照时间倒叙排列 切换相册功能,切换相册页面列出手机中所有的图片目录列表,并且显示出每个目录下所有的图片个数以及封面图片 这两个需求看似简单,实则隐藏着一系列的性能优化问题.在做优化之前,我们调研了一些其他比较出名的app在加载大数量图片的性能表现(gif录制的不够