鸿蒙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);
  }
}
代码如下:
TypeScript 复制代码
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);
  }
}
相关推荐
SuperHeroWu738 分钟前
【HarmonyOS 5】使用openCustomDialog如何禁止手势关闭的方案
华为·harmonyos·open·customdialog·手势关闭
SuperHeroWu739 分钟前
【HarmonyOS 5】鸿蒙的装饰器原理和自定义装饰器
华为·harmonyos·鸿蒙·装饰器·原理·自定义装饰器
脱脱克克41 分钟前
2025.4.9 华为机考 第1题-补丁版本升级
python·算法·华为
jiet_h3 小时前
使用 Ktor 构建现代 Android 应用的后端服务
android
returnShitBoy5 小时前
iOS 上的内存管理是如何处理的?
macos·ios·cocoa
深漂阿碉6 小时前
Android studio2024的第一个安卓项目
android
zilong_zzz6 小时前
文件IO4(提高LCD显示效率/BMP图像原理与应用)
android
_一条咸鱼_7 小时前
大厂Android面试秘籍:Activity 窗口管理模块(四)
android·面试·android jetpack
opentogether9 小时前
PODS_ROOT、BUILT_PRODUCTS_DIR和SRCROOT有什么区别
ios
心之所想,行之将至9 小时前
零基础开始学习鸿蒙开发-智能家居APP离线版介绍
学习·智能家居·harmonyos