鸿蒙ArkUI声明式学习:【UI资源管理】

OpenHarmony 应用的资源分类和资源的访问以及应用开发使用的像素单位以及各单位之间相互转换的方法。

资源分类

移动端应用开发常用到的资源比如图片,音视频,字符串等都有固定的存放目录,OpenHarmony 把这些应用的资源文件统一放在 resources 目录下的各子目录中便于开发者使用和维护, resoures 目录包括两大类,一类为 base 目录与限定词目录,另一类为 rawfile 目录。新建 OpenHarmony 应用,默认生成的资源目录如下所示:

2_3_1_1

base 目录与限定词目录下面可以创建资源组目录(包括 element 、 media 、animation 、 layout 、 graphic 、 profile ),用于存放特定类型的资源文件,各资源目录说明如下图所示:

2_3_1_2

鸿蒙OS开发更多内容↓点击HarmonyOS与OpenHarmony技术
鸿蒙技术文档开发知识更新库gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md在这。

搜狗高速浏览器截图20240326151547.png

资源访问

如果失效请添加mau123789是v直接拿取鸿蒙学习文档

OpenHarmony 应用资源分为两类,一类是应用资源,另一类是系统资源,它们的资源访问方式如下:

  • 访问应用资源

    base 目录下的资源文件会被编译成二进制文件并且给这些资源赋予唯一的 ID ,使用相应资源的时候通过资源访问符  r ( ′ a p p . t y p e . n a m e ′ ) ∗ ∗ 的形式, ∗ ∗ a p p ∗ ∗ 代表是应用内  ‘ r e s o u r c e s ‘ 目录中定义的资源; ∗ ∗ t y p e ∗ ∗ 表示资源类型,可取值有  ‘ c o l o r ‘ 、  ‘ f l o a t ‘ 、  ‘ s t r i n g ‘ 、  ‘ s t r i n g ‘ 、  ‘ m e d i a ‘ 等; ∗ ∗ n a m e ∗ ∗ 表示资源的文件名字。例如  ∗ ∗ s t r i n g . j s o n ∗ ∗ 中新加  ∗ ∗ n a m e ∗ ∗ 为  ∗ ∗ t e x t s t r i n g ∗ ∗ 的字符串,则访问该字符串资源为  ∗ ∗ r('app.type.name')**  的形式,**app** 代表是应用内 `resources` 目录中定义的资源;**type** 表示资源类型,可取值有 `color` 、 `float` 、 `string` 、 `string` 、 `media` 等;**name** 表示资源的文件名字。例如 **string.json** 中新加 **name** 为 **text_string** 的字符串,则访问该字符串资源为  ** r(app.type.name) 的形式,app 代表是应用内 ‘resources‘ 目录中定义的资源;type 表示资源类型,可取值有 ‘color‘  ‘float‘  ‘string‘  ‘string‘  ‘media‘ 等;name 表示资源的文件名字。例如 string.json 中新加 name  textstring 的字符串,则访问该字符串资源为 r(‘app.string.text_string’)

    笔者在 base 目录下新建 float.json 和 color.json 文件,分别存放字体和颜色,资源内容如下图所示:

    2_3_2_1

    通过  $(‘app.type.name’)  访问资源的简单样例如下所示:

    @Entry @Component struct ResourceTest {build() {Column({space: 10}) {Text($r('app.string.text_string'))                       // 访问字符串资源.size({width: 300, height: 120})                       // 设置尺寸.fontSize($r('app.float.text_size'))                   // 访问字体大小.fontColor($r('app.color.text_color'))                 // 访问字体颜色.backgroundImage($r('app.media.test'), ImageRepeat.XY) // 设备背景图片}.width('100%').height('100%').padding(10)}
    }
    

    样例运行结果如下图所示:

    2_3_2_2

  • 访问系统资源

    系统资源包含 颜色 、 圆角 、 字体 、 间距 、 字符串 及 图片 等,通过使用系统资源,不同的开发者可以开发出具有相同视觉风格的应用,开发者可以通过  $r(‘sys.type.name’)  的形式引用系统资源,和访问应用资源不同的是使用 sys 代表系统资源,其它和访问应用资源规则一致。

    访问系统资源简单样例如下所示:

    @Entry @Component struct ResourceTest {build() {Column() {Text('Hello').fontColor($r('sys.color.ohos_id_color_emphasize')).fontSize($r('sys.float.ohos_id_text_size_headline1')).fontFamily($r('sys.string.ohos_id_text_font_family_medium')).backgroundColor($r('sys.color.ohos_id_color_palette_aux1'))Image($r('sys.media.ohos_app_icon')).border({color: $r('sys.color.ohos_id_color_palette_aux1'),radius: $r('sys.float.ohos_id_corner_radius_button'),width: 2}).margin({top: $r('sys.float.ohos_id_elements_margin_horizontal_m'),bottom: $r('sys.float.ohos_id_elements_margin_horizontal_l')}).height(200).width(300)}.padding(10).width("100%").height("100%")}
    }
    

    样例运行结果如下图所示:

    2_3_2_3

像素单位

ArkUI开发框架提供了 4 种像素单位供开发者使用,分别是: px 、 vp 、 fp 和 lpx ,它们之间的区别如下表所示:

名称描述
px屏幕物理像素单位。
vp屏幕密度相关像素单位,根据屏幕像素密度转换为屏幕物理像素。
fp字体像素,与vp类似适用于屏幕密度变化,随系统字体大小设置变化。
lpx视窗逻辑像素单位,lpx单位为实际屏幕宽度与逻辑宽度(在 config.json 中配置的 designWidth )的比值,如配置 designWdith 为 720 时,在实际宽度为 1440 物理像素的屏幕上, 1px 为 2px 。

ArkUI开发框架也提供了全局方法把这些不同的尺寸单位相互转换,全局方法如下所示:

declare function vp2px(value: number): number;
declare function px2vp(value: number): number;
declare function fp2px(value: number): number;
declare function px2fp(value: number): number;
declare function lpx2px(value: number): number;
declare function px2lpx(value: number): number;
  • vp2px:将 vp 单位的数值转换为以 px 为单位的数值。
  • px2vp:将 px 单位的数值转换为以 vp 为单位的数值。
  • fp2px:将 fp 单位的数值转换为以 px 为单位的数值。
  • px2fp:将 px 单位的数值转换为以 fp 为单位的数值。
  • lpx2px:将 lpx 单位的数值转换为以 px 为单位的数值。
  • px2lpx:将 px 单位的数值转换为以 lpx 为单位的数值。

这些单位尺寸具体大小,笔者举个简单样例演示一下:

@Entry @Component struct ResourceTest {build() {Column() {Flex({ wrap: FlexWrap.Wrap }) {Column() {Text("width(220)").width(220).height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center).fontSize('12vp')}.margin(5)Column() {Text("width('220px')").width('220px').height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center)}.margin(5)Column() {Text("width('220vp')").width('220vp').height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center).fontSize('12vp')}.margin(5)Column() {Text("width('220lpx') designWidth:720").width('220lpx').height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center).fontSize('12vp')}.margin(5)Column() {Text("width(vp2px(220) + 'px')").width(vp2px(220) + 'px').height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center).fontSize('12vp')}.margin(5)Column() {Text("fontSize('12fp')").width(220).height(40).backgroundColor(Color.Pink).textAlign(TextAlign.Center).fontSize('12fp')}.margin(5)}.width('100%').height("100%")}.width('100%').height("100%").padding(10)}
}

样例运行结果如下图所示:

2_3_3_1

资源管理器

ArkUI开发框架在 @ohos.resourceManager 模块里提供了资源管理器 ResourceManager,它可以访问不同的资源,比如获取获取字符串资源,获取设备配置信息等等,resourceManager 模块提供部分 API 如下所示:

declare namespace resourceManager {// 省略部分代码export interface ResourceManager {// 获取字符串资源getString(resId: number, callback: AsyncCallback<string>): void;// 获取字符串数组资源getStringArray(resId: number, callback: AsyncCallback<Array<string>>): void;// 获取媒体资源getMedia(resId: number, callback: AsyncCallback<Uint8Array>): void;// 获取设备信息,比如当前屏幕密度,设备类型是手机还是平板等getDeviceCapability(callback: AsyncCallback<DeviceCapability>): void;// 获取配置信息,比如当前屏幕方向密度,当前设备语言getConfiguration(callback: AsyncCallback<Configuration>): void;// 释放ResourceManager资源release();}
}
export default resourceManager;

使用 ResourceManager 之前先调用 getContext(this) 方法获取当前组件的 Context,该 Conetxt 内部定义了一个 ResourceManager 的属性,因此可以直接使用 ResourceManager 的各种 getXXX() 方法获取对应资源, ResourceManager 使用流程如下所示:

  • 引入 resourceManager

    import resourceManager from '@ohos.resourceManager';
    

    1

  • 获取 ResourceManager

    aboutToAppear() {// 获取ResourceManagerlet manager = getContext(this).resourceManager;
    }
    
  • 使用 ResourceManager

    manager.getString(0x1000001, (innerError, data) => {if(data) {// 获取资源成功} else {console.log("error: " + JSON.stringify(innerError))}
    })
    
  • 释放 ResourceManager

    this.manager.release();
    

完整样例如下所示:

import resourceManager from '@ohos.resourceManager';@Entry @Component struct ResourceTest {@State text_string: string = "";@State capability: string = "";@State configuration: string = "";private resManager: resourceManager.ResourceManager;build() {Column({ space: 10 }) {Text(this.text_string)                   // 访问字符串资源.size({ width: 300, height: 120 })     // 设置尺寸.fontSize($r('app.float.text_size'))   // 访问字体大小.fontColor($r('app.color.text_color')) // 访问字体颜色.backgroundImage($r('app.media.test')) // 设备背景图片Text(this.capability)                    // capability信息.fontSize(20)Text(this.configuration)                 // configuration信息.fontSize(20)}.width('100%').height('100%').padding(10)}aboutToAppear() {this.resManager = getContext(this).resourceManager;this.resManager.getStringValue(0x1000001, (innerError, data) => {if(data) {this.text_string = data;} else {console.log("error: " + JSON.stringify(innerError));}})this.resManager.getDeviceCapability((innerError, deviceCapability) => {if(deviceCapability) {this.capability = JSON.stringify(deviceCapability);}})this.resManager.getConfiguration((innerError, configuration) => {if(configuration) {this.configuration = JSON.stringify(configuration);}})}aboutToDisappear() {this.resManager?.release(); // 释放 ReleaseManager 资源}}

样例运行结果如下图所示:

2_3_4_1

渲染出来的 mock string 是因为在预览器上暂时不支持 ResourceManager 的用法,在实际设备上是没问题的。

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaWeb物流信息网的设计与实现

摘要 本文讲述了基于JSP物流信息网的设计与实现。该系统使用java语言开发&#xff0c;使系统具有更好的平台性和可扩展性。 该系统实现了用户登录、注册、查询快递信息、快递公司注册成为合作伙伴以及系统管理员对信息进行管理等功能。系统的主要界面会将所有的服务排列好&…

AI资讯2024-04-08 | 斯坦福大学推出手机端运行大模型—Octopus v2,性能超越GPT-4

关注文章底部公众号可获取每日AI新闻,还有更多好玩使用的黑科技工具分享 斯坦福大学推出可在手机端运行大模型—Octopus v2 Octopus-V2-2B 是一个拥有 20 亿参数的开源语言模型,专为 Android API 量身定制,旨在在 Android 设备上无缝运行,并将实用性扩展到从 Android 系统…

【学习】移动端App性能测试流程有哪些

移动端App性能测试是保证App性能表现的重要环节之一。随着移动设备的普及和移动互联网的发展&#xff0c;移动端App的性能测试变得越来越重要&#xff0c;通过科学合理的性能测试可以发现并解决潜在的性能问题优化App运行效果提高用户体验。性能测试旨在评估App在各种场景下的性…

射影几何基础

射影几何基础 文章目录 射影几何基础2D2D点2D直线二次曲线 3D3D点3D 平面3D直线 2D 2D点 欧氏空间中的笛卡尔坐标&#xff0c;缩放、旋转和仿射变换能表示成矩阵运算&#xff08;线性&#xff09; &#xff1b; 但平移变换和透视投影不能表示成矩阵相乘。所以为了解决这个问题…

2024年最新可用免费云服务器整理汇总

随着云计算技术的不断发展&#xff0c;越来越多的个人和企业开始使用云服务器来满足其数据存储、网站搭建、应用开发等需求。其中&#xff0c;免费云服务器更是受到广大用户的青睐。本文将为大家整理汇总最新的可用免费云服务器资源&#xff0c;助力大家轻松享受云上之旅&#…

mos管开关出现尖峰的原理? mos管开关的时候cs会出现尖峰,请问这是什么原因?

MOS管在开关过程中出现尖峰现象&#xff0c;通常是由于电路中的寄生参数和快速电压变化引起的。以下是一些导致尖峰出现的主要原因和原理&#xff1a; 寄生电容 在MOS管的源极&#xff08;S&#xff09;和漏极&#xff08;D&#xff09;之间存在寄生电容&#xff0c;这个电容在…

CSS变换

CSS变换 根据 CSS 的变换的功能特性&#xff0c;它可以分为位移、旋转、缩放、倾斜和透视&#xff1a; 也可以分成2D变换和3D变换&#xff0c;2D变换是二维平面上进行的&#xff0c;即 X 轴和 Y 轴。这些变换不涉及 Z 轴。3D 变换允许元素在三维空间中进行操作&#xff0c;这些…

BioXCell,1H6--InVivoMAb anti-canine CD34

1H6单克隆抗体与犬CD34发生反应。CD34是一种I型单体唾液酸粘蛋白样糖蛋白&#xff0c;存在于许多干细胞群体中。CD34由骨髓和外周血中的造血祖细胞以及一些间充质干细胞、基质细胞、胚胎成纤维细胞、肿瘤细胞和成人血管内皮细胞表达。CD34经常被用作量化用于造血干细胞移植后该…

【第二十九篇】BurpSuite杂项综合

文章目录 Intruder模块URL编码Grep检索提取logger日志模块Intruder模块URL编码 假设我们需要对GET请求包中的URL目录进行爆破FUZZ: example.com/xxxx(文件名)Intruder模块会自动对我们的文件名字典进行URL编码 例如payload为1.txt时,burp对其进行URL编码并连接到example.c…

vulhub之fastjson篇-1.2.27-rce

一、启动环境 虚拟机:kali靶机:192.168.125.130/172.19.0.1(docker地址:172.19.0.2) 虚拟机:kali攻击机:192.168.125.130/172.19.0.1 本地MAC:172.XX.XX.XX 启动 fastjson 反序列化导致任意命令执行漏洞 环境 1.进入 vulhub 的 Fastjson 1.2.47 路径 cd /../../vulhub/fa…

代码算法训练营day13 | 239. 滑动窗口最大值、347.前 K 个高频元素

day13: 239. 滑动窗口最大值1、&#xff08;暴力算法&#xff09;思路&#xff1a;2、&#xff08;单调队列&#xff09;思路&#xff1a; 347.前 K 个高频元素 239. 滑动窗口最大值 题目链接 状态&#xff1a;暴力ok 文档&#xff1a;programmercarl.com 1、&#xff08;暴力算…

[C语言]——动态内存经典笔试题分析

目录 一.题目1 1.运行结果 2.分析 3.问题所在 4.更正 二.题目2 1.运行结果 2.分析 3.问题所在 4.更正 三.题目3 1.问题所在 2.更正&#xff1a; 四.题目4 一.题目1 void GetMemory(char *p){p (char *)malloc(100);}void Test(void){char *str NULL;GetMemory…