HarmonyOS Next应用开发——多种方式实现图片解码

news2025/1/11 11:07:53

【高心星出品】

图片解码

图片处理就是将设备中保存的图片进行编辑处理然后再存储下来,整个过程需要先图片解码,图片处理,最后在图片编码保存。

图片解码指将所支持格式的存档图片解码成统一的PixelMap,以便在应用或系统中进行图片显示或图片处理。当前支持的存档图片格式包括JPEG、PNG、GIF、WebP、BMP、SVG、ICO、DNG、HEIF(不同硬件设备支持情况不同)。

网络图片解码

通过网络请求获取网络图片的字节,生成ImageSource然后生成PixelMap。

在这里插入图片描述

获取图片
// 创建请求对象
let req = http.createHttp()
req.request('https://pic.616pic.com/ys_img/01/17/47/eVnQ1JdIY4.jpg').then((res) => {
  // 获取图片字节
  let buffer = res.result as ArrayBuffer
  //   生成ImageSource
  let source = image.createImageSource(buffer)
  // 转化成pixelmap
  this.src = source.createPixelMapSync()
完整代码
import { http } from '@kit.NetworkKit';
import { image } from '@kit.ImageKit';

@Entry
@Component
struct InternetPage {
  @State message: string = 'Hello World';
  @State src: PixelMap | undefined = undefined

  build() {
    Column() {
      Image(this.src)
        .width(150)
        .height(150)
        .objectFit(ImageFit.Fill)
        .margin({ top: 20 })
        .border({ width: 2, color: Color.Black })
      Button('加载图片').margin({ top: 20 }).onClick(() => {
        // 创建请求对象
        let req = http.createHttp()
        req.request('https://pic.616pic.com/ys_img/01/17/47/eVnQ1JdIY4.jpg').then((res) => {
          // 获取图片字节
          let buffer = res.result as ArrayBuffer
          //   生成ImageSource
          let source = image.createImageSource(buffer)
          // 转化成pixelmap
          this.src = source.createPixelMapSync()

        })
      })
    }
    .height('100%')
    .width('100%')
  }
}
应用内图片解码

通过获取应用沙箱中文件的描述信息,生成ImageSource然后生成PixelMap。

效果图同上。

获取图片
//   选择图片
let file = fileIo.openSync(getContext(this).getApplicationContext().cacheDir + '/test.jpg',
  fileIo.OpenMode.READ_ONLY)
// 创建imagesource
let source = image.createImageSource(file.fd)
//  获得pixelmap
this.src = source.createPixelMapSync()
完整代码
import { http } from '@kit.NetworkKit';
import { fileIo } from '@kit.CoreFileKit';
import { image } from '@kit.ImageKit';

@Entry
@Component
struct Index {
  @State message: string = 'Hello World';
  @State src: PixelMap | undefined = undefined

  aboutToAppear(): void {
    // 下载一个文件保存在cache中
    let req = http.createHttp()
    req.request('https://pic.616pic.com/ys_img/01/17/47/eVnQ1JdIY4.jpg').then((res) => {
      let buffer = res.result as ArrayBuffer
      let file = fileIo.openSync(getContext(this).getApplicationContext().cacheDir + '/test.jpg',
        fileIo.OpenMode.CREATE | fileIo.OpenMode.WRITE_ONLY)
      fileIo.writeSync(file.fd, buffer)
      fileIo.close(file)
    })
  }

  build() {
    Column() {
      Image(this.src).width(150).height(150).objectFit(ImageFit.Fill).margin({ top: 20 }).border({width:2,color:Color.Black})
      Button('加载图片').margin({ top: 20 }).onClick(() => {
        //   选择图片
        let file = fileIo.openSync(getContext(this).getApplicationContext().cacheDir + '/test.jpg',
          fileIo.OpenMode.READ_ONLY)
        // 创建imagesource
        let source = image.createImageSource(file.fd)
        //  获得pixelmap
        this.src = source.createPixelMapSync()
      })
    }
    .height('100%')
    .width('100%')
  }
}
应用资源包图片解码

假设在应用的rawfile中存放着一张图片,我们使用方法可以将其转化为PixelMap对象。

运行效果同上。

获取图片
//  获取资源管理器
let resoucemanager = getContext(this).resourceManager
//  获取rawfile中图片的描述符
let fd = resoucemanager.getRawFdSync('head.jpg')
// 根据文件描述符创建imagesource
let source = image.createImageSource(fd)
// 创建pixelmap
this.src = source.createPixelMapSync()
完整代码
import { image } from '@kit.ImageKit';

@Entry
@Component
struct ResourcePage {
  @State message: string = 'Hello World';
  @State src: PixelMap | undefined = undefined

  build() {
    Column() {
      Image(this.src)
        .width(150)
        .height(150)
        .objectFit(ImageFit.Fill)
        .margin({ top: 20 })
        .border({ width: 2, color: Color.Black })
      Button('加载图片').margin({ top: 20 }).onClick(() => {
        //  获取资源管理器
        let resoucemanager = getContext(this).resourceManager
        //  获取rawfile中图片的描述符
        let fd = resoucemanager.getRawFdSync('head.jpg')
        // 根据文件描述符创建imagesource
        let source = image.createImageSource(fd)
        // 创建pixelmap
        this.src = source.createPixelMapSync()

      })
    }
    .height('100%')
    .width('100%')
  }
}
用户图库图片解码

可以从用户相册中选择图片解码,由于鸿蒙做了用户和应用的隔离机制,所以图库选择图片较为复杂。

在这里插入图片描述

获取图片
//   创建图片选择器
let photopicker = new photoAccessHelper.PhotoViewPicker()
// 选择图片的配置  最多选择一张图片,支持编辑
let selectoption: photoAccessHelper.PhotoSelectOptions = {
  maxSelectNumber: 1,
  isEditSupported: true
}
photopicker.select(selectoption).then((value) => {
  // 获取相册图片uri 注意此处uri不能直接使用 它是用户uri
  let uri = value.photoUris[0]
  //   获取该uri对应的文件
  let file = fileIo.openSync(uri, fileIo.OpenMode.READ_ONLY)
  //  生成source
  let source = image.createImageSource(file.fd)
  //   获取pixelmap对象
  this.src = source.createPixelMapSync()
完整代码
import { photoAccessHelper } from '@kit.MediaLibraryKit';
import { fileIo } from '@kit.CoreFileKit';
import { image } from '@kit.ImageKit';

@Entry
@Component
struct UserPage {
  @State message: string = 'Hello World';
  @State src: PixelMap | undefined = undefined

  build() {
    Column() {
      Image(this.src)
        .width(150)
        .height(150)
        .objectFit(ImageFit.Fill)
        .margin({ top: 20 })
        .border({ width: 2, color: Color.Black })
      Button('加载图片').margin({ top: 20 }).onClick(() => {
        //   创建图片选择器
        let photopicker = new photoAccessHelper.PhotoViewPicker()
        // 选择图片的配置  最多选择一张图片,支持编辑
        let selectoption: photoAccessHelper.PhotoSelectOptions = {
          maxSelectNumber: 1,
          isEditSupported: true
        }
        photopicker.select(selectoption).then((value) => {
          // 获取相册图片uri 注意此处uri不能直接使用 它是用户uri
          let uri = value.photoUris[0]
          //   获取该uri对应的文件,这里要只读打开否则无权限在
          let file = fileIo.openSync(uri, fileIo.OpenMode.READ_ONLY)
          //  生成source
          let source = image.createImageSource(file.fd)
          //   获取pixelmap对象
          this.src = source.createPixelMapSync()
        })

      })
    }
    .height('100%')
    .width('100%')
  }
}

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

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

相关文章

【贝加莱PLC基础教学】2.1 搜索并连接到对应的PLC(1)

【贝加莱PLC基础教学】目录大全_贝加莱plc p23 1361-CSDN博客 PLC其实和单片机差别不大,无非就是大一点的单片机。另外多加了一点点计算机网络和通讯知识,然而就是这一点点计算机网络知识让大家望而却步。 0.基础知识 在计算机网络中,我们通…

Notepad++通过自定义语言实现日志按照不同级别高亮

借助Notepad的自定义语言可以实现日志的按照不同级别的高亮&#xff1b; 参考&#xff1a; https://blog.csdn.net/commshare/article/details/131208656 在此基础上做了一点修改效果如下&#xff1a; xml文件&#xff1a; <NotepadPlus><UserLang name"Ansibl…

深度学习--CNN实现猫狗识别二分类(附带下载链接, 长期有效)

1. 代码实现(包含流程解释) 样本量: 8005 # # 1.导入数据集(加载图片)数据预处理# 进行图像增强, 通过对图像的旋转 ,缩放,剪切变换, 翻转, 平移等一系列操作来生成新样本, 进而增加样本容量, # 同时对图片数值进行归一化[0:1] from tensorflow.keras.preprocessing.image …

Altair官方教程——HyperMesh视觉控制

在HyperMesh中&#xff0c;模型视角控制可通过标准视图&#xff08;Standard Views&#xff09;工具栏、三维视图控制&#xff08;3D View Controls&#xff09;工具栏以及鼠标实现。 (1) 标准视图工具栏图标。 (2) 鼠标控制- 显示控制的推荐操作方法是使用鼠标。配合键盘上的 …

Lfsr32

首先分析 Lfsr5 首先要理解什么是抽头点&#xff08;tap&#xff09;&#xff0c;注意到图中有两个触发器的输入为前级输出与q[0]的异或&#xff0c;这些位置被称为 tap position.通过观察上图&#xff0c;所谓抽头点指的就是第5个&#xff0c;第3个寄存器的输入经过了异或逻辑…

nosql课本习题

nosql题目 1. 文档数据库相比其他 NoSQL 的突出优势和特点是什么&#xff1f; 答案&#xff1a; 文档数据库的突出优势在于它的灵活性和可扩展性。不同于传统的关系型数据库&#xff0c;文档数据库允许存储半结构化和非结构化数据&#xff0c;每个文档可以有不同的字段&#x…

Django操作数据库

Django操作数据库 1、ORM框架2、ORM-创建数据库3、ORM-连接数据库4、ORM-操作表4.1、类创建表4.2、修改表结构4.2.1、删除表结构4.2.2、新增表结构 5、ORM-增删改查5.1、新增数据5.2、删除数据5.3、查询数据5.4、更新数据 1、ORM框架 Django开发操作数据库很简单&#xff0c;内…

沈阳乐晟睿浩科技有限公司技术创新,奠定坚实基础

在当今数字经济蓬勃发展的时代&#xff0c;电子商务以其独特的魅力和无限潜力&#xff0c;正深刻改变着人们的消费习惯与商业模式。在这场变革中&#xff0c;沈阳乐晟睿浩科技有限公司凭借其敏锐的市场洞察力、强大的技术实力以及前瞻性的战略眼光&#xff0c;迅速崛起&#xf…

Java爬虫:获取数据的入门详解

在数字化时代&#xff0c;数据已成为最宝贵的资产之一。无论是市场研究、客户洞察还是产品开发&#xff0c;获取大量数据并从中提取有价值的信息变得至关重要。Java&#xff0c;作为一种成熟且功能强大的编程语言&#xff0c;为编写爬虫提供了强大的支持。Java爬虫可以帮助我们…

月入30万!用AI做养生赚麻了,全网最全最详细的变现教程

现在不养生&#xff0c;将来养医生&#xff01; 秋冬将至&#xff0c;又到了宝子们养生意识季节性觉醒的时间了&#xff0c;这时候&#xff0c;网上关于养生的内容搜索量激增&#xff0c;也催生了AI养生自媒体创作的热潮。 比如这位博主采用养生文案搭配AI简笔画的形式&#…

拥抱新质生产力 | 大势智慧亮相第12届中国测绘地理信息技术装备博览会

10月15日—17日&#xff0c;由中国测绘学会主办的2024中国测绘地理信息科学技术年会暨中国测绘地理信息技术装备博览会在河南省郑州市隆重举行。 10月15日&#xff0c;第12届中国测绘地理信息技术装备博览会在郑州国际会展中心盛大开幕。 大势智慧CTO张帆受邀出席博览会开幕式…

pdman在关系图中展示表的后排字段

1.当想在关系图中通过箭头指向来表明表与表之间的关系时&#xff0c;发现对应关联表的关联字段不展示&#xff08;原表该字段展示在后排&#xff0c;关系图只展示前排字段&#xff09; 2.找到对应表&#xff0c;对该字段手动设置可见 3.保存后再次进入关系图即可看到 3.1 3.2…

LabVIEW程序员可以从哪几个方面提升自己?有没有详细的路线图?

作为一名LabVIEW程序员&#xff0c;要在快速发展的技术领域保持竞争力并不断提升自己&#xff0c;需要从多个方面进行持续的学习和实践。下面我将为你详细说明LabVIEW程序员提升自己的几个关键方向&#xff0c;并给出具体的成长路线图。 1. 夯实基础&#xff1a;掌握LabVIEW的…

解决mac ssh端终端只有黑白颜色的问题

主要是因为没有开启颜色配置。修改下文件即可 cd ~ vi .zshrc 内容如下 export LS_OPTIONS--colorauto export CLICOLORYes export LSCOLORSExgxcxdxcxegedabagGxGx 关闭终端后重登录&#xff0c;这下有颜色了好看了 配色&#xff1a;目录蓝 可执行绿 软链青 颜色配置 详…

MyBatis入门之一对一关联关系(示例)

【图书介绍】《SpringSpring MVCMyBatis从零开始学&#xff08;视频教学版&#xff09;&#xff08;第3版&#xff09;》-CSDN博客 《SpringSpring MVCMyBatis从零开始学(视频教学版)&#xff08;第3版&#xff09;》(杨章伟&#xff0c;刘祥淼)【摘要 书评 试读】- 京东图书 …

CTFHUB技能树之SQL——字符型注入

开启靶场&#xff0c;打开链接&#xff1a; 直接指明是SQL字符型注入&#xff0c;但还是来判断一下 &#xff08;1&#xff09;检查是否存在注入点 1 and 11# 返回正确 1 and 12# 返回错误 说明存在SQL字符型注入 &#xff08;2&#xff09;猜字段数 1 order by 2# 1 order…

InnoDB引擎(架构,事务原理,MVCC详细解读)

目录 架构分析 逻辑存储结构​ 内存结构​ Buffer Pool​ ChaneBuffer 自适应哈希​ LogBuffer​ 磁盘结构​ 后台线程​ 事务原理​ redolog日志 undolog日志​ MVCC​ 三个隐藏字段​ undolog版本链 readview​ RC(读已提交原理分析)​ RR(可重复读原理分析…

MySQL 数据库的备份与恢复:最佳实践与深度探讨

MySQL 数据库的备份与恢复&#xff1a;最佳实践与深度探讨 在现代应用程序和企业系统中&#xff0c;数据库是其核心组件之一&#xff0c;负责存储和管理大量的关键数据。MySQL 作为一种广泛应用的开源数据库管理系统&#xff0c;支持高性能和可扩展性&#xff0c;被广泛应用于…

aws 把vpc残留删除干净

最近忘了把vpc 删干净导致又被收了冤大头钱 在删除vpc 的收发现又eni在使用&#xff0c;但是忘了是哪个资源在占用 先用命令行把占用的资源找出来停掉 使用 AWS 命令行界面&#xff08;CLI&#xff09;来查看 VPC 的使用情况 列出子网&#xff1a; aws ec2 describe-subnets …

每日一道算法题(Leetcode 20)

Whats past is prologue. 凡是过去&#xff0c;皆为序章。 题目 分析 1. 我们可以用栈的结构来解决这道题。 2. 我们使用while循环&#xff0c;每次读取字符串中一个元素进行操作&#xff0c;直到最后读取到 \0为止。 3. 如果遇见 (, [ ,{ 这三种左括号&#xff0c;则把该左…