48 Star 141 Fork 33

ArkUI-X/docs

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
js-apis-resource-manager.md 104.48 KB
一键复制 编辑 原始数据 按行查看 历史
mamingshuai 提交于 2024-06-24 14:43 . Upgrade to ArkUI-X-2.0.0-Beta1

@ohos.resourceManager (资源管理)

资源管理模块,根据当前configuration:语言、区域、横竖屏、Mcc(移动国家码)和Mnc(移动网络码)、Device capability(设备类型)、Density(分辨率)提供获取应用资源信息读取接口。

说明:

本模块首批接口从API version 6开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

使用说明

从API Version9开始,Stage模型通过context获取resourceManager对象的方式后,可直接调用其内部获取资源的接口,无需再导入包。

import UIAbility from '@ohos.app.ability.UIAbility';

export default class EntryAbility extends UIAbility {
    onWindowStageCreate(windowStage) {
        let context = this.context;
        let resourceManager = context.resourceManager;
    }
}

Direction

用于表示设备屏幕方向。

系统能力:SystemCapability.Global.ResourceManager

名称 说明
DIRECTION_VERTICAL 0 竖屏
DIRECTION_HORIZONTAL 1 横屏

DeviceType

用于表示当前设备类型。

系统能力:SystemCapability.Global.ResourceManager

名称 说明
DEVICE_TYPE_PHONE 0x00 手机

ScreenDensity

用于表示当前设备屏幕密度。

系统能力:SystemCapability.Global.ResourceManager

名称 说明
SCREEN_SDPI 120 小规模的屏幕密度
SCREEN_MDPI 160 中规模的屏幕密度
SCREEN_LDPI 240 大规模的屏幕密度
SCREEN_XLDPI 320 特大规模的屏幕密度
SCREEN_XXLDPI 480 超大规模的屏幕密度
SCREEN_XXXLDPI 640 超特大规模的屏幕密度

Configuration

表示当前设备的状态。

系统能力:SystemCapability.Global.ResourceManager

参数:

名称 类型 可读 可写 说明
direction Direction 当前设备屏幕方向
locale string 当前系统语言

示例:

this.context.resourceManager.getConfiguration((error, value) => {
  let direction = value.direction;
  let locale = value.locale;
});

DeviceCapability

表示设备支持的能力。

系统能力:SystemCapability.Global.ResourceManager

参数:

名称 类型 可读 可写 说明
screenDensity ScreenDensity 当前设备屏幕密度
deviceType DeviceType 当前设备类型

示例:

this.context.resourceManager.getDeviceCapability((error, value) => {
  let screenDensity = value.screenDensity;
  let deviceType = value.deviceType;
});

RawFileDescriptor8+

表示rawfile的descriptor信息。

系统能力: SystemCapability.Global.ResourceManager

参数:

名称 类型 可读 可写 说明
fd number rawfile所在hap的文件描述符
offset number rawfile的起始偏移量
length number rawfile的文件长度

Resource9+

表示的资源信息。

系统能力: 以下各项对应的系统能力均为SystemCapability.Global.ResourceManager

参数:

名称 类型 可读 可写 说明
bundleName string 应用的bundle名称
moduleName string 应用的module名称
id number 资源的id值

ResourceManager

提供访问应用资源的能力。

说明:

  • ResourceManager涉及到的方法,仅限基于TS扩展的声明式开发范式使用。

  • 资源文件在工程的resources目录中定义,id可通过$r(资源地址).id的方式获取,例如$r('app.string.test').id。

getStringValue9+

getStringValue(resId: number, callback: AsyncCallback<string>): void

用户获取指定资源ID对应的字符串,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
callback AsyncCallback<string> 异步回调,用于返回获取的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the module resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例Stage:

  try {
      this.context.resourceManager.getStringValue($r('app.string.test').id, (error, value) => {
        if (error != null) {
            console.log("error is " + error);
        } else {
            let str = value;
        }
    });
  } catch (error) {
      console.error(`callback getStringValue failed, error code: ${error.code}, message: ${error.message}.`)
  }

getStringValue9+

getStringValue(resId: number): Promise<string>

用户获取指定资源ID对应的字符串,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
Promise<string> 资源ID值对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringValue($r('app.string.test').id).then(value => {
      let str = value;
  }).catch(error => {
      console.log("getStringValue promise error is " + error);
  });
} catch (error) {
  console.error(`promise getStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringValue9+

getStringValue(resource: Resource, callback: AsyncCallback<string>): void

用户获取指定resource对象对应的字符串,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
callback AsyncCallback<string> 异步回调,用于返回获取的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.string.test').id
};
try {
  this.context.resourceManager.getStringValue(resource, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let str = value;
      }
  });
} catch (error) {
  console.error(`callback getStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringValue9+

getStringValue(resource: Resource): Promise<string>

用户获取指定resource对象对应的字符串,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
Promise<string> resource对象对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.string.test').id
};
try {
  this.context.resourceManager.getStringValue(resource).then(value => {
    let str = value;
  }).catch(error => {
    console.log("getStringValue promise error is " + error);
  });
} catch (error) {
  console.error(`callback getStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayValue9+

getStringArrayValue(resId: number, callback: AsyncCallback<Array<string>>): void

用户获取指定资源ID对应的字符串数组,使用callback形式返回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
callback AsyncCallback<Array<string>> 异步回调,用于返回获取的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringArrayValue($r('app.strarray.test').id, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let strArray = value;
      }
  });
} catch (error) {
  console.error(`callback getStringArrayValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayValue9+

getStringArrayValue(resId: number): Promise<Array<string>>

用户获取指定资源ID对应的字符串数组,使用Promise形式返回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
Promise<Array<string>> 资源ID值对应的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringArrayValue($r('app.strarray.test').id).then(value => {
      let strArray = value;
  }).catch(error => {
      console.log("getStringArrayValue promise error is " + error);
  });
} catch (error) {
  console.error(`promise getStringArrayValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayValue9+

getStringArrayValue(resource: Resource, callback: AsyncCallback<Array<string>>): void

用户获取指定resource对象对应的字符串数组,使用callback形式返回回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
callback AsyncCallback<Array<string>> 异步回调,用于返回获取的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.strarray.test').id
};
try {
  this.context.resourceManager.getStringArrayValue(resource, (error, value) => {
    if (error != null) {
        console.log("error is " + error);
    } else {
        let strArray = value;
    }
  });
} catch (error) {
  console.error(`callback getStringArrayValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayValue9+

getStringArrayValue(resource: Resource): Promise<Array<string>>

用户获取指定resource对象对应的字符串数组,使用Promise形式返回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
Promise<Array<string>> resource对象对应的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.strarray.test').id
};
try {
  this.context.resourceManager.getStringArrayValue(resource).then(value => {
    let strArray = value;
  }).catch(error => {
      console.log("getStringArray promise error is " + error);
  });
} catch (error) {
  console.error(`promise getStringArrayValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent9+

getMediaContent(resId: number, callback: AsyncCallback<Uint8Array>): void

用户获取指定资源ID对应的媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContent($r('app.media.test').id, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent10+

getMediaContent(resId: number, density: number, callback: AsyncCallback<Uint8Array>): void

用户获取指定资源ID对应的指定屏幕密度媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContent($r('app.media.test').id, 120, (error, value) => {
      if (error != null) {
          console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent9+

getMediaContent(resId: number): Promise<Uint8Array>

用户获取指定资源ID对应的媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
Promise<Uint8Array> 资源ID值对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
    this.context.resourceManager.getMediaContent($r('app.media.test').id).then(value => {
        let media = value;
    }).catch(error => {
        console.log("getMediaContent promise error is " + error);
    });
} catch (error) {
  console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent10+

getMediaContent(resId: number, density: number): Promise<Uint8Array>

用户获取指定资源ID对应的指定屏幕密度媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<Uint8Array> 资源ID值对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
    this.context.resourceManager.getMediaContent($r('app.media.test').id, 120).then(value => {
        let media = value;
    }).catch(error => {
        console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`);
    });
} catch (error) {
  console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent9+

getMediaContent(resource: Resource, callback: AsyncCallback<Uint8Array>): void

用户获取指定resource对象对应的媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContent(resource, (error, value) => {
      if (error != null) {
        console.log("error is " + error);
      } else {
        let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent10+

getMediaContent(resource: Resource, density: number, callback: AsyncCallback<Uint8Array>): void

用户获取指定resource对象对应的指定屏幕密度媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContent(resource, 120, (error, value) => {
      if (error != null) {
        console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
        let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent9+

getMediaContent(resource: Resource): Promise<Uint8Array>

用户获取指定resource对象对应的媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
Promise<Uint8Array> resource对象对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContent(resource).then(value => {
    let media = value;
  }).catch(error => {
    console.log("getMediaContent promise error is " + error);
  });
} catch (error) {
  console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContent10+

getMediaContent(resource: Resource, density: number): Promise<Uint8Array>

用户获取指定resource对象对应的指定屏幕密度媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<Uint8Array> resource对象对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContent(resource, 120).then(value => {
    let media = value;
  }).catch(error => {
    console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getMediaContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase649+

getMediaContentBase64(resId: number, callback: AsyncCallback<string>): void

用户获取指定资源ID对应的图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContentBase64($r('app.media.test').id, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let media = value;
      }
  });       
} catch (error) {
  console.error(`callback getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase6410+

getMediaContentBase64(resId: number, density: number, callback: AsyncCallback<string>): void

用户获取指定资源ID对应的指定屏幕密度图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContentBase64($r('app.media.test').id, 120, (error, value) => {
      if (error != null) {
          console.error(`callback getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
          let media = value;
      }
  });       
} catch (error) {
  console.error(`callback getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase649+

getMediaContentBase64(resId: number): Promise<string>

用户获取指定资源ID对应的图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
Promise<string> 资源ID值对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContentBase64($r('app.media.test').id).then(value => {
      let media = value;
  }).catch(error => {
      console.log("getMediaContentBase64 promise error is " + error);
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase6410+

getMediaContentBase64(resId: number, density: number): Promise<string>

用户获取指定资源ID对应的指定屏幕密度图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<string> 资源ID值对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

try {
  this.context.resourceManager.getMediaContentBase64($r('app.media.test').id, 120).then(value => {
      let media = value;
  }).catch(error => {
      console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase649+

getMediaContentBase64(resource: Resource, callback: AsyncCallback<string>): void

用户获取指定resource对象对应的图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContentBase64(resource, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase6410+

getMediaContentBase64(resource: Resource, density: number, callback: AsyncCallback<string>): void

用户获取指定resource对象对应的指定屏幕密度图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContentBase64(resource, 120, (error, value) => {
      if (error != null) {
          console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase649+

getMediaContentBase64(resource: Resource): Promise<string>

用户获取指定resource对象对应的图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
Promise<string> resource对象对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContentBase64(resource).then(value => {
      let media = value;
  }).catch(error => {
      console.log("getMediaContentBase64 promise error is " + error);
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaContentBase6410+

getMediaContentBase64(resource: Resource, density: number): Promise<string>

用户获取指定resource对象对应的指定屏幕密度图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<string> resource对象对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.media.test').id
};
try {
  this.context.resourceManager.getMediaContentBase64(resource, 120).then(value => {
      let media = value;
  }).catch(error => {
      console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getMediaContentBase64 failed, error code: ${error.code}, message: ${error.message}.`)
}

getConfiguration

getConfiguration(callback: AsyncCallback<Configuration>): void

用户获取设备的Configuration,使用callback形式返回Configuration对象。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
callback AsyncCallback<Configuration> 异步回调,用于返回设备的Configuration

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.getConfiguration((error, value) => {
        if (error != null) {
            console.log("error is " + error);
        } else {
            let direction = value.direction;
            let locale = value.locale;
        }
    });
});

getConfiguration

getConfiguration(): Promise<Configuration>

用户获取设备的Configuration,使用Promise形式返回Configuration对象。

系统能力:SystemCapability.Global.ResourceManager

返回值:

类型 说明
Promise<Configuration> 设备的Configuration

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.getConfiguration().then(value => {
        let direction = value.direction;
        let locale = value.locale;
    }).catch(error => {
        console.log("getConfiguration promise error is " + error);
    });
});

getDeviceCapability

getDeviceCapability(callback: AsyncCallback<DeviceCapability>): void

用户获取设备的DeviceCapability,使用callback形式返回DeviceCapability对象。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
callback AsyncCallback<DeviceCapability> 异步回调,用于返回设备的DeviceCapability

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.getDeviceCapability((error, value) => {
        if (error != null) {
            console.log("error is " + error);
        } else {
            let screenDensity = value.screenDensity;
            let deviceType = value.deviceType;
        }
    });
});

getDeviceCapability

getDeviceCapability(): Promise<DeviceCapability>

用户获取设备的DeviceCapability,使用Promise形式返回DeviceCapability对象。

系统能力:SystemCapability.Global.ResourceManager

返回值:

类型 说明
Promise<DeviceCapability> 设备的DeviceCapability

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.getDeviceCapability().then(value => {
        let screenDensity = value.screenDensity;
        let deviceType = value.deviceType;
    }).catch(error => {
        console.log("getDeviceCapability promise error is " + error);
    });
});

getPluralStringValue9+

getPluralStringValue(resId: number, num: number, callback: AsyncCallback<string>): void

根据指定数量获取指定ID字符串表示的单复数字符串,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
num number 数量值
callback AsyncCallback<string> 异步回调,返回根据指定数量获取指定ID字符串表示的单复数字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getPluralStringValue($r("app.plural.test").id, 1, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let str = value;
      }
  });
} catch (error) {
  console.error(`callback getPluralStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}   

getPluralStringValue9+

getPluralStringValue(resId: number, num: number): Promise<string>

根据指定数量获取对指定ID字符串表示的单复数字符串,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
num number 数量值

返回值:

类型 说明
Promise<string> 根据提供的数量获取对应ID字符串表示的单复数字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getPluralStringValue($r("app.plural.test").id, 1).then(value => {
      let str = value;
  }).catch(error => {
      console.log("getPluralStringValue promise error is " + error);
  });
} catch (error) {
  console.error(`callback getPluralStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}  

getPluralStringValue9+

getPluralStringValue(resource: Resource, num: number, callback: AsyncCallback<string>): void

根据指定数量获取指定resource对象表示的单复数字符串,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
num number 数量值
callback AsyncCallback<string> 异步回调,返回根据指定数量获取指定resource对象表示的单复数字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.plural.test').id
};
try {
  this.context.resourceManager.getPluralStringValue(resource, 1, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let str = value;
      }
  });
} catch (error) {
  console.error(`callback getPluralStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}  

getPluralStringValue9+

getPluralStringValue(resource: Resource, num: number): Promise<string>

根据指定数量获取对指定resource对象表示的单复数字符串,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
num number 数量值

返回值:

类型 说明
Promise<string> 根据提供的数量获取对应resource对象表示的单复数字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.plural.test').id
};
try {
  this.context.resourceManager.getPluralStringValue(resource, 1).then(value => {
      let str = value;
  }).catch(error => {
      console.log("getPluralStringValue promise error is " + error);
  });
} catch (error) {
  console.error(`callback getPluralStringValue failed, error code: ${error.code}, message: ${error.message}.`)
}

getRawFileContent9+

getRawFileContent(path: string, callback: AsyncCallback<Uint8Array>): void

用户获取resources/rawfile目录下对应的rawfile文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的rawfile文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 If the resource not found by path.

示例:

try {
  this.context.resourceManager.getRawFileContent("test.xml", (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let rawFile = value;
      }
  });
} catch (error) {
  console.error(`callback getRawFileContent failed, error code: ${error.code}, message: ${error.message}.`)
}
    

getRawFileContent9+

getRawFileContent(path: string): Promise<Uint8Array>

用户获取resources/rawfile目录下对应的rawfile文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径

返回值:

类型 说明
Promise<Uint8Array> rawfile文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 If the resource not found by path.

示例:

try {
  this.context.resourceManager.getRawFileContent("test.xml").then(value => {
      let rawFile = value;
  }).catch(error => {
      console.log("getRawFileContent promise error is " + error);
  });
} catch (error) {
  console.error(`promise getRawFileContent failed, error code: ${error.code}, message: ${error.message}.`)
}

getRawFd9+

getRawFd(path: string, callback: AsyncCallback<RawFileDescriptor>): void

用户获取resources/rawfile目录下对应rawfile文件的descriptor,使用callback形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径
callback AsyncCallback<RawFileDescriptor> 异步回调,用于返回获取的rawfile文件的descriptor

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 If the resource not found by path.

示例:

try {
  this.context.resourceManager.getRawFd("test.xml", (error, value) => {
      if (error != null) {
          console.log(`callback getRawFd failed error code: ${error.code}, message: ${error.message}.`);
      } else {
          let fd = value.fd;
          let offset = value.offset;
          let length = value.length;
      }
  });
} catch (error) {
    console.error(`callback getRawFd failed, error code: ${error.code}, message: ${error.message}.`)
};

getRawFd9+

getRawFd(path: string): Promise<RawFileDescriptor>

用户获取resources/rawfile目录下对应rawfile文件的descriptor,使用Promise形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径

返回值:

类型 说明
Promise<RawFileDescriptor> rawfile文件descriptor

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 If the resource not found by path.

示例:

try {
  this.context.resourceManager.getRawFd("test.xml").then(value => {
      let fd = value.fd;
      let offset = value.offset;
      let length = value.length;
  }).catch(error => {
      console.log(`promise getRawFd error error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getRawFd failed, error code: ${error.code}, message: ${error.message}.`);
};

closeRawFileDescriptor8+

closeRawFileDescriptor(path: string, callback: AsyncCallback<void>): void

用户关闭resources/rawfile目录下rawfile文件的descriptor,使用callback形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径
callback AsyncCallback<void> 异步回调

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.closeRawFileDescriptor("test.xml", (error, value) => {
        if (error != null) {
            console.log("error is " + error);
        }
    });
});

closeRawFileDescriptor8+

closeRawFileDescriptor(path: string): Promise<void>

用户关闭resources/rawfile目录下rawfile文件的descriptor,使用Promise形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径

返回值:

类型 说明
Promise<void> 无返回值

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.closeRawFileDescriptor("test.xml").then(value => {
        let result = value;
    }).catch(error => {
        console.log("closeRawFileDescriptor promise error is " + error);
    });
});

closeRawFd9+

closeRawFd(path: string, callback: AsyncCallback<void>): void

用户关闭resources/rawfile目录下rawfile文件的descriptor,使用callback形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径
callback AsyncCallback<void> 异步回调

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 The resource not found by path.

示例:

try {
  this.context.resourceManager.closeRawFd("test.xml", (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      }
  });
} catch (error) {
  console.error(`callback closeRawFd failed, error code: ${error.code}, message: ${error.message}.`)
}
    

closeRawFd9+

closeRawFd(path: string): Promise<void>

用户关闭resources/rawfile目录下rawfile文件的descriptor,使用Promise形式返回。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
path string rawfile文件路径

返回值:

类型 说明
Promise<void> 无返回值

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001005 If the resource not found by path.

示例:

try {
  this.context.resourceManager.closeRawFd("test.xml").then(value => {
      let result = value;
  }).catch(error => {
      console.log("closeRawFd promise error is " + error);
  });
} catch (error) {
  console.error(`promise closeRawFd failed, error code: ${error.code}, message: ${error.message}.`)
}

release7+

release()

用户释放创建的resourceManager。

系统能力:SystemCapability.Global.ResourceManager

示例:

resourceManager.getResourceManager((error, mgr) => {
    mgr.release();
});

getStringByName9+

getStringByName(resName: string, callback: AsyncCallback<string>): void

用户获取指定资源名称对应的字符串,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
callback AsyncCallback<string> 异步回调,用于返回获取的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringByName("test", (error, value) => {
      if (error != null) {
           console.log("error is " + error);
      } else {
          let string = value;
      }
  });
} catch (error) {
  console.error(`callback getStringByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringByName9+

getStringByName(resName: string): Promise<string>

用户获取指定资源名称对应的字符串,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
Promise<string> 资源名称对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringByName("test").then(value => {
      let string = value;
  }).catch(error => {
      console.log("getStringByName promise error is " + error);
  });
} catch (error) {
  console.error(`promise getStringByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayByName9+

getStringArrayByName(resName: string, callback: AsyncCallback<Array<string>>): void

用户获取指定资源名称对应的字符串数组,使用callback形式返回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
callback AsyncCallback<Array<string>> 异步回调,用于返回获取的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringArrayByName("test", (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let strArray = value;
      }
  });
} catch (error) {
  console.error(`callback getStringArrayByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringArrayByName9+

getStringArrayByName(resName: string): Promise<Array<string>>

用户获取指定资源名称对应的字符串数组,使用Promise形式返回字符串数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
Promise<Array<string>> 资源名称对应的字符串数组

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringArrayByName("test").then(value => {
      let strArray = value;
  }).catch(error => {
      console.log("getStringArrayByName promise error is " + error);
  });
} catch (error) {
  console.error(`promise getStringArrayByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaByName9+

getMediaByName(resName: string, callback: AsyncCallback<Uint8Array>): void

用户获取指定资源ID对应的媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaByName("test", (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaByName10+

getMediaByName(resName: string, density: number, callback: AsyncCallback<Uint8Array>): void

用户获取指定资源ID对应的指定屏幕密度媒体文件内容,使用callback形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<Uint8Array> 异步回调,用于返回获取的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaByName("test", 120, (error, value) => {
      if (error != null) {
          console.error(`callback getMediaByName failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaByName9+

getMediaByName(resName: string): Promise<Uint8Array>

用户获取指定资源名称对应的媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
Promise<Uint8Array> 资源名称对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaByName("test").then(value => {
      let media = value;
  }).catch(error => {
      console.log("getMediaByName promise error is " + error);
  });
} catch (error) {
  console.error(`promise getMediaByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaByName10+

getMediaByName(resName: string, density: number): Promise<Uint8Array>

用户获取指定资源名称对应的指定屏幕密度媒体文件内容,使用Promise形式返回字节数组。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<Uint8Array> 资源名称对应的媒体文件内容

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaByName("test", 120).then(value => {
      let media = value;
  }).catch(error => {
      console.error(`promise getMediaByName failed, error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getMediaByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaBase64ByName9+

getMediaBase64ByName(resName: string, callback: AsyncCallback<string>): void

用户获取指定资源名称对应的图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaBase64ByName("test", (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaBase64ByName10+

getMediaBase64ByName(resName: string, density: number, callback: AsyncCallback<string>): void

用户获取指定资源名称对应的指定屏幕密度图片资源Base64编码,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
density number 资源获取需要的屏幕密度,0表示默认屏幕密度
callback AsyncCallback<string> 异步回调,用于返回获取的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaBase64ByName("test", 120, (error, value) => {
      if (error != null) {
          console.error(`callback getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`);
      } else {
          let media = value;
      }
  });
} catch (error) {
  console.error(`callback getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaBase64ByName9+

getMediaBase64ByName(resName: string): Promise<string>

用户获取指定资源名称对应的图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
Promise<string> 资源名称对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaBase64ByName("test").then(value => {
      let media = value;
  }).catch(error => {
      console.log("getMediaBase64ByName promise error is " + error);
  });
} catch (error) {
  console.error(`promise getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getMediaBase64ByName10+

getMediaBase64ByName(resName: string, density: number): Promise<string>

用户获取指定资源名称对应的指定屏幕密度图片资源Base64编码,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
density number 资源获取需要的屏幕密度,0表示默认屏幕密度

返回值:

类型 说明
Promise<string> 资源名称对应的图片资源Base64编码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.

示例:

try {
  this.context.resourceManager.getMediaBase64ByName("test", 120).then(value => {
      let media = value;
  }).catch(error => {
      console.error(`promise getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`);
  });
} catch (error) {
  console.error(`promise getMediaBase64ByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getDrawableDescriptor10+

getDrawableDescriptor(resId: number, density?: number, type?: number): DrawableDescriptor

用户获取指定资源ID对应的DrawableDescriptor对象,用于图标的显示,使用同步方式返回。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值。
density number 资源获取需要的屏幕密度,0或缺省表示默认屏幕密度。
type11+ number Android和ios平台仅支持0或缺省,表示取应用自身图标资源。

返回值:

类型 说明
DrawableDescriptor 资源ID值对应的DrawableDescriptor对象。

错误码:

以下错误码的详细介绍请参见资源管理错误码通用错误码

错误码ID 错误信息
401 If the input parameter invalid. Possible causes: 1.Incorrect parameter types; 2.Parameter verification failed.
9001001 Invalid resource ID.
9001002 No matching resource is found based on the resource ID.

示例:

import { BusinessError } from '@ohos.base';

try {
  this.context.resourceManager.getDrawableDescriptor($r('app.media.icon').id);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptor($r('app.media.icon').id, 120);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptor($r('app.media.icon').id, 0, 1);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}

getDrawableDescriptor10+

getDrawableDescriptor(resource: Resource, density?: number, type?: number): DrawableDescriptor

用户获取指定resource对应的DrawableDescriptor对象,用于图标的显示,使用同步方式返回。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Global.ResourceManager

模型约束:此接口仅可在Stage模型下使用。

参数:

参数名 类型 必填 说明
resource Resource 资源信息。
density number 资源获取需要的屏幕密度,0或缺省表示默认屏幕密度。
type11+ number Android和ios平台仅支持0或缺省,表示取应用自身图标资源。

返回值:

类型 说明
DrawableDescriptor 资源ID值对应的DrawableDescriptor对象。

错误码:

以下错误码的详细介绍请参见资源管理错误码通用错误码

错误码ID 错误信息
401 If the input parameter invalid. Possible causes: 1.Incorrect parameter types; 2.Parameter verification failed.
9001001 Invalid resource ID.
9001002 No matching resource is found based on the resource ID.

示例:

import resourceManager from '@ohos.resourceManager';
import { BusinessError } from '@ohos.base';

let resource: resourceManager.Resource = {
  bundleName: "com.example.myapplication",
  moduleName: "entry",
  id: $r('app.media.icon').id
};
try {
  this.context.resourceManager.getDrawableDescriptor(resource);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptor(resource, 120);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptor(resource, 0, 1);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptor failed, error code: ${code}, message: ${message}.`);
}

getDrawableDescriptorByName10+

getDrawableDescriptorByName(resName: string, density?: number, type?: number): DrawableDescriptor

用户获取指定资源名称对应的DrawableDescriptor对象,用于图标的显示,使用同步方式返回。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称。
density number 资源获取需要的屏幕密度,0或缺省表示默认屏幕密度。
type11+ number Android和ios平台仅支持0或缺省,表示取应用自身图标资源。

返回值:

类型 说明
DrawableDescriptor 资源ID值对应的DrawableDescriptor对象。

错误码:

以下错误码的详细介绍请参见资源管理错误码通用错误码

错误码ID 错误信息
401 If the input parameter invalid. Possible causes: 1.Incorrect parameter types; 2.Parameter verification failed.
9001003 Invalid resource name.
9001004 No matching resource is found based on the resource name.

示例:

import { BusinessError } from '@ohos.base';

try {
  this.context.resourceManager.getDrawableDescriptorByName('icon');
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptorByName failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptorByName('icon', 120);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptorByName failed, error code: ${code}, message: ${message}.`);
}
try {
  this.context.resourceManager.getDrawableDescriptorByName('icon', 0, 1);
} catch (error) {
  let code = (error as BusinessError).code;
  let message = (error as BusinessError).message;
  console.error(`getDrawableDescriptorByName failed, error code: ${code}, message: ${message}.`);
}

getPluralStringByName9+

getPluralStringByName(resName: string, num: number, callback: AsyncCallback<string>): void

根据传入的数量值,获取资源名称对应的字符串资源,使用callback形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
num number 数量值
callback AsyncCallback<string> 异步回调,返回根据传入的数量值获取资源名称对应的字符串资源

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getPluralStringByName("test", 1, (error, value) => {
      if (error != null) {
          console.log("error is " + error);
      } else {
          let str = value;
      }
  });
} catch (error) {
  console.error(`callback getPluralStringByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getPluralStringByName9+

getPluralStringByName(resName: string, num: number): Promise<string>

根据传入的数量值,获取资源名称对应的字符串资源,使用Promise形式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
num number 数量值

返回值:

类型 说明
Promise<string> 根据传入的数量值获取资源名称对应的字符串资源

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getPluralStringByName("test", 1).then(value => {
    let str = value;
  }).catch(error => {
    console.log("getPluralStringByName promise error is " + error);
  });
} catch (error) {
  console.error(`promise getPluralStringByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringSync9+

getStringSync(resId: number): string

用户获取指定资源ID对应的字符串,使用同步方式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
string 资源ID值对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringSync($r('app.string.test').id);
} catch (error) {
  console.error(`getStringSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringSync10+

getStringSync(resId: number, ...args: Array<string | number>): string

用户获取指定资源ID对应的字符串,根据args参数进行格式化,使用同步方式返回相应字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值
args Array<string | number> 格式化字符串资源参数
支持参数类型:
-%d、%f、%s、%%
说明:%%转译符,转译%
举例:%%d格式化后为%d字符串

返回值:

类型 说明
string 资源ID值对应的格式化字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.
9001007 If the resource obtained by resId formatting error.

示例:

try {
  this.context.resourceManager.getStringSync($r('app.string.test').id, "format string", 10, 98.78);
} catch (error) {
  console.error(`getStringSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringSync9+

getStringSync(resource: Resource): string

用户获取指定resource对象对应的字符串,使用同步方式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
string resource对象对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.string.test').id
};
try {
  this.context.resourceManager.getStringSync(resource);
} catch (error) {
  console.error(`getStringSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringSync10+

getStringSync(resource: Resource, ...args: Array<string | number>): string

用户获取指定resource对象对应的字符串,根据args参数进行格式化,使用同步方式返回相应字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息
args Array<string | number> 格式化字符串资源参数
支持参数类型:
-%d、%f、%s、%%
说明:%%转译符,转译%
举例:%%d格式化后为%d字符串

返回值:

类型 说明
string resource对象对应的格式化字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.
9001007 If the resource obtained by resId formatting error.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.string.test').id
};
try {
  this.context.resourceManager.getStringSync(resource, "format string", 10, 98.78);
} catch (error) {
  console.error(`getStringSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringByNameSync9+

getStringByNameSync(resName: string): string

用户获取指定资源名称对应的字符串,使用同步方式返回字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
string 资源名称对应的字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getStringByNameSync("test");
} catch (error) {
  console.error(`getStringByNameSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getStringByNameSync10+

getStringByNameSync(resName: string, ...args: Array<string | number>): string

用户获取指定资源名称对应的字符串,根据args参数进行格式化,使用同步方式返回相应字符串。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称
args Array<string | number> 格式化字符串资源参数
支持参数类型:
-%d、%f、%s、%%
说明:%%转译符,转译%
举例:%%d格式化后为%d字符串

返回值:

类型 说明
string 资源名称对应的格式化字符串

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.
9001008 If the resource obtained by resName formatting error.

示例:

try {
  this.context.resourceManager.getStringByNameSync("test", "format string", 10, 98.78);
} catch (error) {
  console.error(`getStringByNameSync failed, error code: ${error.code}, message: ${error.message}.`)
}

getBoolean9+

getBoolean(resId: number): boolean

使用同步方式,返回获取指定资源ID对应的布尔结果。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
boolean 资源ID值对应的布尔结果

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getBoolean($r('app.boolean.boolean_test').id);
} catch (error) {
  console.error(`getBoolean failed, error code: ${error.code}, message: ${error.message}.`)
}

getBoolean9+

getBoolean(resource: Resource): boolean

使用同步方式,返回获取指定resource对象对应的布尔结果。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
boolean resource对象对应的布尔结果

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.boolean.boolean_test').id
};
try {
  this.context.resourceManager.getBoolean(resource);
} catch (error) {
  console.error(`getBoolean failed, error code: ${error.code}, message: ${error.message}.`)
}

getBooleanByName9+

getBooleanByName(resName: string): boolean

使用同步方式,返回获取指定资源名称对应的布尔结果

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
boolean 资源名称对应的布尔结果

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getBooleanByName("boolean_test");
} catch (error) {
  console.error(`getBooleanByName failed, error code: ${error.code}, message: ${error.message}.`)
}

getNumber9+

getNumber(resId: number): number

用户获取指定资源ID对应的integer数值或者float数值,使用同步方式返回资源对应的数值。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resId number 资源ID值

返回值:

类型 说明
number 资源ID值对应的数值。Integer对应的是原数值,float对应的是真实像素点值,具体参考示例代码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getNumber($r('app.integer.integer_test').id); // integer对应返回的是原数值
} catch (error) {
  console.error(`getNumber failed, error code: ${error.code}, message: ${error.message}.`)
}

try {
  this.context.resourceManager.getNumber($r('app.float.float_test').id); // float对应返回的是真实像素点值
} catch (error) {
  console.error(`getNumber failed, error code: ${error.code}, message: ${error.message}.`)
}

getNumber9+

getNumber(resource: Resource): number

用户获取指定resource对象对应的integer数值或者float数值,使用同步方式返回资源对应的数值。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resource Resource 资源信息

返回值:

类型 说明
number resource对象对应的数值。Integer对应的是原数值,float对应的是真实像素点值, 具体参考示例代码

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001001 If the resId invalid.
9001002 If the resource not found by resId.
9001006 If the resource re-ref too much.

示例:

let resource = {
    bundleName: "com.example.myapplication",
    moduleName: "entry",
    id: $r('app.integer.integer_test').id
};
try {
  this.context.resourceManager.getNumber(resource);// integer对应返回的是原数值, float对应返回的是真实像素点值
} catch (error) {
  console.error(`getNumber failed, error code: ${error.code}, message: ${error.message}.`)
}

getNumberByName9+

getNumberByName(resName: string): number

用户获取指定资源名称对应的integer数值或者float数值,使用同步方式资源对应的数值。

系统能力:SystemCapability.Global.ResourceManager

参数:

参数名 类型 必填 说明
resName string 资源名称

返回值:

类型 说明
number 资源名称对应的数值

错误码:

以下错误码的详细介绍请参见资源管理错误码

错误码ID 错误信息
9001003 If the resName invalid.
9001004 If the resource not found by resName.
9001006 If the resource re-ref too much.

示例:

try {
  this.context.resourceManager.getNumberByName("integer_test");
} catch (error) {
  console.error(`getNumberByName failed, error code: ${error.code}, message: ${error.message}.`)
}

try {
  this.context.resourceManager.getNumberByName("float_test");
} catch (error) {
  console.error(`getNumberByName failed, error code: ${error.code}, message: ${error.message}.`)
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/arkui-x/docs.git
git@gitee.com:arkui-x/docs.git
arkui-x
docs
docs
master

搜索帮助

A270a887 8829481 3d7a4017 8829481