Android实现点击图片上传SQLite数据库
作者:Awesome_lay 时间:2021-06-23 04:35:50
在使用各类App的时候,尤其是在发布朋友圈、微博的时候,都会选择配图,进入手机相册,选择自己想要的照片,作为发布内容的一部分,这里就简单介绍一下点击图片上传的方法。
1、动态获取权限
在Android 6.0之后,除了在清单文件中声明权限之外,通常做的还有就是动态申请权限。
//从手机相册中获取图片需要动态申请权限
if(ContextCompat.checkSelfPermission(this,
Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED){
ActivityCompat.requestPermissions(this,
new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},ALBUM_CODE);
}else{
//如果已经获取权限,那么就直接拿
takePhoto();
}
//权限申请回调
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
switch (requestCode){
case ALBUM_CODE:
//获取照片
takePhoto();
break;
}
}
2、跳转到相册,选择照片
private void takePhoto() {
Intent intent = new Intent(Intent.ACTION_PICK,null);
intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI,
"image/*");
startActivityForResult(intent,ALBUM_CODE);
}
涉及到的隐式跳转的Action是ACTION_PICK,通过带结果的回调startActivityForResult,将图片信息带回。
3、处理图片数据,显示在ImageView。
//从相册返回的回调
@Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch (requestCode) {
case ALBUM_CODE:
Uri uri = data.getData();
if(uri != null){
// 将图片显示在ImageView
iv_goods.setVisibility(View.VISIBLE);
//
Glide.with(this).load(uri).into(iv_goods);
}
break;
}
将图片显示在ImagView中后,如果想要将图片保存在数据库,需要做一系列的转换。
首先,SQLite数据库支持的数据类型包括:int、String、text、Blob,其中Blob就是在存储图片等多媒体的时候,使用的类型。
其实Blob可以支持多种输入类型,像图片这类的资源,通常需要转换为字节流,采用byte数组来存储,因此在SQLite中,也可以使用byte数组来存储图片,因此需要将Drawable类型的图片转换为byte数组。
//Drawable对象转换为byte数组
public static byte[] getBytes(Drawable drawable){
//将Drawable对象转换为bitmap对象
Bitmap bitmap = ((BitmapDrawable) drawable).getBitmap();
//创建输出字节流
ByteArrayOutputStream bos = new ByteArrayOutputStream();
//压缩
bitmap.compress(Bitmap.CompressFormat.PNG, 1, bos);
return bos.toByteArray();
}
我这边用的是Room组件
@ColumnInfo(name = "drawable")
private byte[] drawable;
在获取图片资源的时候,获取byte数组,将其转换为Bitmap或者Drawable,就可以取出照片显示。
//byte数组转换为Bitmap
public static Bitmap getBitmap(byte[] bytes){
//BitmapFactory
Bitmap bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
return bitmap;
}
来源:https://blog.csdn.net/qq_33235287/article/details/106128229
标签:Android,上传,SQLite
0
投稿
猜你喜欢
SpringMVC @RequestBody出现400 Bad Request的解决
2021-10-18 11:50:50
android绘制曲线和折线图的方法
2021-11-19 02:26:02
Springcloud Config配置中心使用与相关介绍
2021-07-13 05:15:17
如何通过XML方式配置并实现Mybatis
2021-12-21 02:49:04
java 避免出现NullPointerException(空指针)的方法总结
2022-08-31 04:15:51
springboot结合websocket聊天室实现私聊+群聊
2022-09-25 03:22:23
C#网络爬虫代码分享 C#简单的爬取工具
2023-10-12 15:03:41
详解Kotlin的空指针处理
2022-06-03 06:57:58
Mybatis的详细使用教程
2022-02-15 21:08:20
C#简单的加密类实例
2022-12-15 11:31:18
Java异常ClassCastException的解决
2022-10-21 02:37:13
DevExpress TreeList 常见问题解决方法
2022-07-15 18:16:54
Java根据模板导出Excel报表并复制模板生成多个Sheet页
2022-09-09 01:16:01
WinForm调用jar包的方法分析
2023-11-17 04:09:46
C++实现扫雷游戏示例讲解
2022-05-03 18:49:05
Mybatis-Plus之ID自动增长的设置实现
2022-10-27 00:09:47
java如何获取map中value的最大值
2023-04-11 05:12:04
Java中HashMap里面key为null存放到哪
2023-11-10 02:46:47
Android应用开发之将SQLite和APK一起打包的方法
2023-07-03 04:16:07
Java Socket编程(四) 重复和并发服务器
2022-06-29 07:07:06