Android实现图片区域裁剪功能

 更新时间:2017年12月19日 08:39:56   作者:LCore  
这篇文章主要为大家详细介绍了Android实现图片区域裁剪功能,调用相册、拍照实现缩放、切割图片,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

今天做的就是关于实现图片的区域裁剪功能。由于项目功能的需要笔者需要实现PDF文档的阅读,并且就某个页面实现“图片”裁剪(一个页面理解为一张图片)。笔者对着方面是一点儿也不熟悉,因此就得上网查资料了。之后笔者找到了Android可以通过调用系统相册、拍照实现图片的裁剪、缩放功能。

这一过程就像是在某个应用中上传头像,并对头像进行调整。现做一个记录与分享。

首先我们还是来看看实际的效果图吧!

一开始的界面:            

接下来:

看看实际实现区域裁剪的效果吧?需要注意的是这是系统自带的功能来实现的。

如何实现的呢?源代码如下:

直接看Activity的代码,布局文件这里就不给出来了(比较简单,就一个button)

package com.xiaoma.piccut.demo; 
 
import java.io.File; 
import android.app.Activity; 
import android.app.AlertDialog; 
import android.content.DialogInterface; 
import android.content.Intent; 
import android.graphics.Bitmap; 
import android.graphics.drawable.BitmapDrawable; 
import android.graphics.drawable.Drawable; 
import android.net.Uri; 
import android.os.Bundle; 
import android.os.Environment; 
import android.provider.MediaStore; 
import android.view.View; 
import android.view.View.OnClickListener; 
import android.widget.Button; 
import android.widget.ImageButton; 
import android.widget.ImageView; 
/** 
 * 调用系统相册或者拍照来实现图片的裁剪、缩放 
 * @author Kiritor 
 **/ 
public class PicCutDemoActivity extends Activity { 
 
 private Button btn = null; 
 /** Called when the activity is first created. */ 
 @Override 
 public void onCreate(Bundle savedInstanceState) { 
  super.onCreate(savedInstanceState); 
  setContentView(R.layout.main); 
  //初始化 
  init(); 
 } 
  
 /** 
  * 初始化方法实现 
  */ 
 private void init() { 
  btn = (Button) findViewById(R.id.button1); 
  btn.setOnClickListener(new OnClickListener() { 
   @Override 
   public void onClick(View v) { 
    ShowPickDialog(); 
   } 
  }); 
 } 
 
  
 /** 
  * 控件点击事件实现 
  * 
  * 因为有朋友问不同控件的背景图裁剪怎么实现, 
  * 我就在这个地方用了三个控件,只为了自己记录学习 
  * 大家觉得没用的可以跳过啦 
  */ 
  
 
 /** 
  * 选择提示对话框 
  */ 
 private void ShowPickDialog() { 
  new AlertDialog.Builder(this) 
    .setTitle("设置头像...") 
    .setNegativeButton("相册", new DialogInterface.OnClickListener() { 
     public void onClick(DialogInterface dialog, int which) { 
      dialog.dismiss(); 
       
      Intent intent = new Intent(Intent.ACTION_PICK, null); 
       
      /** 
       * 下面这句话,与其它方式写是一样的效果,如果: 
       * intent.setData(MediaStore.Images.Media.EXTERNAL_CONTENT_URI); 
       * intent.setType(""image/*");设置数据类型 
       * 如果朋友们要限制上传到服务器的图片类型时可以直接写如:"image/jpeg 、 image/png等的类型" 
       */ 
      intent.setDataAndType( 
        MediaStore.Images.Media.EXTERNAL_CONTENT_URI, 
        "image/*"); 
      startActivityForResult(intent, 1); 
 
     } 
    }) 
    .setPositiveButton("拍照", new DialogInterface.OnClickListener() { 
     public void onClick(DialogInterface dialog, int whichButton) { 
      dialog.dismiss(); 
      Intent intent = new Intent( 
        MediaStore.ACTION_IMAGE_CAPTURE); 
      //下面这句指定调用相机拍照后的照片存储的路径 
      intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri 
        .fromFile(new File(Environment 
          .getExternalStorageDirectory(), 
          "xiaoma.jpg"))); 
      startActivityForResult(intent, 2); 
     } 
    }).show(); 
 } 
 
 @Override 
 protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
  switch (requestCode) { 
  // 如果是直接从相册获取 
  case 1: 
   startPhotoZoom(data.getData()); 
   break; 
  // 如果是调用相机拍照时 
  case 2: 
   File temp = new File(Environment.getExternalStorageDirectory() 
     + "/test.jpg"); 
   startPhotoZoom(Uri.fromFile(temp)); 
   break; 
  // 取得裁剪后的图片 
  case 3: 
   if(data != null){ 
    setPicToView(data); 
   } 
   break; 
  default: 
   break; 
 
  } 
  super.onActivityResult(requestCode, resultCode, data); 
 } 
  
 /** 
  * 裁剪图片方法实现 
  * @param uri 
  */ 
 public void startPhotoZoom(Uri uri) { 
  Intent intent = new Intent("com.android.camera.action.CROP"); 
  intent.setDataAndType(uri, "image/*"); 
  //下面这个crop=true是设置在开启的Intent中设置显示的VIEW可裁剪 
  intent.putExtra("crop", "true"); 
  // aspectX aspectY 是宽高的比例 
  intent.putExtra("aspectX", 1); 
  intent.putExtra("aspectY", 1); 
  // outputX outputY 是裁剪图片宽高 
  intent.putExtra("outputX", 150); 
  intent.putExtra("outputY", 150); 
  intent.putExtra("return-data", true); 
  startActivityForResult(intent, 3); 
 } 
  
 /** 
  * 保存裁剪之后的图片数据 
  * @param picdata 
  */ 
 private void setPicToView(Intent picdata) { 
  Bundle extras = picdata.getExtras(); 
  if (extras != null) { 
   Bitmap photo = extras.getParcelable("data"); 
   Drawable drawable = new BitmapDrawable(photo); 
    
  } 
 } 
 
} 

Ok!一个简单的图片裁剪功能就完成了,完整的源码:Android实现图片裁剪功能

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

相关文章

  • Android中CountDownTimer类详解

    Android中CountDownTimer类详解

    本文详细讲解了Android中CountDownTimer类,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-12-12
  • 浅谈Glide缓存key的问题

    浅谈Glide缓存key的问题

    这篇文章主要介绍了浅谈Glide缓存key的问题,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • android获取联系人示例分享

    android获取联系人示例分享

    这篇文章主要介绍了android获取联系人示例,需要的朋友可以参考下
    2014-02-02
  • android设计模式之单例模式详解

    android设计模式之单例模式详解

    这篇文章主要介绍了android设计模式中的单例模式详解,需要的朋友可以参考下
    2014-04-04
  • Android开发手册Button实现selector选择器

    Android开发手册Button实现selector选择器

    这篇文章主要为大家介绍了Android开发手册Button实现selector选择器,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • Android自定义ViewGroup实现标签流容器FlowLayout

    Android自定义ViewGroup实现标签流容器FlowLayout

    这篇文章主要介绍了Android自定义ViewGroup实现FlowLayout标签流容器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 详解关于MIUI 9沉浸式状态栏的最新适配

    详解关于MIUI 9沉浸式状态栏的最新适配

    由于各系统版本的限制,沉浸式状态栏对系统有要求,本篇文章主要介绍了详解关于MIUI 9沉浸式状态栏的最新适配,非常具有实用价值,需要的朋友可以参考下
    2018-05-05
  • Android UI组件LinearLayout线性布局详解

    Android UI组件LinearLayout线性布局详解

    这篇文章主要为大家详细介绍了AndroidUI组件LinearLayout线性布局,具有一定的实用性,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • Android保存Activity状态的方法

    Android保存Activity状态的方法

    这篇文章主要介绍了Android保存Activity状态的方法,结合实例形式较为详细的分析了Android保存Activity状态的原理、实现步骤及相关注意事项,需要的朋友可以参考下
    2016-08-08
  • android顶部(toolbar)搜索框实现代码

    android顶部(toolbar)搜索框实现代码

    这篇文章主要介绍了android顶部(toolbar)搜索框实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01

最新评论