【android开发-21】android中调用系统摄像头camera拍照和相册的用法详解

news2024/11/18 5:56:57

1,调用摄像头

在Android中,调用系统摄像头拍照需要使用Intent来启动Camera应用,并在应用中设置相应的权限。下面是一个简单的例子:

// 创建一个Intent对象,指定要执行的动作是拍照  
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);  
  
// 确保应用程序有权限访问相机  
if (intent.resolveActivity(getPackageManager()) != null) {  
    // 创建一个临时的文件来保存拍摄的照片  
    File photoFile = null;  
    try {  
        photoFile = createImageFile();  
    } catch (IOException ex) {  
        // 处理文件创建失败的情况  
    }  
    // 如果文件已成功创建,则继续执行下面的代码  
    if (photoFile != null) {  
        // 将文件URI传递给Intent对象  
        Uri photoURI = FileProvider.getUriForFile(this, "com.example.android.fileprovider", photoFile);  
        intent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI);  
        // 启动相机应用,拍摄照片并保存到指定的文件中  
        startActivityForResult(intent, REQUEST_IMAGE_CAPTURE);  
    }  
}

其中,createImageFile()方法用于创建一个临时文件来保存拍摄的照片。你需要实现该方法并在其中指定文件的名称和保存位置。例如:

private File createImageFile() throws IOException {  
    // 创建一个保存照片的目录  
    String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());  
    String imageFileName = "JPEG_" + timeStamp + "_";  
    File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);  
    File image = File.createTempFile(imageFileName, ".jpg", storageDir);  
    // 保存文件的路径,用于共享文件  
    mCurrentPhotoPath = image.getAbsolutePath();  
    return image;  
}

在上面的代码中,REQUEST_IMAGE_CAPTURE是一个整数常量,用于标识启动相机的请求。你需要在Activity类中定义一个成员变量来保存该常量,并在onActivityResult()方法中处理拍照结果。例如:

private static final int REQUEST_IMAGE_CAPTURE = 1;  
  
@Override  
protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
    if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK) {  
        // 处理拍摄的照片,例如显示在ImageView中或保存到数据库中  
        Bundle extras = data.getExtras();  
        Bitmap imageBitmap = (Bitmap) extras.get("data");  
        mImageView.setImageBitmap(imageBitmap);  
    }  
}

在Android中,要调用系统摄像头拍照,需要在AndroidManifest.xml文件中声明必要的权限,并在需要使用摄像头拍照的地方请求这些权限。此外,还需要使用Content Provider来注册摄像头提供者。以下是一个简单的例子:

首先,在AndroidManifest.xml文件中声明权限:

<uses-permission android:name="android.permission.CAMERA" />  
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

然后,在需要使用摄像头拍照的地方请求这些权限。例如,在一个Activity中,可以使用以下代码:

if (ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA) != PackageManager.PERMISSION_GRANTED) {  
    ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CAMERA}, REQUEST_CAMERA_PERMISSION);  
}

请注意,你需要在你的应用的Manifest文件中注册你的Provider,例如:

<provider android:name=".MyProvider" android:authorities="com.example.android.fileprovider" />

其中,“com.example.android.fileprovider”是你自己定义的authority名称,需要与你在createImageFile()方法中的“com.example.android.fileprovider”相匹配。

FileProvider是Android中用于实现不同应用间文件共享的工具。它继承自ContentProvider,主要用于在应用间共享文件时提供文件访问的接口。

要使用FileProvider,首先需要在AndroidManifest.xml文件中注册该Provider,并声明其权限。例如:

<provider android:name="androidx.core.content.FileProvider"   
          android:authorities="com.example.app.fileprovider"  
          android:exported="false"  
          android:grantUriPermissions="true">  
    <meta-data android:name="android.support.FILE_PROVIDER_PATHS"   
              android:resource="@xml/file_paths"></meta-data>  
</provider>

其中,android:authorities属性指定了该Provider的权限,android:grantUriPermissions属性允许其他应用通过URI访问该Provider所共享的文件,android:exported属性表示该Provider是否允许其他应用访问。

在上述代码中,我们使用标签来指定共享文件的路径。这些路径需要在res/xml/file_paths.xml文件中定义。例如:

<paths>  
    <files-path name="shared_images" path="shared_images/"/>  
</paths>

在应用中,我们可以使用FileProvider来获取共享文件的URI,并通过该URI来访问共享文件。例如:

File file = new File(context.getExternalFilesDir(null), "shared_images/test.jpg");  
Uri fileUri = FileProvider.getUriForFile(context, "com.example.app.fileprovider", file);

上述代码中,我们首先创建一个File对象,表示共享文件的路径。然后,我们使用FileProvider的静态方法getUriForFile()来获取该文件的URI。该URI可以用于在应用中访问该文件,例如将其显示在ImageView中或将文件保存到另一个应用中。

2,从相册中选择照片
在Android中,从相册选择照片需要申请读取外部存储的权限。以下是一个示例代码,展示如何在Android中申请读取外部存储的权限:

首先,在AndroidManifest.xml文件中添加以下权限声明:

<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

然后,在Activity中,你可以使用以下代码来请求读取外部存储的权限:

// 检查是否已经拥有读取外部存储的权限  
if (ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE)  
        != PackageManager.PERMISSION_GRANTED) {  
    // 如果没有权限,则请求权限  
    ActivityCompat.requestPermissions(this,  
            new String[]{Manifest.permission.READ_EXTERNAL_STORAGE},  
            REQUEST_CODE_PERMISSIONS);  
} else {  
    // 已经拥有权限,可以从相册选择照片了  
    selectPhotoFromGallery();  
}

在上面的代码中,我们首先使用ContextCompat.checkSelfPermission()方法来检查是否已经拥有读取外部存储的权限。如果没有权限,则使用ActivityCompat.requestPermissions()方法来请求权限。在这个示例中,我们将请求码设置为REQUEST_CODE_PERMISSIONS,你可以根据需要进行修改。当用户授予或拒绝权限时,系统会回调onRequestPermissionsResult()方法。因此,你需要在Activity中重写该方法来处理权限请求的结果:

@Override  
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {  
    super.onRequestPermissionsResult(requestCode, permissions, grantResults);  
    if (requestCode == REQUEST_CODE_PERMISSIONS) {  
        if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {  
            // 权限已授予,可以从相册选择照片了  
            selectPhotoFromGallery();  
        } else {  
            // 权限被拒绝,无法从相册选择照片  
            Toast.makeText(this, "Permission denied", Toast.LENGTH_SHORT).show();  
        }  
    }  
}

最后,您需要实现selectPhotoFromGallery()方法来启动选择照片的Intent。以下是一个示例实现:

// 请求码,用于在AndroidManifest.xml中声明权限  
private static final int REQUEST_SELECT_PHOTO = 1;  
  
// 创建一个选择照片的Intent  
private void selectPhotoFromGallery() {  
    Intent intent = new Intent();  
    // 设置Intent类型和操作,为了从相册中选择照片  
    intent.setType("image/*");  
    intent.setAction(Intent.ACTION_GET_CONTENT);  
    // 启动Intent,并在选择照片后返回到当前Activity  
    startActivityForResult(Intent.createChooser(intent, "Select Picture"), REQUEST_SELECT_PHOTO);  
}  
  
// 重写onActivityResult方法,处理从相册返回的照片  
@Override  
protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
    super.onActivityResult(requestCode, resultCode, data);  
    if (requestCode == REQUEST_SELECT_PHOTO && resultCode == RESULT_OK && data != null && data.getData() != null) {  
        Uri selectedImageUri = data.getData();  
        try {  
            // 使用BitmapFactory从Uri获取Bitmap对象  
            Bitmap bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(selectedImageUri));  
            // 在这里处理选定的图片,例如显示在ImageView中或保存到文件中。  
        } catch (FileNotFoundException e) {  
            e.printStackTrace();  
        }  
    }  
}

这段代码首先创建一个类型为"image/*“、操作为"GET_CONTENT"的Intent,然后使用Intent.createChooser()创建一个选择器,标题为"Select Picture”。然后,调用startActivityForResult()启动这个Intent,在用户选择照片后返回到当前Activity。在onActivityResult()方法中,我们检查请求码和结果码是否匹配,然后从返回的Intent中获取照片的URI,并使用BitmapFactory.decodeStream()从该URI获取Bitmap对象。最后,你可以在此处处理选定的图片,例如将其显示在ImageView中或保存到文件中。

3,完整项目代码
该项目app可以直接实现从相册中适配不同分辨率的照片或者打开摄像头直接拍照,然后把照片直接显示到ImageView中。如下效果:
在这里插入图片描述
完整项目app的实现代码下载路径:https://download.csdn.net/download/jiangchaobing_2017/88609936

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1295021.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

循环结构中 break、continue、return 和exit() 的区别

循环结构中 break、continue、return 和exit() 的区别 文章目录 循环结构中 break、continue、return 和exit() 的区别一、break语句二、continue语句三、return 语句四、exit() 函数 说明&#xff1a;本文内容参考牟海军 著《C语言进阶&#xff1a; 重点、难点与疑点解析》&a…

MyBatis中的N+1问题,使用ResultSet来解决,需要存储过程【非常详细】

基础表sql 订单表 CREATE TABLE test_order (order_id bigint(20) NOT NULL AUTO_INCREMENT COMMENT 订单id,order_name varchar(255) NOT NULL DEFAULT COMMENT 订单名字,PRIMARY KEY (order_id) ) ENGINEInnoDB AUTO_INCREMENT3 DEFAULT CHARSETutf8mb4 COMMENT订单表;INS…

八个适合女大学生做的赚钱小副业

大学的生活可以说是多姿多彩&#xff0c;既有沉浸在课堂知识中的学习&#xff0c;也有课余时间可以自由支配的自我发展。然而&#xff0c;作为一名女大学生&#xff0c;除了追求优异的学业表现&#xff0c;是否还有其他更加多元化且有意义的方式来充实自己呢&#xff1f; 当然&…

Kubernetes集群安装高可用postgresql

Kubernetes集群安装高可用postgresql Bitnami 提供的 postgresql-ha 解决方案是一个预配置的、高可用的 PostgreSQL 集群配置&#xff0c;通常部署在 Kubernetes 环境中。它使用了一些关键技术和组件来实现数据库的高可用性。&#xff0c;Bitnami postgresql-ha 主要采用以下构…

问题:batchnormal训练单个batch_size就会报错吗

Batch Normalization&#xff08;批标准化&#xff09;是一种深度学习中的正则化技巧&#xff0c;它可以改进网络的训练过程。在训练神经网络时&#xff0c;Batch Normalization可以帮助解决内部协变量偏移&#xff08;Internal Covariate Shift&#xff09;的问题。 在标准的…

库卡LBR_iisy_3_R760协作机器人导入到coppeliasim

1.从库卡官网xpert下载模型 一般载都是这个step文件格式&#xff0c;其他的好像不太好用。coppeliasim导入格式用的是stl,需要用freeCAD打开重新转换一下。下载下来后&#xff0c;很多都是一个整体&#xff0c;在freeCAD导入中&#xff0c;导入选择要不勾选合并。 下载完用CAD …

DHTMLX Scheduler PRO 6.0.5 Crack

功能丰富的 JavaScript调度程序 DHTMLX Scheduler 是一个 JavaScript 日程安排日历&#xff0c;具有 10 个视图和可定制的界面&#xff0c;用于开发任何类型的日程安排应用程序。 DHTMLX JS 调度程序库的主要特性 我们的 JS 调度程序最需要的功能之一是时间轴视图。借助时间轴…

USB Type-C一拖二线缆制作方法

1 实现方法 Figure 1-1 Type-C Socket(母口) Figure 1-2 Type-C Plug(公头) Table 1-1 Type-C Socket Pin连接描述 Type-C Plug连接&#xff0c; 需要做一个一拖二的线&#xff0c;一根的一端是USB&#xff0c; 另外一根的一端是USB转UART&#xff0c; 参考Table 1-2。 Table 1…

c++详解栈

一.什么是栈 堆栈又名栈&#xff08;stack&#xff09;&#xff0c;它是一种运算受限的数据结构&#xff08;线性表&#xff09;&#xff0c;只不过他和数组不同&#xff0c;数组我们可以想象成一个装巧克力的盒子&#xff0c;你想拿一块巧克力&#xff0c;不需要改变其他巧克…

私域运营:12个朋友圈经营模板

做私域运营的各位&#xff0c;想必大家都会烦恼朋友圈要发什么才能保证最高效吧&#xff01; 首先&#xff0c;我们需要明确&#xff0c;朋友圈是什么&#xff1f; 朋友圈是我们打造信任感的地方&#xff0c;也是我们的信息能够及时触达用户的重要渠道。很多人都有一个习惯&a…

java每日一记 —— mybatis的动态数据源切换

动态数据源切换 1.环境初始化2.切换数据源代码3.第二节代码的测试4.用注解的方式进行优化 此代码在jdk11上测试通过&#xff0c;SpringBoot版本为2.7.14 1.环境初始化 1.创建两个库 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS 0;-- 表结构 DROP TABLE IF EXISTS t_stu; CRE…

电脑录屏软件哪个好?全面对比,为您揭秘

电脑录屏软件成为创作者、教育者以及普通用户的得力工具&#xff0c;用于捕捉屏幕上的精彩瞬间或创作教学内容&#xff0c;可是电脑录屏软件哪个好呢&#xff1f;本文将深入比较三款备受瞩目的电脑录屏软件&#xff0c;通过详细的分步骤介绍&#xff0c;帮助用户了解它们的使用…

【Element-ui】Icon 图标与Button 按钮

文章目录 前言一、Icon 图标1.1 作用1.2 使用方法1.3 图标集合 二、Button 按钮2.1 基础用法2.2 禁用状态2.3 文字按钮2.4 图标按钮2.5 按钮组2.6 加载中2.7 不同尺寸 总结 前言 在前端开发中&#xff0c;界面的设计和交互是至关重要的一部分。一个直观、易用的界面往往离不开…

在winform中使用blazor hybrid构建页面

1、Blazor Hybrid简介 Blazor Hybrid 使开发人员能够将桌面和移动本机客户端框架与 .NET 和 Blazor 结合使用。在 Blazor Hybrid 应用中&#xff0c;Razor 组件在设备上是本机运行的。 这些组件通过本地互操作通道呈现到嵌入式 Web 视图控件。 组件不在浏览器中运行&#xff0…

怎么将用户引流到你的私域中?

微信私域运营是一种利用微信平台建立与用户深度联系的营销方式&#xff0c;可在私域中触达并服务用户。 那么如何将在将用户引流至你的私域中呢&#xff1f; 可以从以下几个小方法入手。 ①打造一个吸引人的个人品牌形象非常重要。在社交媒体上展示真实、独特、专业的一面&a…

oracle实验2023-12-8--触发器

第十四周实验 【例】功能要求&#xff1a;增加一新表XS_1&#xff0c;表结构和表XS相同&#xff0c;用来存放从XS表中删除的记录。 分析: 1、创建表 xs_1 SQL> create table xs_1 as select * from xs; Table created SQL> truncate table xs_1; Table truncated题目&a…

详解数据入表准备工作:如何判定数据资源?

务部发布的《企业数据资源相关会计处理暂行规定》即将于明年1月生效&#xff0c;但《暂行规定》并未详细解释数据资源这一概念。到底什么是数据资源&#xff0c;怎样将数据资源入表&#xff0c;成为众多国有企业与上市公司关心的问题。 — 01 — 什么是数据资源&#xff1f;…

【Linux系统化学习】命令行参数 | 环境变量的再次理解

个人主页点击直达&#xff1a;小白不是程序媛 Linux专栏&#xff1a;Linux系统化学习 代码仓库&#xff1a;Gitee 目录 mian函数传参获取环境变量 手动添加环境变量 导出环境变量 environ获取环境变量 本地变量和环境变量的区别 Linux的命令分类 常规命令 内建命令 …

PostgreSQL 技术内幕(十二) CloudberryDB 并行化查询之路

随着数据驱动的应用日益增多&#xff0c;数据查询和分析的量级和时效性要求也在不断提升&#xff0c;对数据库的查询性能提出了更高的要求。为了满足这一需求&#xff0c;数据库引擎不断经历创新&#xff0c;其中并行执行引擎是性能提升的重要手段之一&#xff0c;逐渐成为数据…

最新版IDEA专业版大学生申请免费许可证教学(无需学校教育邮箱+官方途径+非破解手段)

文章目录 前言1. 申请学籍在线验证报告2. 进入IDEA官网进行认证3. 申请 JB (IDEA) 账号4. 打开 IDEA 专业版总结 前言 当你进入本篇文章时, 你应该是已经遇到了 IDEA 社区版无法解决的问题, 或是想进一步体验 IDEA 专业版的强大. 本文是一篇学生申请IDEA免费许可证的教学, 在学…