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
投稿

猜你喜欢

  • java Disruptor构建高性能内存队列使用详解

    2022-02-03 00:41:14
  • Java CompletableFuture实现多线程异步编排

    2023-07-22 22:57:02
  • Android对sdcard扩展卡文件操作实例详解

    2023-12-20 11:34:55
  • Android连接MySQL数据库并进行增删改查操作示例讲解

    2023-07-03 13:20:15
  • 基于android中权限的集合汇总

    2023-04-06 09:32:35
  • Android ActionBar使用教程

    2023-10-24 19:09:08
  • 深入浅析JDK8新特性之Lambda表达式

    2023-06-22 08:38:58
  • Java 重写时应当遵守的 11 条规则

    2023-02-10 18:58:06
  • Android RxJava与Retrofit结合使用详解

    2021-10-19 20:10:53
  • C#实现截图工具小项目

    2023-10-02 08:20:03
  • SpringBoot 在项目启动之后执行自定义方法的两种方式小结

    2021-05-25 15:46:36
  • 一次Jvm old过高的排查过程实战记录

    2023-05-07 23:33:49
  • Android实现SQLite添加、更新及删除行的方法

    2022-03-29 05:23:45
  • C#图表算法之有向图

    2021-11-25 14:50:57
  • SpringBoot响应处理之以Json数据返回的实现方法

    2023-12-21 12:21:47
  • 深入c# Func委托的详解

    2022-02-15 05:44:51
  • Java数据结构之数组(动力节点之Java学院整理)

    2023-09-23 21:20:12
  • idea手动刷新git分支的详细教程

    2022-04-05 11:53:43
  • Java 8 中 Map 骚操作之 merge() 的使用方法

    2022-03-31 01:19:27
  • WPF使用DrawingContext实现绘制刻度条

    2023-06-19 08:35:17
  • asp之家 软件编程 m.aspxhome.com