当前位置: 首页 > 编程笔记 >

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

薛保臣
2023-03-14
本文向大家介绍Android实现拍照、选择相册图片并裁剪功能,包括了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"/>

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

 类似资料:
  • 本文向大家介绍Android实现拍照、选择图片并裁剪图片功能,包括了Android实现拍照、选择图片并裁剪图片功能的使用技巧和注意事项,需要的朋友参考一下 一、 实现拍照、选择图片并裁剪图片效果 按照之前博客的风格,首先看下实现效果。      二、 uCrop项目应用 想起之前看到的Yalantis/uCrop效果比较绚,但是研究源码之后发现在定制界面方面还是有一点的限制,于是在它的基础上做了修

  • 本文向大家介绍android完美实现 拍照 选择图片 剪裁等代码分享,包括了android完美实现 拍照 选择图片 剪裁等代码分享的使用技巧和注意事项,需要的朋友参考一下 前言,版本兼容问题主要是由于4.4以前和4.4以后的Uri的格式不同所造成的错误 1.拍照 和选择图片   ①选择图片   ②拍照 2.获取系统传来的值 标记符 3.图片选取后 根据Url 转成流 并保存 4.保存图片 记得加权

  • 本文向大家介绍Android编程实现图片拍照剪裁的方法,包括了Android编程实现图片拍照剪裁的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android实现图片拍照剪裁的方法。分享给大家供大家参考,具体如下: 调用系统的裁剪工具对相册或者拍照的图片进行裁剪。 startActivityforResult用的很恰当,一些系统action需要注意。 XML文件: 希望本文所述对大家

  • 本文向大家介绍Android实现读取相机(相册)图片并进行剪裁,包括了Android实现读取相机(相册)图片并进行剪裁的使用技巧和注意事项,需要的朋友参考一下 我们先说一下思路,在android系统中就自带了图片剪切的应用,所以,我们只需要将我们获取到的相片传给图片剪切应用,再将剪切好的相片返回到我们自己的界面显示就ok了 在开发一些APP的过程中,我们可能涉及到头像的处理,比如从手机或者相册获取

  • 本文向大家介绍Android图片或拍照选择图片功能实例代码,包括了Android图片或拍照选择图片功能实例代码的使用技巧和注意事项,需要的朋友参考一下 前言 一般公司都有更换用户头像功能,需要从图库中选择图片或者拍照,基本还会对图片进行裁剪。最近抽空就做了一些简单的封装,方便以后使用。主要是用了建造者模式,链式调用,方便简单。可以自定义图片路径,附带裁剪和简单压缩功能。使用实例如下: 相册图片 说

  • 本文向大家介绍android系统拍照结合android-crop裁剪图片,包括了android系统拍照结合android-crop裁剪图片的使用技巧和注意事项,需要的朋友参考一下 在一个应用中更换用户的头像,一般有拍照和从图库中选择照片两种方法,现在网上也有很多开源的,但是很多都太复杂。而 Android-crop 这个库比较小,代码不复杂,比较适合,但是它没有拍照这个功能,需要我们自己整合进去。