效果图:


MainActivity.java:

public class MainActivity extends AppCompatActivity {public static final int TAKE_PHOTO =1;public static final int CHOOSE_PHOTO=2;private ImageView picture;private Button tiao;private Uri imageUri;String index = "";     //  作为拍照还是相册的标识String info = "";     //  uri变成字符串@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);Button takePhoto = findViewById(R.id.take_photo);Button chooseFromAlbum = findViewById(R.id.choose_from_album);tiao = findViewById(R.id.btn_tiao);tiao.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {Intent intent = new Intent(MainActivity.this,Xian_Activity.class);initData();startActivity(intent);}});picture = findViewById(R.id.picture);//  拍照takePhoto.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//          获取本地时间,作为图片的名字,防止拍了多张照片时,出现图片覆盖导致之前图片消失的问题SimpleDateFormat format = new SimpleDateFormat("yyyy年MM月dd日HH:mm:ss");Date curDate = new Date(System.currentTimeMillis());String str = format.format(curDate);/***          创建File对象,用于存储拍照后的照片*          第一个参数:  是这张照片存放在手机SD卡的对应关联缓存应用*          第二个参数:  这张图片的命名*/File outputImage = new File(getExternalCacheDir(),str+".jpg");try {if (outputImage.exists()){          //  检查与File对象相连接的文件和目录是否存在于磁盘中outputImage.delete();           //  删除与File对象相连接的文件和目录}outputImage.createNewFile();        //  如果与File对象相连接的文件不存在,则创建一个空文件} catch (IOException e) {e.printStackTrace();}if (Build.VERSION.SDK_INT >= 24){       //  如果运行设备的系统版本高于 Android7.0/***          将File对象转换成一个封装过的Uri对象*          第一个参数:  要求传入Context参数*          第二个参数:  可以是任意唯一的字符串*          第三个参数:  我们刚刚创建的File对象*/imageUri = FileProvider.getUriForFile(MainActivity.this,"ccv.turbosnail.cameraalbumtest.fileprovider",outputImage);}else{                  //  如果运行设备的系统版本低于 Android7.0//  将File对象转换成Uri对象,这个Uri对象表示着output_image.jpg 这张图片的本地真实路径imageUri = Uri.fromFile(outputImage);}/***      启动相机程序*///  将Intent的action指定为 拍照到指定目录 —— android.media.action.IMAGE_CAPTUREIntent intent = new Intent("android.media.action.IMAGE_CAPTURE");//  指定图片的输出地址intent.putExtra(MediaStore.EXTRA_OUTPUT,imageUri);//  在通过startActivityForResult(),来启动活动,因此拍完照后会有结果返回到 onActivityResult()方法中startActivityForResult(intent,TAKE_PHOTO);  //  打开相机,用自定义常量 —— TAKE_PHOTO来作为case处理图片的标识}});//  相册chooseFromAlbum.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {//  动态申请WRITE_EXTERNAL_STORAGE 这个危险权限。因为相册中的照片时存储在SD卡上的,我们从SD卡中读取照片就需要申请这个权限//  WRITE_EXTERNAL_STORAGE  ——  同时授权程序对SD卡读和写的能力if (ContextCompat.checkSelfPermission(MainActivity.this,Manifest.permission.WRITE_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED){ActivityCompat.requestPermissions(MainActivity.this,new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},1);}else{openAlbum();        //  用户授权了权限申请之后就会调用该方法}}});}private void initData() {MySQLite dbHelper = new MySQLite(MainActivity.this,"user",null,1);SQLiteDatabase db = dbHelper.getReadableDatabase();ContentValues cv = new ContentValues();cv.put("PHOTO",info);cv.put("FLAG",index);db.insert("user",null,cv);db.close();}@Overrideprotected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {switch (requestCode){case TAKE_PHOTO:if (resultCode == RESULT_OK){try{//  根据Uri找到这张照片的位置,将它解析成Bitmap对象,然后将把它设置到imageView中显示出来Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(imageUri));info = ""+imageUri;index = "2";picture.setImageBitmap(bitmap);} catch (FileNotFoundException e) {e.printStackTrace();}}break;case CHOOSE_PHOTO:/***          之所以这样做是是因为,Android 系统从4.4版本开始,选取相册图片不再返回图片真实的Uri了,而是一个封装过的Uri,因此*          如果是4.4版本以上的手机就需要对这个Uri进行解析才行*/if (resultCode == RESULT_OK){if (Build.VERSION.SDK_INT  >= 19){      //  如果是在4.4及以 上 系统的手机就调用该方法来处理图片handleImageOnKitKat(data);}else{handleImageBeforeKitKat(data);      //  如果是在4.4以 下 系统的手机就调用该方法来处理图片}}break;default:break;}}/***          如何解析这个封装过的Uri*/@RequiresApi(api = Build.VERSION_CODES.KITKAT)private void handleImageOnKitKat(Intent data) {String imagePath = null;Uri uri = data.getData();if (DocumentsContract.isDocumentUri(this,uri)){//  如果返回的Uri是 document 类型的话,那就取出 document id 进行处理String docId = DocumentsContract.getDocumentId(uri);if ("com.android.providers.media.documents".equals(uri.getAuthority())){String id = docId.split(":")[1];        //  解析出数字格式idString selection = MediaStore.Images.Media._ID + "=" + id;imagePath = getImagePath(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,selection);}else if ("com.android.providers.downloads.documents".equals(uri.getAuthority())){Uri contentUri = ContentUris.withAppendedId(Uri.parse("content://downloads/public_downloads"),Long.valueOf(docId));imagePath = getImagePath(contentUri,null);}}else if ("content".equalsIgnoreCase(uri.getScheme())){//  如果是 content 类型的Uri,则使用普通方式处理imagePath = getImagePath(uri,null);}else if ("file".equalsIgnoreCase(uri.getScheme())){//  如果是 file 类型的 Uri ,直接获取图片路径即可imagePath = uri.getPath();}displayImage(imagePath);        //  拿到图片路径后,在调用 displayImage() 方法将图片显示到界面上}private void handleImageBeforeKitKat(Intent data) {Uri uri = data.getData();String imagePath = getImagePath(uri,null);displayImage(imagePath);}private void displayImage(String imagePath) {if (imagePath != null){Bitmap bitmap = BitmapFactory.decodeFile(imagePath);index = "1";info = imagePath;picture.setImageBitmap(bitmap);}else{Toast.makeText(this,"failed to gei image",Toast.LENGTH_SHORT).show();}}private String getImagePath(Uri uri, String selection) {String path = null;//  通过 Uri 和 selection 来获取真实图片的路径Cursor cursor = getContentResolver().query(uri,null,selection,null,null);if (cursor != null){if (cursor.moveToNext()){//  MediaStore.Images.Media.insertImage —— 得到保存图片的原始路径path = cursor.getString(cursor.getColumnIndex(MediaStore.Images.Media.DATA));}cursor.close();}return path;}private void openAlbum() {/***      启动相册程序*///  action —— android.intent.action.GET_CONTENTIntent intent = new Intent("android.intent.action.GET_CONTENT");//  该函数表示要查找文件的mime类型(如*/*),这个和组件在manifest里定义的相对应,但在源代码里intent.setType("image/*");startActivityForResult(intent,CHOOSE_PHOTO);    //打开相册,用自定义常量 —— CHOOSE_PHOTO来作为case处理图片的标识}@Overridepublic void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {switch (requestCode){case 1:if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED){openAlbum();}else {Toast.makeText(this,"You denied the permission",Toast.LENGTH_SHORT).show();}break;default:}}
}

MySQLite.java

public class MySQLite extends SQLiteOpenHelper {public MySQLite(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {super(context, name, factory, version);}@Overridepublic void onCreate(SQLiteDatabase db) {db.execSQL("CREATE TABLE user(_id INTEGER PRIMARY KEY AUTOINCREMENT," +"PHOTO TEXT," +"FLAG TEXT)");}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}

Xian_Activity.java

public class Xian_Activity extends AppCompatActivity {private Button btnText;private ImageView picture;String info = "",index = "";@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_xian_);picture = findViewById(R.id.img_picture);btnText = findViewById(R.id.btn_text);btnText.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {initData();}});}private void initData() {MySQLite dbHelper = new MySQLite(Xian_Activity.this,"user",null,1);SQLiteDatabase db = dbHelper.getReadableDatabase();Cursor cursor = db.query("user",null,null,null,null,null,null);while (cursor.moveToNext()){index = cursor.getString(cursor.getColumnIndex("FLAG"));info = cursor.getString(cursor.getColumnIndex("PHOTO"));if (index.equals("1")){        //  相册Bitmap bitmap = BitmapFactory.decodeFile(info);picture.setImageBitmap(bitmap);}else if (index.equals("2")){    //  拍照Uri imgUri = Uri.parse(info);try {Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(imgUri));picture.setImageBitmap(bitmap);} catch (FileNotFoundException e) {e.printStackTrace();}}}}
}

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout  xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".MainActivity"><Buttonandroid:id="@+id/btn_tiao"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginTop="10dp"android:text="跳转"/><Buttonandroid:id="@+id/take_photo"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginTop="10dp"android:text="拍照"/><Buttonandroid:id="@+id/choose_from_album"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="相册"/><ImageViewandroid:id="@+id/picture"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_horizontal"/></LinearLayout>

activity_xian.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"tools:context=".Xian_Activity"><Buttonandroid:id="@+id/btn_text"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="查看"/><ImageViewandroid:id="@+id/img_picture"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_horizontal"/></LinearLayout>

点击运行即可!
最后,我真诚的希望能评论一句嘛,让我知道你来过,我会很开心的

Android 实现 相机、相册功能 + 图片存取数据库操作相关推荐

  1. Android自定义相机拍照、图片裁剪的实现

    原文:Android自定义相机拍照.图片裁剪的实现 最近项目里面又要加一个拍照搜题的功能,也就是用户对着不会做的题目拍一张照片,将照片的文字使用ocr识别出来,再调用题库搜索接口搜索出来展示给用户,类 ...

  2. uni-app 相机相册选择图片转base64

    uni-app 相机相册选择图片转base64 一.base64 需求说明: 后端上传图片接口,是post请求.接口如下: 二.接口规则 请求方法:POST 请求数据类型:JSON 请求头(HEADE ...

  3. android拍照所需的权限,eclipse --- Android拍照,相册选择图片以及Android6.0权限管理...

    [实例简介] eclipse --- Android拍照,相册选择图片以及Android6.0权限管理 [实例截图] [核心代码] camreainandroidm └── camreainandro ...

  4. android 调用相册功能吗,Android调用系统相册选择图片,支持小米4云相册

    用小米4调用系统相册选择照片时,如果云相册功能开启的话.云相册中的图片也会显示在选择列表中.经过测试,选择到云相册中的图片的话,uri的scheme是file,而不再试content.本文支持云相册的 ...

  5. Android调用系统相机,相册裁切图片展示的实现

    效果图: MainActivity package com.example.administrator.rxxjava;import android.content.Intent; import an ...

  6. 从相机相册获取图片裁剪后用于评论晒图或更换背景图

    这是我人生中写的第一篇博客,是否要纪念一下这一刻(2016.09.01 16:52).其实关于写博客,老早就有这种写法,首先觉得他能够帮我总结我学到的和用过的技术,其次还能帮助那些和我有一样需求的人, ...

  7. cocos creator 调用相机相册裁剪图片并上传到服务器

    大致思路就是creator里面js调用Java和object-c代码,调起系统相机相册,选取图库图片/拍照图片进行裁剪,然后转化为base64字符串,最后通过http post请求上传到服务器. Ja ...

  8. android+代码调用+相册+小米,Android调用系统相册选择图片,支持小米4云相册

    用小米4调用系统相册选择照片时,如果云相册功能开启的话.云相册中的图片也会显示在选择列表中.经过测试,选择到云相册中的图片的话,uri的scheme是file,而不再试content.本文支持云相册的 ...

  9. android通过访问相册获取图片并展示在ImageView中

    第一步:添加相应的权限以及属性: ①在manifest中设置权限 <uses-feature android:name="android.hardware.camera" / ...

  10. android 调用相机并获取图片地址,Android 7.0使用FileProvider获取相机拍照的图片路径...

    这里主要是基于Android 7.0,Nougat 实现一个获取相机拍照的图片后,使用FileProvider把图片转换为实际的路径. 首先需要在AndroidManifest.xml声明调用相机的权 ...

最新文章

  1. java查询结果自定义显示_JPA自定义对象接收查询结果集操作
  2. oracle对象权限回收,【Privilege】Oracle对象权限级联收回现象测试
  3. 用友U9 cloud助力临工重机实现定制化生产
  4. C++ Opengl 绘制二次几何体源码
  5. PHPStorm无法保存个人设置 ctrl左键无法找到类
  6. 【小白成长撸】--二分查找
  7. 网络安全应急演练方案内容_筑牢网络安全屏障 盐田区开展网络安全应急演练...
  8. jquery ajax 解决跨域访问问题
  9. ACWING830 单调栈
  10. 批判性思维-真理连贯论
  11. 米家 智能 服务器,为什么一谈到智能家居 都是小米米家?
  12. EXCEL之REPT(),让数据更直观!
  13. 马云常说要把阿里做到102岁,那么中国从古到今有多少家过百年的企业?
  14. MySql的详细安装与配置步骤
  15. 妮妮lisp_140种Python标准库、第三方库和外部工具都有!
  16. 网站如何防御DDOS攻击
  17. 产品分析报告—Soul
  18. 推荐三个 VSCode 摸鱼插件
  19. 2019杭电多校第七场 HDU - 6656 Kejin Player 期望
  20. 关联规则----Apriori算法以及代码实现

热门文章

  1. 架构实战项目心得(一):技术和工具
  2. [SPM_hw1]记一次项目经历
  3. 从最近的AAAI和EMNLP中了解命名实体识别与关系抽取的联合建模
  4. ACL'22 | 一种基于隐变量建模的并行文本生成模型
  5. 【模型压缩系列】一:模型替换
  6. 中文NER的正确打开方式: 词汇增强方法总结 (从Lattice LSTM到FLAT)
  7. 【论文分享】PathQG: 基于事实的神经问题生成
  8. 【ICLR2020】会议的16篇最佳深度学习论文
  9. 【清华ACL2020长文】KdConv:多领域知识驱动的中文多轮对话数据集
  10. 【学术】施一公分享自身经验:如何提高自己的专业英文文献阅读能力