欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 旅游 > 鸿蒙NEXT开发资源工具类(ArkTs)

鸿蒙NEXT开发资源工具类(ArkTs)

2025/4/13 21:15:36 来源:https://blog.csdn.net/weixin_48639457/article/details/147067747  浏览:    关键词:鸿蒙NEXT开发资源工具类(ArkTs)
import { AppUtil } from './AppUtil';
import { StrUtil } from './StrUtil';
import { resourceManager } from '@kit.LocalizationKit';/*** 资源工具类。* 提供访问应用资源的能力,包括布尔值、数字、字符串等资源的获取。** @author 鸿蒙布道师* @since 2025/04/08*/
export class ResUtil {/*** 获取提供访问应用资源的能力。** @returns 返回 ResourceManager 实例。*/static getResourceManager(): resourceManager.ResourceManager {return AppUtil.getContext().resourceManager;}/*** 获取指定资源对应的布尔结果。** @param resId 资源 ID 值或资源信息。* @returns 返回布尔值。*/static getBoolean(resId: number | Resource): boolean {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getBoolean(resId) : manager.getBoolean(resId);}/*** 获取指定资源名称对应的布尔结果。** @param resName 资源名称。* @returns 返回布尔值。*/static getBooleanByName(resName: string): boolean {return ResUtil.getResourceManager().getBooleanByName(resName);}/*** 获取指定资源对应的整数或浮点数值。** @param resId 资源 ID 值或资源信息。* @returns 返回数值。*/static getNumber(resId: number | Resource): number {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getNumber(resId) : manager.getNumber(resId);}/*** 获取指定资源名称对应的整数或浮点数值。** @param resName 资源名称。* @returns 返回数值。*/static getNumberByName(resName: string): number {return ResUtil.getResourceManager().getNumberByName(resName);}/*** 获取指定资源对应的字符串。* 支持格式化参数:* - 格式化符号:%d、%f、%s、%%、%数字\$d、%数字\$f、%数字\$s;* - 说明:%%转义为%; %数字\$d表示使用第几个参数;* - 示例:%%d格式化后为%d字符串; %1\$d表示使用第一个参数。** @param resId 资源 ID 值或资源信息。* @param args 格式化字符串资源参数(可选)。* @returns 返回格式化后的字符串。*/static getStringSync(resId: number | Resource, ...args: Array<string | number>): string {const manager = ResUtil.getResourceManager();return typeof resId === 'number'? manager.getStringSync(resId, ...args): manager.getStringSync(resId, ...args);}/*** 异步获取指定资源对应的字符串。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为字符串。*/static async getStringValue(resId: number | Resource): Promise<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number'? manager.getStringValue(resId): manager.getStringValue(resId);}/*** 获取指定资源名称对应的字符串(同步)。* 支持格式化参数:* - 格式化符号:%d、%f、%s、%%、%数字\$d、%数字\$f、%数字\$s;* - 说明:%%转义为%; %数字\$d表示使用第几个参数;* - 示例:%%d格式化后为%d字符串; %1\$d表示使用第一个参数。** @param resName 资源名称。* @param args 格式化字符串资源参数(可选)。* @returns 返回格式化后的字符串。*/static getStringByNameSync(resName: string, ...args: Array<string | number>): string {const manager = ResUtil.getResourceManager();return args.length > 0 ? manager.getStringByNameSync(resName, ...args) : manager.getStringByNameSync(resName);}/*** 获取指定资源名称对应的字符串(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为字符串。*/static async getStringByName(resName: string): Promise<string> {return ResUtil.getResourceManager().getStringByName(resName);}/*** 获取指定资源对应的字符串数组(同步)。** @param resId 资源 ID 值或资源信息。* @returns 返回字符串数组。*/static getStringArrayValueSync(resId: number | Resource): Array<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getStringArrayValueSync(resId) : manager.getStringArrayValueSync(resId);}/*** 获取指定资源对应的字符串数组(异步)。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为字符串数组。*/static async getStringArrayValue(resId: number | Resource): Promise<Array<string>> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getStringArrayValue(resId) : manager.getStringArrayValue(resId);}/*** 获取指定资源名称对应的字符串数组(同步)。** @param resName 资源名称。* @returns 返回字符串数组。*/static getStringArrayByNameSync(resName: string): Array<string> {return ResUtil.getResourceManager().getStringArrayByNameSync(resName);}/*** 获取指定资源名称对应的字符串数组(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为字符串数组。*/static async getStringArrayByName(resName: string): Promise<Array<string>> {return ResUtil.getResourceManager().getStringArrayByName(resName);}/*** 根据指定数量获取单复数字符串(同步)。** @param resId 资源 ID 值或资源信息。* @param num 数量值。* @returns 返回单复数字符串。*/static getPluralStringValueSync(resId: number | Resource, num: number): string {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getPluralStringValueSync(resId, num) : manager.getPluralStringValueSync(resId, num);}/*** 根据指定数量获取单复数字符串(异步)。** @param resId 资源 ID 值或资源信息。* @param num 数量值。* @returns 返回 Promise,解析为单复数字符串。*/static async getPluralStringValue(resId: number | Resource, num: number): Promise<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getPluralStringValue(resId, num) : manager.getPluralStringValue(resId, num);}/*** 根据指定数量获取资源名称对应的单复数字符串(同步)。** @param resName 资源名称。* @param num 数量值。* @returns 返回单复数字符串。*/static getPluralStringByNameSync(resName: string, num: number): string {return ResUtil.getResourceManager().getPluralStringByNameSync(resName, num);}/*** 根据指定数量获取资源名称对应的单复数字符串(异步)。** @param resName 资源名称。* @param num 数量值。* @returns 返回 Promise,解析为单复数字符串。*/static async getPluralStringByName(resName: string, num: number): Promise<string> {return ResUtil.getResourceManager().getPluralStringByName(resName, num);}/*** 获取指定资源对应的颜色值(十进制)(同步)。** @param resId 资源 ID 值或资源信息。* @returns 返回颜色值(十进制)。*/static getColorSync(resId: number | Resource): number {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getColorSync(resId) : manager.getColorSync(resId);}/*** 获取指定资源对应的颜色值(十进制)(异步)。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为颜色值(十进制)。*/static async getColor(resId: number | Resource): Promise<number> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getColor(resId) : manager.getColor(resId);}/*** 获取指定资源名称对应的颜色值(十进制)(同步)。** @param resName 资源名称。* @returns 返回颜色值(十进制)。*/static getColorByNameSync(resName: string): number {return ResUtil.getResourceManager().getColorByNameSync(resName);}/*** 获取指定资源名称对应的颜色值(十进制)(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为颜色值(十进制)。*/static async getColorByName(resName: string): Promise<number> {return ResUtil.getResourceManager().getColorByName(resName);}/*** 获取指定资源对应的媒体文件内容(同步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @returns 返回媒体文件内容(Uint8Array)。*/static getMediaContentSync(resId: number | Resource, density?: number): Uint8Array {const manager = ResUtil.getResourceManager();return density !== undefined? (typeof resId === 'number' ? manager.getMediaContentSync(resId, density) : manager.getMediaContentSync(resId, density)): (typeof resId === 'number' ? manager.getMediaContentSync(resId) : manager.getMediaContentSync(resId));}/*** 获取指定资源对应的媒体文件内容(异步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @returns 返回 Promise,解析为媒体文件内容(Uint8Array)。*/static async getMediaContent(resId: number | Resource, density?: number): Promise<Uint8Array> {const manager = ResUtil.getResourceManager();return density !== undefined? (typeof resId === 'number' ? manager.getMediaContent(resId, density) : manager.getMediaContent(resId, density)): (typeof resId === 'number' ? manager.getMediaContent(resId) : manager.getMediaContent(resId));}/*** 获取指定资源名称对应的媒体文件内容(同步或异步)。** @param resName 资源名称。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回媒体文件内容(Uint8Array)。*/static getMediaByName(resName: string, density?: number, isAsync = false): Uint8Array | Promise<Uint8Array> {const manager = ResUtil.getResourceManager();if (isAsync) {return density !== undefined? manager.getMediaByName(resName, density): manager.getMediaByName(resName);} else {return density !== undefined? manager.getMediaByNameSync(resName, density): manager.getMediaByNameSync(resName);}}/*** 获取指定资源 ID 对应的图片资源 Base64 编码(同步或异步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回图片资源 Base64 编码。*/static getMediaContentBase64(resId: number | Resource,density?: number,isAsync = false): string | Promise<string> {const manager = ResUtil.getResourceManager();const callMethod = isAsync ? 'getMediaContentBase64' : 'getMediaContentBase64Sync';return density !== undefined? typeof resId === 'number'? manager[callMethod](resId, density): manager[callMethod](resId, density): typeof resId === 'number'? manager[callMethod](resId): manager[callMethod](resId);}/*** 获取指定资源名称对应的图片资源 Base64 编码(同步或异步)。** @param resName 资源名称。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回图片资源 Base64 编码。*/static getMediaBase64ByName(resName: string,density?: number,isAsync = false): string | Promise<string> {const manager = ResUtil.getResourceManager();return isAsync? density !== undefined? manager.getMediaBase64ByName(resName, density): manager.getMediaBase64ByName(resName): density !== undefined? manager.getMediaBase64ByNameSync(resName, density): manager.getMediaBase64ByNameSync(resName);}/*** 获取 resources/rawfile 目录下对应的 rawfile 文件内容(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件内容(Uint8Array)。*/static getRawFileContent(path: string, isAsync = false): Uint8Array | Promise<Uint8Array> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFileContent(path) : manager.getRawFileContentSync(path);}/*** 获取 resources/rawfile 目录下对应的 rawfile 文件内容,并转换为字符串(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件内容(字符串)。*/static getRawFileContentStr(path: string, isAsync = false): string | Promise<string> {const getContent = isAsync? async (): Promise<string> => StrUtil.unit8ArrayToStr(await ResUtil.getRawFileContent(path, true)): (): string => StrUtil.unit8ArrayToStr(ResUtil.getRawFileContent(path, false));return getContent();}/*** 获取 resources/rawfile 目录下文件夹及文件列表(同步或异步)。** @param path rawfile 文件夹路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件列表。*/static getRawFileList(path: string, isAsync = false): Array<string> | Promise<Array<string>> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFileList(path) : manager.getRawFileListSync(path);}/*** 获取 resources/rawfile 目录下对应 rawfile 文件所在 HAP 的 descriptor 信息(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回 RawFileDescriptor。*/static getRawFd(path: string, isAsync = false): resourceManager.RawFileDescriptor | Promise<resourceManager.RawFileDescriptor> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFd(path) : manager.getRawFdSync(path);}/*** 关闭 resources/rawfile 目录下 rawfile 文件所在 HAP 的 descriptor 信息(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。*/static closeRawFd(path: string, isAsync = false): void | Promise<void> {const manager = ResUtil.getResourceManager();return isAsync ? manager.closeRawFd(path) : manager.closeRawFdSync(path);}/*** 获取设备的 Configuration(同步或异步)。** @param isAsync 是否为异步操作,默认为 false。* @returns 返回设备的 Configuration。*/static getConfiguration(isAsync = false): resourceManager.Configuration | Promise<resourceManager.Configuration> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getConfiguration() : manager.getConfigurationSync();}/*** 获取设备的 DeviceCapability(同步或异步)。** @param isAsync 是否为异步操作,默认为 false。* @returns 返回设备的 DeviceCapability。*/static getDeviceCapability(isAsync = false): resourceManager.DeviceCapability | Promise<resourceManager.DeviceCapability> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getDeviceCapability() : manager.getDeviceCapabilitySync();}/*** 应用运行时,加载指定的资源路径,实现资源覆盖。** @param path 资源路径。*/static addResource(path: string): void {ResUtil.getResourceManager().addResource(path);}/*** 用户运行时,移除指定的资源路径,还原被覆盖前的资源。** @param path 资源路径。*/static removeResource(path: string): void {ResUtil.getResourceManager().removeResource(path);}/*** 判断指定路径是否是 rawfile 下的目录。** @param path rawfile 路径。* @returns true 表示是 rawfile 下的目录,false 表示不是。*/static isRawDir(path: string): boolean {return ResUtil.getResourceManager().isRawDir(path);}
}
代码如下:
import { AppUtil } from './AppUtil';
import { StrUtil } from './StrUtil';
import { resourceManager } from '@kit.LocalizationKit';/*** 资源工具类。* 提供访问应用资源的能力,包括布尔值、数字、字符串等资源的获取。** @author 鸿蒙布道师* @since 2025/04/08*/
export class ResUtil {/*** 获取提供访问应用资源的能力。** @returns 返回 ResourceManager 实例。*/static getResourceManager(): resourceManager.ResourceManager {return AppUtil.getContext().resourceManager;}/*** 获取指定资源对应的布尔结果。** @param resId 资源 ID 值或资源信息。* @returns 返回布尔值。*/static getBoolean(resId: number | Resource): boolean {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getBoolean(resId) : manager.getBoolean(resId);}/*** 获取指定资源名称对应的布尔结果。** @param resName 资源名称。* @returns 返回布尔值。*/static getBooleanByName(resName: string): boolean {return ResUtil.getResourceManager().getBooleanByName(resName);}/*** 获取指定资源对应的整数或浮点数值。** @param resId 资源 ID 值或资源信息。* @returns 返回数值。*/static getNumber(resId: number | Resource): number {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getNumber(resId) : manager.getNumber(resId);}/*** 获取指定资源名称对应的整数或浮点数值。** @param resName 资源名称。* @returns 返回数值。*/static getNumberByName(resName: string): number {return ResUtil.getResourceManager().getNumberByName(resName);}/*** 获取指定资源对应的字符串。* 支持格式化参数:* - 格式化符号:%d、%f、%s、%%、%数字\$d、%数字\$f、%数字\$s;* - 说明:%%转义为%; %数字\$d表示使用第几个参数;* - 示例:%%d格式化后为%d字符串; %1\$d表示使用第一个参数。** @param resId 资源 ID 值或资源信息。* @param args 格式化字符串资源参数(可选)。* @returns 返回格式化后的字符串。*/static getStringSync(resId: number | Resource, ...args: Array<string | number>): string {const manager = ResUtil.getResourceManager();return typeof resId === 'number'? manager.getStringSync(resId, ...args): manager.getStringSync(resId, ...args);}/*** 异步获取指定资源对应的字符串。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为字符串。*/static async getStringValue(resId: number | Resource): Promise<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number'? manager.getStringValue(resId): manager.getStringValue(resId);}/*** 获取指定资源名称对应的字符串(同步)。* 支持格式化参数:* - 格式化符号:%d、%f、%s、%%、%数字\$d、%数字\$f、%数字\$s;* - 说明:%%转义为%; %数字\$d表示使用第几个参数;* - 示例:%%d格式化后为%d字符串; %1\$d表示使用第一个参数。** @param resName 资源名称。* @param args 格式化字符串资源参数(可选)。* @returns 返回格式化后的字符串。*/static getStringByNameSync(resName: string, ...args: Array<string | number>): string {const manager = ResUtil.getResourceManager();return args.length > 0 ? manager.getStringByNameSync(resName, ...args) : manager.getStringByNameSync(resName);}/*** 获取指定资源名称对应的字符串(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为字符串。*/static async getStringByName(resName: string): Promise<string> {return ResUtil.getResourceManager().getStringByName(resName);}/*** 获取指定资源对应的字符串数组(同步)。** @param resId 资源 ID 值或资源信息。* @returns 返回字符串数组。*/static getStringArrayValueSync(resId: number | Resource): Array<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getStringArrayValueSync(resId) : manager.getStringArrayValueSync(resId);}/*** 获取指定资源对应的字符串数组(异步)。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为字符串数组。*/static async getStringArrayValue(resId: number | Resource): Promise<Array<string>> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getStringArrayValue(resId) : manager.getStringArrayValue(resId);}/*** 获取指定资源名称对应的字符串数组(同步)。** @param resName 资源名称。* @returns 返回字符串数组。*/static getStringArrayByNameSync(resName: string): Array<string> {return ResUtil.getResourceManager().getStringArrayByNameSync(resName);}/*** 获取指定资源名称对应的字符串数组(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为字符串数组。*/static async getStringArrayByName(resName: string): Promise<Array<string>> {return ResUtil.getResourceManager().getStringArrayByName(resName);}/*** 根据指定数量获取单复数字符串(同步)。** @param resId 资源 ID 值或资源信息。* @param num 数量值。* @returns 返回单复数字符串。*/static getPluralStringValueSync(resId: number | Resource, num: number): string {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getPluralStringValueSync(resId, num) : manager.getPluralStringValueSync(resId, num);}/*** 根据指定数量获取单复数字符串(异步)。** @param resId 资源 ID 值或资源信息。* @param num 数量值。* @returns 返回 Promise,解析为单复数字符串。*/static async getPluralStringValue(resId: number | Resource, num: number): Promise<string> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getPluralStringValue(resId, num) : manager.getPluralStringValue(resId, num);}/*** 根据指定数量获取资源名称对应的单复数字符串(同步)。** @param resName 资源名称。* @param num 数量值。* @returns 返回单复数字符串。*/static getPluralStringByNameSync(resName: string, num: number): string {return ResUtil.getResourceManager().getPluralStringByNameSync(resName, num);}/*** 根据指定数量获取资源名称对应的单复数字符串(异步)。** @param resName 资源名称。* @param num 数量值。* @returns 返回 Promise,解析为单复数字符串。*/static async getPluralStringByName(resName: string, num: number): Promise<string> {return ResUtil.getResourceManager().getPluralStringByName(resName, num);}/*** 获取指定资源对应的颜色值(十进制)(同步)。** @param resId 资源 ID 值或资源信息。* @returns 返回颜色值(十进制)。*/static getColorSync(resId: number | Resource): number {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getColorSync(resId) : manager.getColorSync(resId);}/*** 获取指定资源对应的颜色值(十进制)(异步)。** @param resId 资源 ID 值或资源信息。* @returns 返回 Promise,解析为颜色值(十进制)。*/static async getColor(resId: number | Resource): Promise<number> {const manager = ResUtil.getResourceManager();return typeof resId === 'number' ? manager.getColor(resId) : manager.getColor(resId);}/*** 获取指定资源名称对应的颜色值(十进制)(同步)。** @param resName 资源名称。* @returns 返回颜色值(十进制)。*/static getColorByNameSync(resName: string): number {return ResUtil.getResourceManager().getColorByNameSync(resName);}/*** 获取指定资源名称对应的颜色值(十进制)(异步)。** @param resName 资源名称。* @returns 返回 Promise,解析为颜色值(十进制)。*/static async getColorByName(resName: string): Promise<number> {return ResUtil.getResourceManager().getColorByName(resName);}/*** 获取指定资源对应的媒体文件内容(同步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @returns 返回媒体文件内容(Uint8Array)。*/static getMediaContentSync(resId: number | Resource, density?: number): Uint8Array {const manager = ResUtil.getResourceManager();return density !== undefined? (typeof resId === 'number' ? manager.getMediaContentSync(resId, density) : manager.getMediaContentSync(resId, density)): (typeof resId === 'number' ? manager.getMediaContentSync(resId) : manager.getMediaContentSync(resId));}/*** 获取指定资源对应的媒体文件内容(异步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @returns 返回 Promise,解析为媒体文件内容(Uint8Array)。*/static async getMediaContent(resId: number | Resource, density?: number): Promise<Uint8Array> {const manager = ResUtil.getResourceManager();return density !== undefined? (typeof resId === 'number' ? manager.getMediaContent(resId, density) : manager.getMediaContent(resId, density)): (typeof resId === 'number' ? manager.getMediaContent(resId) : manager.getMediaContent(resId));}/*** 获取指定资源名称对应的媒体文件内容(同步或异步)。** @param resName 资源名称。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回媒体文件内容(Uint8Array)。*/static getMediaByName(resName: string, density?: number, isAsync = false): Uint8Array | Promise<Uint8Array> {const manager = ResUtil.getResourceManager();if (isAsync) {return density !== undefined? manager.getMediaByName(resName, density): manager.getMediaByName(resName);} else {return density !== undefined? manager.getMediaByNameSync(resName, density): manager.getMediaByNameSync(resName);}}/*** 获取指定资源 ID 对应的图片资源 Base64 编码(同步或异步)。** @param resId 资源 ID 值或资源信息。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回图片资源 Base64 编码。*/static getMediaContentBase64(resId: number | Resource,density?: number,isAsync = false): string | Promise<string> {const manager = ResUtil.getResourceManager();const callMethod = isAsync ? 'getMediaContentBase64' : 'getMediaContentBase64Sync';return density !== undefined? typeof resId === 'number'? manager[callMethod](resId, density): manager[callMethod](resId, density): typeof resId === 'number'? manager[callMethod](resId): manager[callMethod](resId);}/*** 获取指定资源名称对应的图片资源 Base64 编码(同步或异步)。** @param resName 资源名称。* @param density 屏幕密度(可选),0 或缺省表示默认屏幕密度。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回图片资源 Base64 编码。*/static getMediaBase64ByName(resName: string,density?: number,isAsync = false): string | Promise<string> {const manager = ResUtil.getResourceManager();return isAsync? density !== undefined? manager.getMediaBase64ByName(resName, density): manager.getMediaBase64ByName(resName): density !== undefined? manager.getMediaBase64ByNameSync(resName, density): manager.getMediaBase64ByNameSync(resName);}/*** 获取 resources/rawfile 目录下对应的 rawfile 文件内容(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件内容(Uint8Array)。*/static getRawFileContent(path: string, isAsync = false): Uint8Array | Promise<Uint8Array> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFileContent(path) : manager.getRawFileContentSync(path);}/*** 获取 resources/rawfile 目录下对应的 rawfile 文件内容,并转换为字符串(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件内容(字符串)。*/static getRawFileContentStr(path: string, isAsync = false): string | Promise<string> {const getContent = isAsync? async (): Promise<string> => StrUtil.unit8ArrayToStr(await ResUtil.getRawFileContent(path, true)): (): string => StrUtil.unit8ArrayToStr(ResUtil.getRawFileContent(path, false));return getContent();}/*** 获取 resources/rawfile 目录下文件夹及文件列表(同步或异步)。** @param path rawfile 文件夹路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回文件列表。*/static getRawFileList(path: string, isAsync = false): Array<string> | Promise<Array<string>> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFileList(path) : manager.getRawFileListSync(path);}/*** 获取 resources/rawfile 目录下对应 rawfile 文件所在 HAP 的 descriptor 信息(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。* @returns 返回 RawFileDescriptor。*/static getRawFd(path: string, isAsync = false): resourceManager.RawFileDescriptor | Promise<resourceManager.RawFileDescriptor> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getRawFd(path) : manager.getRawFdSync(path);}/*** 关闭 resources/rawfile 目录下 rawfile 文件所在 HAP 的 descriptor 信息(同步或异步)。** @param path rawfile 文件路径。* @param isAsync 是否为异步操作,默认为 false。*/static closeRawFd(path: string, isAsync = false): void | Promise<void> {const manager = ResUtil.getResourceManager();return isAsync ? manager.closeRawFd(path) : manager.closeRawFdSync(path);}/*** 获取设备的 Configuration(同步或异步)。** @param isAsync 是否为异步操作,默认为 false。* @returns 返回设备的 Configuration。*/static getConfiguration(isAsync = false): resourceManager.Configuration | Promise<resourceManager.Configuration> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getConfiguration() : manager.getConfigurationSync();}/*** 获取设备的 DeviceCapability(同步或异步)。** @param isAsync 是否为异步操作,默认为 false。* @returns 返回设备的 DeviceCapability。*/static getDeviceCapability(isAsync = false): resourceManager.DeviceCapability | Promise<resourceManager.DeviceCapability> {const manager = ResUtil.getResourceManager();return isAsync ? manager.getDeviceCapability() : manager.getDeviceCapabilitySync();}/*** 应用运行时,加载指定的资源路径,实现资源覆盖。** @param path 资源路径。*/static addResource(path: string): void {ResUtil.getResourceManager().addResource(path);}/*** 用户运行时,移除指定的资源路径,还原被覆盖前的资源。** @param path 资源路径。*/static removeResource(path: string): void {ResUtil.getResourceManager().removeResource(path);}/*** 判断指定路径是否是 rawfile 下的目录。** @param path rawfile 路径。* @returns true 表示是 rawfile 下的目录,false 表示不是。*/static isRawDir(path: string): boolean {return ResUtil.getResourceManager().isRawDir(path);}
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词