想了解更多内容,请访问:
成都创新互联2013年开创至今,是专业互联网技术服务公司,拥有项目成都网站建设、成都网站设计网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元安达做网站,已为上家服务,为安达各地企业和个人服务,联系电话:18982081108
和华为官方合作共建的鸿蒙技术社区
https://harmonyos./#zz
声明一下哦,这是我看了夏曹俊老师在周六的直播预习材料的加持下所写的一个小demo,大家记得都去看夏老师的直播哦,入口主页就有显示。
不多说,先上demo的跑起来的效果,如下两张图:点击显示图片的按钮之后就会显示出一张图片(图片是个什么玩意,知足吧,我拿远程模拟机拍摄的)
完整demo在附件中进行下载
PS说一下操作步骤吧,把demo烧进手机,记住此时候的手机是没有图片的,先打开照相机拍摄一张图片,然后你就会得到和下面截图一样的什么玩意的图片,然后打开demo,点击显示图片按钮就会显示你拍摄到的图片了)
老规矩还是先说一下大概思路:
1.读取本机的图片,首先你得有权限,所以先想办法获得权限
2.获得权限之后,就可以使用类似数据库的搜索方法来搜索图片的ID了
3.获得ID之后,然后将其转换为uri
4.得到uri之后,然后使用uri生成Pixmap
5.得到Pixmap之后,使用Image来渲染其Pixmap
1.来获得读取照片的权限
在config中添加如下配置文件:
- "reqPermissions": [{
- "name": "ohos.permission.READ_USER_STORAGE"
- }
然后在java代码中获取到这个权限
- String[] permission = {"ohos.permission.READ_USER_STORAGE"};
- requestPermissionsFromUser(permission,0);
2.获得权限之后,就可以使用类似数据库的搜索方法来搜索图片的ID了
首先获得一个DataAbilityHelper
- DataAbilityHelper helper = DataAbilityHelper.creator(getContext());
然后调用query查询方法获得图片ID,这里其实只有一张
- ResultSet result = helper.query(AVStorage.Images.Media.EXTERNAL_DATA_ABILITY_URI, null, null);
- int mediaId = result.getInt(result.getColumnIndexForName(AVStorage.Images.Media.ID));
3.获得ID之后,然后将其转换为uri
- Uri uri = Uri.appendEncodedPathToUri(AVStorage.Images.Media.EXTERNAL_DATA_ABILITY_URI,""+mediaId);
4.得到uri之后,然后使用uri生成Pixmap
4.1 先将得到的uri使用openFile的API得到FileDescriptor对象
4.2 使用上一步的对象作为参数新建一个ImageSource对象和这个对象之下的DecodingOptions对象
4.3 然后调用上一步建好的ImageSource对象的createThumbnailPixelmap方法生成Pixmap
- FileDescriptor filedesc = helper.openFile(uri,"r");
- ImageSource.DecodingOptions decodingOpts = new ImageSource.DecodingOption();
- decodingOpts.desiredSize = new Size(300,300);
- ImageSource imageSource = ImageSource.create(filedesc,null);
- PixelMap pixelMap = imageSource.createThumbnailPixelmap(decodingOpts,true);
5.得到Pixmap之后,使用Image来渲染其Pixmap
无论使用何种手段得到一个Image对象,然后调用它的setPixelMap将上一步得到的Pixmap作为参数传进去就OK了。至于别的都是一些对Image其他属性的设置。
- Image img = (Image)findComponentById(ResourceTable.Id_image1);
- img.setId(mediaId);
- img.setHeight(300);
- img.setWidth(300);
- img.setMarginTop(20);
- img.setMarginLeft(20);
- img.setPixelMap(pixelMap);
- img.setScaleMode(Image.ScaleMode.ZOOM_CENTER);
由于时间比较急,所以这个demo比较简单,只可以显示一张图片,下周我应该会在这个demo的基础上继续完善,有兴趣的朋友可以关注一下。
完整demo的源码见附件
©著作权归作者和HarmonyOS技术社区共同所有,如需转载,请注明出处,否则将追究法律责任
想了解更多内容,请访问:
和华为官方合作共建的鸿蒙技术社区
https://harmonyos./#zz
当前标题:鸿蒙HarmonyOS之获取系统照片并解码渲染显示(附完整Demo)
浏览地址:http://www.36103.cn/qtweb/news49/8999.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联