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裁剪图片
Android选择图片
android 拍照相册裁剪、android 拍照裁剪、android 拍照裁剪上传、android 拍照裁剪demo、android拍照裁剪 旋转,以便于您获取更多的相关知识。

时间: 2024-11-01 15:56:22

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

使用Java代码在Android中实现图片裁剪功能_Android

前言Android应用中经常会遇到上传相册图片的需求,这里记录一下如何进行相册图片的选取和裁剪. 相册选取图片1. 激活相册或是文件管理器,来获取相片,代码如下: private static final int TAKE_PICTURE_FROM_ALBUM = 1; private void takePictureFromAlbum() { Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.setType("image

Android自定义View实现照片裁剪框与照片裁剪功能_Android

本文所需要实现的就是这样一种有逼格的效果: 右上角加了个图片框,按下确定可以裁剪正方形区域里的图片并显示在右上角. 实现思路: 1:首先需要自定义一个ZoomImageView来显示我们需要的图片,这个View需要让图片能够以合适的位置展现在当前布局的图片展示区域内(合适的位置值的是:如果图片长度大于屏幕,则压缩图片长度至屏幕宽度,高度等比压缩并居中显示,如果图片高度大于屏幕,则压缩图片高度至屏幕高度,长度等比压缩并居中显示.): 2:然后需要实现这个拖动的框框,该框框实现的功能有四点:拖动.扩

深入剖析Android的Volley库中的图片加载功能_Android

一.基本使用要点回顾 Volley框架在请求网络图片方面也做了很多工作,提供了好几种方法.本文介绍使用ImageLoader来进行网络图片的加载. ImageLoader的内部使用ImageRequest来实现,它的构造器可以传入一个ImageCache缓存形参,实现了图片缓存的功能,同时还可以过滤重复链接,避免重复发送请求. 下面是ImageLoader加载图片的实现方法: public void displayImg(View view){ ImageView imageView = (Im

Android UI之ImageView实现图片旋转和缩放_Android

这一篇,给大家介绍一下ImageView控件的使用,ImageView主要是用来显示图片,可以对图片进行放大.缩小.旋转的功能. android:sacleType属性指定ImageVIew控件显示图片的方式,例如:center表示图像以不缩放的方式显示在ImageView控件的中心,如果设置为fitCenter,表示图像按照比例缩放至合适的位置,并在ImageView控件的中心. 首先我们开发一个简单的案例,实现图片的放大缩小和旋转: 先看看实现的效果: 缩放截图1: 缩放截图2: 旋转截图1

Android编程实现只显示图片一部分的方法_Android

本文实例讲述了Android编程实现只显示图片一部分的方法.分享给大家供大家参考,具体如下: 在Android应用程序中加载一张图片,然后把它显示出来这是一件非常容易的事情,那怎么才能显示一张图片的一小部分呢,一种做法是把图片ps一下,要显示的那部分单独存成一张图片,然后程序中加载它,并把它显示出来.但这样会增加程序的图片量.对一张完整的图,用程序去切割你想要的那部分也是很简单的. 下面实现的一个程序,是加载了一张图片,然后经过变换让图片填充到手机的整个屏幕,然后在屏幕的中间显示图片中间的100