调取系统相册和照相机选取图片

2023-11-29 09:58

本文主要是介绍调取系统相册和照相机选取图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在让用户自定义头像或皮肤的时候  可能会采取照相或选取相册等方法来实现用户自定义,这里我们就简单实现一下~ 

在这里先贴出布局-----仅供参考

activity_main://一张图片而已  很简单

<ImageView   android:layout_width="fill_parent"  android:layout_height="fill_parent"  android:id="@+id/img_true"  />  

activity_select_photo://选择图片   其中有一些图片资源和动画,在文末分享给大家


<?xml version="1.0" encoding="utf-8"?>  
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="fill_parent"  android:layout_height="wrap_content"  android:gravity="center_horizontal" >  <LinearLayout  android:id="@+id/dialog_layout"  android:layout_width="fill_parent"  android:layout_height="wrap_content"  android:layout_alignParentBottom="true"  android:layout_marginLeft="10dip"  android:layout_marginRight="10dip"  android:layout_marginBottom="10dp"  android:gravity="center_horizontal"  android:orientation="vertical" >  <LinearLayout  android:layout_width="fill_parent"  android:layout_height="wrap_content"  android:background="@drawable/select_photo_up_bg"  android:orientation="vertical"  android:paddingBottom="5dp"  android:paddingTop="5dp" >  <Button  android:id="@+id/btn_take_photo"  android:layout_width="fill_parent"  android:layout_height="35dp"  android:background="@drawable/select_photo_bg"  android:text="@string/paizhaoxuanqu"  android:textStyle="bold" />  <View  android:layout_width="fill_parent"  android:layout_height="0.5px"  android:background="#828282" />  <Button  android:id="@+id/btn_pick_photo"  android:layout_width="fill_parent"  android:layout_height="35dp"  android:layout_marginTop="0dip"  android:background="@drawable/select_photo_bg"  android:text="@string/xiangcexuanqu"  android:textStyle="bold" />  </LinearLayout>  <Button  android:id="@+id/btn_cancel"  android:layout_width="fill_parent"  android:layout_height="35dp"  android:layout_marginTop="20dip"  android:background="@drawable/select_photo_bg"  android:paddingBottom="5dp"  android:paddingTop="5dp"  android:text="@string/exit"  android:textColor="#ffff0000"  android:textStyle="bold" />  </LinearLayout>  </RelativeLayout>  

-----------MainActivity-----------

图片监听事件   点击跳转选择页面使用回调


<span style="white-space:pre">    </span>private ImageView imgtrue;  /** 选择文件 */  public static final int TO_SELECT_PHOTO = 1;  <span style="white-space:pre">        </span>//图片选择事件  imgtrue.setOnClickListener(new OnClickListener() {  Intent intent;  @Override  public void onClick(View v) {  // TODO Auto-generated method stub  intent = new Intent(this, SelectPhotoActivity.class);  startActivityForResult(intent, TO_SELECT_PHOTO);  intent = null;  }  });  


回调方法 接收图片地址  设置给控件

@SuppressWarnings("deprecation")  
@Override  
protected void onActivityResult(int requestCode, int resultCode, Intent data) {  if (resultCode == Activity.RESULT_OK && requestCode == TO_SELECT_PHOTO) {  picPath = data.getStringExtra(SelectPhotoActivity.KEY_PHOTO_PATH);  Bitmap bm = BitmapFactory.decodeFile(picPath);  zoomBitmap = zoomBitmap(bm, 300, 300);  imgtrue.setBackgroundDrawable(new BitmapDrawable(bm));  }  super.onActivityResult(requestCode, resultCode, data);  
}  

将获取的图片按宽高进行缩放

/** * 将原图按照指定的宽高进行缩放 *  * @param oldBitmap * @param newWidth * @param newHeight * @return */  
private Bitmap zoomBitmap(Bitmap oldBitmap, int newWidth, int newHeight) {  int width = oldBitmap.getWidth();  int height = oldBitmap.getHeight();  float scaleWidth = ((float) newWidth) / width;  float scaleHeight = ((float) newHeight) / height;  Matrix matrix = new Matrix();  matrix.postScale(scaleWidth, scaleHeight);  Bitmap newBitmap = Bitmap.createBitmap(width, height, Config.RGB_565);  Canvas canvas = new Canvas(newBitmap);  canvas.drawBitmap(newBitmap, matrix, null);  return newBitmap;  
}  

------------------SelectPhotoActivity------------------

//图片选择

import android.app.Activity;  
import android.content.ContentValues;  
import android.content.Intent;  
import android.database.Cursor;  
import android.net.Uri;  
import android.os.Bundle;  
import android.os.Environment;  
import android.provider.MediaStore;  
import android.view.MotionEvent;  
import android.view.View;  
import android.view.View.OnClickListener;  
import android.widget.Button;  
import android.widget.Toast;  public class SelectPhotoActivity extends Activity implements OnClickListener {  /** 使用照相机拍照获取图片 */  public static final int SELECT_PIC_BY_TACK_PHOTO = 1;  /** 使用相册中的图片 */  public static final int SELECT_PIC_BY_PICK_PHOTO = 2;  /** 开启相机 */  private Button btn_take_photo;  /** 开启图册 */  private Button btn_pick_photo;  /** 取消 */  private Button btn_cancel;  /** 获取到的图片路径 */  private String picPath;  private Intent lastIntent;  private Uri photoUri;  /** 从Intent获取图片路径的KEY */  public static final String KEY_PHOTO_PATH = "photo_path";  @Override  protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.activity_select_photo);  btn_take_photo = (Button) findViewById(R.id.btn_take_photo);  btn_pick_photo = (Button) findViewById(R.id.btn_pick_photo);  btn_cancel = (Button) findViewById(R.id.btn_cancel);  lastIntent = getIntent();  btn_take_photo.setOnClickListener(this);  btn_pick_photo.setOnClickListener(this);  btn_cancel.setOnClickListener(this);  }  @Override  public void onClick(View v) {  switch (v.getId()) {  case R.id.btn_take_photo : // 开启相机  takePhoto();  break;  case R.id.btn_pick_photo : // 开启图册  pickPhoto();  break;  case R.id.btn_cancel : // 取消操作  this.finish();  break;  default :  break;  }  }  private void takePhoto() {  //  执行拍照前,应该先判断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 = this.getContentResolver().insert(  MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values);  intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, photoUri);  startActivityForResult(intent, SELECT_PIC_BY_TACK_PHOTO);  } else {  Toast.makeText(getApplicationContext(), "内存卡不存在",  Toast.LENGTH_SHORT).show();  }  }  /*** *  从相册中取图片 */  private void pickPhoto() {  Intent intent = new Intent();  intent.setType("image/*");  intent.setAction(Intent.ACTION_GET_CONTENT);  startActivityForResult(intent, SELECT_PIC_BY_PICK_PHOTO);  }  @Override  public boolean onTouchEvent(MotionEvent event) {  finish();  return super.onTouchEvent(event);  }  @Override  protected void onActivityResult(int requestCode, int resultCode, Intent data) {  if (resultCode == Activity.RESULT_OK) {  doPhoto(requestCode, data);  }  super.onActivityResult(requestCode, resultCode, data);  }  /**  * 选择图片后,获取图片的路径  */  private void doPhoto(int requestCode, Intent data) {  if (requestCode == SELECT_PIC_BY_PICK_PHOTO) {// 从相册取图片,有些手机有异常情况,请注意  if (data == null) {  Toast.makeText(getApplicationContext(), "选择图片文件出错",  Toast.LENGTH_SHORT).show();  return;  }  photoUri = data.getData();  if (photoUri == null) {  Toast.makeText(getApplicationContext(), "选择图片文件出错",  Toast.LENGTH_SHORT).show();  return;  }  }  String[] pojo = {MediaStore.Images.Media.DATA};  @SuppressWarnings("deprecation")  Cursor cursor = managedQuery(photoUri, pojo, null, null, null);  if (cursor != null) {  int columnIndex = cursor.getColumnIndexOrThrow(pojo[0]);  cursor.moveToFirst();  picPath = cursor.getString(columnIndex);  cursor.close();  }  if (picPath != null  && (picPath.endsWith(".png") || picPath.endsWith(".PNG")  || picPath.endsWith(".jpg") || picPath.endsWith(".JPG"))) {  lastIntent.putExtra(KEY_PHOTO_PATH, picPath);  setResult(Activity.RESULT_OK, lastIntent);  finish();  } else {  Toast.makeText(getApplicationContext(), "选择图片文件不正确",  Toast.LENGTH_SHORT).show();  }  }  }  

资源分享:

动画anim
push_bottom_in.xml
<?xml version="1.0" encoding="utf-8"?>  
<!-- 上下滑入式 -->  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  <translate  android:duration="200"  android:fromYDelta="100%p"  android:toYDelta="0" />  </set>  


push_bottom_out.xml:
<?xml version="1.0" encoding="utf-8"?>  
<!-- 上下滑出式 -->  
<set xmlns:android="http://schemas.android.com/apk/res/android" >  <translate  android:duration="200"  android:fromYDelta="0"  android:toYDelta="50%p" />  
</set>  

图片资源:







这篇关于调取系统相册和照相机选取图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/432386

相关文章

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

使用Python将长图片分割为若干张小图片

《使用Python将长图片分割为若干张小图片》这篇文章主要为大家详细介绍了如何使用Python将长图片分割为若干张小图片,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果1. Python需求

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用

Debian如何查看系统版本? 7种轻松查看Debian版本信息的实用方法

《Debian如何查看系统版本?7种轻松查看Debian版本信息的实用方法》Debian是一个广泛使用的Linux发行版,用户有时需要查看其版本信息以进行系统管理、故障排除或兼容性检查,在Debia... 作为最受欢迎的 linux 发行版之一,Debian 的版本信息在日常使用和系统维护中起着至关重要的作

什么是cron? Linux系统下Cron定时任务使用指南

《什么是cron?Linux系统下Cron定时任务使用指南》在日常的Linux系统管理和维护中,定时执行任务是非常常见的需求,你可能需要每天执行备份任务、清理系统日志或运行特定的脚本,而不想每天... 在管理 linux 服务器的过程中,总有一些任务需要我们定期或重复执行。就比如备份任务,通常会选在服务器资

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has