# @ohos.wallpaper (壁纸) 壁纸管理服务是OpenHarmony中的系统服务,主要为系统提供壁纸管理服务能力,支持系统显示、设置、切换壁纸等功能。 > **说明:** > > 本模块首批接口从API version 7开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 ## 导入模块 ```js import wallpaper from '@ohos.wallpaper'; ``` ## WallpaperResourceType10+ 定义壁纸的资源枚举类型。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 | 名称 | 值 |说明 | | -------- | -------- |-------- | | DEFAULT | 0 |默认为图片资源。 | | PICTURE | 1 |图片资源。 | | VIDEO | 2 |视频资源。 | | PACKAGE | 3 |包资源。 | ## WallpaperType7+ 定义壁纸的枚举类型。 **系统能力**: SystemCapability.MiscServices.Wallpaper | 名称 | 值 |说明 | | -------- | -------- |-------- | | WALLPAPER_SYSTEM | 0 |主屏幕壁纸标识。 | | WALLPAPER_LOCKSCREEN | 1 |锁屏壁纸标识。 | ## RgbaColor(deprecated) 定义壁纸颜色信息结构。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper | 名称 | 类型 | 可读 | 可写 | 说明 | | -------- | -------- | -------- | -------- | -------- | | red | number | 是 | 是 | 表示红色值,范围为 0 到 255。 | | green | number | 是 | 是 | 表示绿色值,范围为 0 到 255。 | | blue | number | 是 | 是 | 表示蓝色值,范围为 0 到 255。 | | alpha | number | 是 | 是 | 表示 alpha 值,范围为 0 到 255。 | ## wallpaper.setVideo10+ setVideo(source: string, wallpaperType: WallpaperType, callback: AsyncCallback<void>): void 将视频资源设置为桌面或锁屏的动态壁纸 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string | 是 | mp4文件的Uri路径。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<void> | 是 | 回调函数,设置壁纸成功,error为undefined,否则返回error信息。 | **示例:** ```js let wallpaperPath = "/data/storage/el2/base/haps/entry/files/test.mp4"; try { wallpaper.setVideo(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to setVideo because: ${JSON.stringify(error)}`); return; } console.log(`success to setVideo.`); }); } catch (error) { console.error(`failed to setVideo because: ${JSON.stringify(error)}`); } ``` ## wallpaper.setVideo10+ setVideo(source: string, wallpaperType: WallpaperType): Promise<void> 将视频资源设置为桌面或锁屏的动态壁纸 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string | 是 | mp4文件的Uri路径。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 无返回结果的Promise对象。 | **示例:** ```js let wallpaperPath = "/data/storage/el2/base/haps/entry/files/test.mp4"; try { wallpaper.setVideo(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to setVideo.`); }).catch((error) => { console.error(`failed to setVideo because: ${JSON.stringify(error)}`); }); } catch (error) { console.error(`failed to setVideo because: ${JSON.stringify(error)}`); } ``` ## wallpaper.on('wallpaperChange')10+ on(type: 'wallpaperChange', callback: (wallpaperType: WallpaperType, resourceType: WallpaperResourceType) => void): void 订阅壁纸变化通知事件。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 事件回调类型。支持的事件为'wallpaperChange',完成壁纸切换后触发该事件。 | | callback | function | 是 | 壁纸变化触发该回调方法,返回壁纸类型和壁纸资源类型。
- wallpaperType
壁纸类型。
- resourceType
壁纸资源类型。 | **示例:** ```js try { let listener = (wallpaperType, resourceType) => { console.log(`wallpaper color changed.`); }; wallpaper.on('wallpaperChange', listener); } catch (error) { console.error(`failed to on because: ${JSON.stringify(error)}`); } ``` ## wallpaper.off('wallpaperChange')10+ off(type: 'wallpaperChange', callback?: (wallpaperType: WallpaperType, resourceType: WallpaperResourceType) => void): void 取消订阅壁纸变化通知事件。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 事件回调类型。支持的事件为'wallpaperChange',完成壁纸切换后触发该事件。 | | callback | function | 否 | 表示要取消的壁纸变化回调,不填写该参数则取消订阅该type对应的所有回调。
- wallpaperType
壁纸类型。
- resourceType
壁纸资源类型。 | **示例:** ```js let listener = (wallpaperType, resourceType) => { console.log(`wallpaper color changed.`); }; try { wallpaper.on('wallpaperChange', listener); } catch (error) { console.error(`failed to on because: ${JSON.stringify(error)}`); } try { // 取消订阅listener wallpaper.off('wallpaperChange', listener); } catch (error) { console.error(`failed to off because: ${JSON.stringify(error)}`); } try { // 取消所有'wallpaperChange'类型的订阅 wallpaper.off('wallpaperChange'); } catch (error) { console.error(`failed to off because: ${JSON.stringify(error)}`); } ``` ## wallpaper.getColorsSync9+ getColorsSync(wallpaperType: WallpaperType): Array<RgbaColor> 获取指定类型壁纸的主要颜色信息。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值**: | 类型 | 说明 | | -------- | -------- | | Array<[RgbaColor](#rgbacolor)> | 返回壁纸的主要颜色信息。 | **示例**: ```js try { let colors = wallpaper.getColorsSync(wallpaper.WallpaperType.WALLPAPER_SYSTEM); console.log(`success to getColorsSync: ${JSON.stringify(colors)}`); } catch (error) { console.error(`failed to getColorsSync because: ${JSON.stringify(error)}`); } ``` ## wallpaper.getMinHeightSync9+ getMinHeightSync(): number 获取壁纸的最小高度值。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 返回壁纸的最小高度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的高度值代替。 | **示例:** ```js let minHeight = wallpaper.getMinHeightSync(); ``` ## wallpaper.getMinWidthSync9+ getMinWidthSync(): number 获取壁纸的最小宽度值。 **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **返回值:** | 类型 | 说明 | | -------- | -------- | | number | 壁纸的最小宽度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的宽度值代替。 | **示例:** ```js let minWidth = wallpaper.getMinWidthSync(); ``` ## wallpaper.restore9+ restore(wallpaperType: WallpaperType, callback: AsyncCallback<void>): void 移除指定类型的壁纸,恢复为默认显示的壁纸。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<void> | 是 | 回调函数,移除壁纸成功,error为undefined,否则返回error信息。 | **示例:** ```js wallpaper.restore(wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to restore because: ${JSON.stringify(error)}`); return; } console.log(`success to restore.`); }); ``` ## wallpaper.restore9+ restore(wallpaperType: WallpaperType): Promise<void> 移除指定类型的壁纸,恢复为默认显示的壁纸。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 无返回结果的Promise对象。 | **示例:** ```js wallpaper.restore(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to restore.`); }).catch((error) => { console.error(`failed to restore because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.setImage9+ setImage(source: string | image.PixelMap, wallpaperType: WallpaperType, callback: AsyncCallback<void>): void 将指定资源设置为指定类型的壁纸。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string \| [image.PixelMap](js-apis-image.md#pixelmap7) | 是 | JPEG或PNG文件的Uri路径,或者PNG格式文件的位图。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<void> | 是 | 回调函数,设置壁纸成功,error为undefined,否则返回error信息。 | **示例:** ```js // source类型为string let wallpaperPath = "/data/storage/el2/base/haps/entry/files/js.jpeg"; wallpaper.setImage(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to setImage because: ${JSON.stringify(error)}`); return; } console.log(`success to setImage.`); }); // source类型为image.PixelMap import image from '@ohos.multimedia.image'; let imageSource = image.createImageSource("file://" + wallpaperPath); let opts = { "desiredSize": { "height": 3648, "width": 2736 } }; imageSource.createPixelMap(opts).then((pixelMap) => { wallpaper.setImage(pixelMap, wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to setImage because: ${JSON.stringify(error)}`); return; } console.log(`success to setImage.`); }); }).catch((error) => { console.error(`failed to createPixelMap because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.setImage9+ setImage(source: string | image.PixelMap, wallpaperType: WallpaperType): Promise<void> 将指定资源设置为指定类型的壁纸。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string \| [image.PixelMap](js-apis-image.md#pixelmap7) | 是 | JPEG或PNG文件的Uri路径,或者PNG格式文件的位图。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 无返回结果的Promise对象。 | **示例:** ```js // source类型为string let wallpaperPath = "/data/storage/el2/base/haps/entry/files/js.jpeg"; wallpaper.setImage(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to setImage.`); }).catch((error) => { console.error(`failed to setImage because: ${JSON.stringify(error)}`); }); // source类型为image.PixelMap import image from '@ohos.multimedia.image'; let imageSource = image.createImageSource("file://" + wallpaperPath); let opts = { "desiredSize": { "height": 3648, "width": 2736 } }; imageSource.createPixelMap(opts).then((pixelMap) => { wallpaper.setImage(pixelMap, wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to setImage.`); }).catch((error) => { console.error(`failed to setImage because: ${JSON.stringify(error)}`); }); }).catch((error) => { console.error(`failed to createPixelMap because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getImage9+ getImage(wallpaperType: WallpaperType, callback: AsyncCallback<image.PixelMap>): void; 获取壁纸图片的像素图。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<[image.PixelMap](js-apis-image.md#pixelmap7)> | 是 | 回调函数,调用成功则返回壁纸图片的像素图对象,调用失败则返回error信息。 | **示例:** ```js wallpaper.getImage(wallpaper.WallpaperType.WALLPAPER_SYSTEM, function (error, data) { if (error) { console.error(`failed to getImage because: ${JSON.stringify(error)}`); return; } console.log(`success to getImage: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getImage9+ getImage(wallpaperType: WallpaperType): Promise<image.PixelMap> 获取壁纸图片的像素图。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<[image.PixelMap](js-apis-image.md#pixelmap7)> | 调用成功则返回壁纸图片的像素图对象,调用失败则返回error信息。 | **示例:** ```js wallpaper.getImage(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then((data) => { console.log(`success to getImage: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getImage because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.on('colorChange')(deprecated) on(type: 'colorChange', callback: (colors: Array<RgbaColor>, wallpaperType: WallpaperType) => void): void 订阅壁纸颜色变化结果上报事件。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取值为'colorChange',表示壁纸颜色变化结果上报事件。 | | callback | function | 是 | 壁纸颜色变化触发该回调方法,返回壁纸类型和壁纸的主要颜色信息。
- colors
壁纸的主要颜色信息,其类型见[RgbaColor](#rgbacolor)。
- wallpaperType
壁纸类型。 | **示例:** ```js try { let listener = (colors, wallpaperType) => { console.log(`wallpaper color changed.`); }; wallpaper.on('colorChange', listener); } catch (error) { console.error(`failed to on because: ${JSON.stringify(error)}`); } ``` ## wallpaper.off('colorChange')(deprecated) off(type: 'colorChange', callback?: (colors: Array<RgbaColor>, wallpaperType: WallpaperType) => void): void 取消订阅壁纸颜色变化结果上报事件。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | type | string | 是 | 取值为'colorChange',表示取消订阅壁纸颜色变化结果上报事件。 | | callback | function | 否 | 表示要取消的壁纸颜色变化的回调,不填写该参数则取消订阅该type对应的所有回调。
- colors
壁纸的主要颜色信息,其类型见[RgbaColor](#rgbacolor)。
- wallpaperType
壁纸类型。 | **示例:** ```js let listener = (colors, wallpaperType) => { console.log(`wallpaper color changed.`); }; try { wallpaper.on('colorChange', listener); } catch (error) { console.error(`failed to on because: ${JSON.stringify(error)}`); } try { // 取消订阅listener wallpaper.off('colorChange', listener); } catch (error) { console.error(`failed to off because: ${JSON.stringify(error)}`); } try { // 取消所有'colorChange'类型的订阅 wallpaper.off('colorChange'); } catch (error) { console.error(`failed to off because: ${JSON.stringify(error)}`); } ``` ## wallpaper.getColors(deprecated) getColors(wallpaperType: WallpaperType, callback: AsyncCallback<Array<RgbaColor>>): void 获取指定类型壁纸的主要颜色信息。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<Array<[RgbaColor](#rgbacolor)>> | 是 | 回调函数,返回壁纸的主要颜色信息。 | **示例:** ```js wallpaper.getColors(wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error, data) => { if (error) { console.error(`failed to getColors because: ${JSON.stringify(error)}`); return; } console.log(`success to getColors: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getColors(deprecated) getColors(wallpaperType: WallpaperType): Promise<Array<RgbaColor>> 获取指定类型壁纸的主要颜色信息。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<Array<[RgbaColor](#rgbacolor)>> | 返回壁纸的主要颜色信息。 | **示例:** ```js wallpaper.getColors(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then((data) => { console.log(`success to getColors: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getColors because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getId(deprecated) getId(wallpaperType: WallpaperType, callback: AsyncCallback<number>): void 获取指定类型壁纸的ID。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<number> | 是 | 回调函数,返回壁纸的ID。如果配置了指定类型的壁纸就返回一个大于等于0的数,否则返回-1。取值范围是-1到(2^31-1)。 | **示例:** ```js wallpaper.getId(wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error, data) => { if (error) { console.error(`failed to getId because: ${JSON.stringify(error)}`); return; } console.log(`success to getId: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getId(deprecated) getId(wallpaperType: WallpaperType): Promise<number> 获取指定类型壁纸的ID。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 壁纸的ID。如果配置了这种壁纸类型的壁纸就返回一个大于等于0的数,否则返回-1。取值范围是-1到(2^31-1)。 | **示例:** ```js wallpaper.getId(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then((data) => { console.log(`success to getId: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getId because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getMinHeight(deprecated) getMinHeight(callback: AsyncCallback<number>): void 获取壁纸的最小高度值。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<number> | 是 | 回调函数,返回壁纸的最小高度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的高度值代替。 | **示例:** ```js wallpaper.getMinHeight((error, data) => { if (error) { console.error(`failed to getMinHeight because: ${JSON.stringify(error)}`); return; } console.log(`success to getMinHeight: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getMinHeight(deprecated) getMinHeight(): Promise<number> 获取壁纸的最小高度值。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 返回壁纸的最小高度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的高度值代替。 | **示例:** ```js wallpaper.getMinHeight().then((data) => { console.log(`success to getMinHeight: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getMinHeight because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getMinWidth(deprecated) getMinWidth(callback: AsyncCallback<number>): void 获取壁纸的最小宽度值。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<number> | 是 | 回调函数,壁纸的最小宽度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的宽度值代替。 | **示例:** ```js wallpaper.getMinWidth((error, data) => { if (error) { console.error(`failed to getMinWidth because: ${JSON.stringify(error)}`); return; } console.log(`success to getMinWidth: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getMinWidth(deprecated) getMinWidth(): Promise<number> 获取壁纸的最小宽度值。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 壁纸的最小宽度值,单位是像素。如果返回值等于0,说明没有设置壁纸,调用者应该使用默认显示的宽度值代替。 | **示例:** ```js wallpaper.getMinWidth().then((data) => { console.log(`success to getMinWidth: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getMinWidth because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.isChangePermitted(deprecated) isChangePermitted(callback: AsyncCallback<boolean>): void 是否允许应用改变当前用户的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 回调函数,返回是否允许应用改变当前用户的壁纸。如果允许返回true,否则返回false。 | **示例:** ```js wallpaper.isChangePermitted((error, data) => { if (error) { console.error(`failed to isChangePermitted because: ${JSON.stringify(error)}`); return; } console.log(`success to isChangePermitted: ${JSON.stringify(data)}`); }); ``` ## wallpaper.isChangePermitted(deprecated) isChangePermitted(): Promise<boolean> 是否允许应用改变当前用户的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 返回是否允许应用改变当前用户的壁纸。如果允许返回true,否则返回false。 | **示例:** ```js wallpaper.isChangePermitted().then((data) => { console.log(`success to isChangePermitted: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to isChangePermitted because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.isOperationAllowed(deprecated) isOperationAllowed(callback: AsyncCallback<boolean>): void 是否允许用户设置壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | callback | AsyncCallback<boolean> | 是 | 回调函数,返回是否允许用户设置壁纸。如果允许返回true,否则返回false。 | **示例:** ```js wallpaper.isOperationAllowed((error, data) => { if (error) { console.error(`failed to isOperationAllowed because: ${JSON.stringify(error)}`); return; } console.log(`success to isOperationAllowed: ${JSON.stringify(data)}`); }); ``` ## wallpaper.isOperationAllowed(deprecated) isOperationAllowed(): Promise<boolean> 是否允许用户设置壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **系统能力**: SystemCapability.MiscServices.Wallpaper **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<boolean> | 异步回调函数,返回是否允许用户设置壁纸。如果允许返回true,否则返回false。 | **示例:** ```js wallpaper.isOperationAllowed().then((data) => { console.log(`success to isOperationAllowed: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to isOperationAllowed because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.reset(deprecated) reset(wallpaperType: WallpaperType, callback: AsyncCallback<void>): void 移除指定类型的壁纸,恢复为默认显示的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<void> | 是 | 回调函数,移除壁纸成功,error为undefined,否则返回error信息。 | **示例:** ```js wallpaper.reset(wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to reset because: ${JSON.stringify(error)}`); return; } console.log(`success to reset.`); }); ``` ## wallpaper.reset(deprecated) reset(wallpaperType: WallpaperType): Promise<void> 移除指定类型的壁纸,恢复为默认显示的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 无返回结果的Promise对象。 | **示例:** ```js wallpaper.reset(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to reset.`); }).catch((error) => { console.error(`failed to reset because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.setWallpaper(deprecated) setWallpaper(source: string | image.PixelMap, wallpaperType: WallpaperType, callback: AsyncCallback<void>): void 将指定资源设置为指定类型的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string \| [image.PixelMap](js-apis-image.md#pixelmap7) | 是 | JPEG或PNG文件的Uri路径,或者PNG格式文件的位图。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<void> | 是 | 回调函数,设置壁纸成功,error为undefined,否则返回error信息。 | **示例:** ```js // source类型为string let wallpaperPath = "/data/storage/el2/base/haps/entry/files/js.jpeg"; wallpaper.setWallpaper(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to setWallpaper because: ${JSON.stringify(error)}`); return; } console.log(`success to setWallpaper.`); }); // source类型为image.PixelMap import image from '@ohos.multimedia.image'; let imageSource = image.createImageSource("file://" + wallpaperPath); let opts = { "desiredSize": { "height": 3648, "width": 2736 } }; imageSource.createPixelMap(opts).then((pixelMap) => { wallpaper.setWallpaper(pixelMap, wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error) => { if (error) { console.error(`failed to setWallpaper because: ${JSON.stringify(error)}`); return; } console.log(`success to setWallpaper.`); }); }).catch((error) => { console.error(`failed to createPixelMap because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.setWallpaper(deprecated) setWallpaper(source: string | image.PixelMap, wallpaperType: WallpaperType): Promise<void> 将指定资源设置为指定类型的壁纸。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.SET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | source | string \| [image.PixelMap](js-apis-image.md#pixelmap7) | 是 | JPEG或PNG文件的Uri路径,或者PNG格式文件的位图。 | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<void> | 无返回结果的Promise对象。 | **示例:** ```js // source类型为string let wallpaperPath = "/data/storage/el2/base/haps/entry/files/js.jpeg"; wallpaper.setWallpaper(wallpaperPath, wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to setWallpaper.`); }).catch((error) => { console.error(`failed to setWallpaper because: ${JSON.stringify(error)}`); }); // source类型为image.PixelMap import image from '@ohos.multimedia.image'; let imageSource = image.createImageSource("file://" + wallpaperPath); let opts = { "desiredSize": { "height": 3648, "width": 2736 } }; imageSource.createPixelMap(opts).then((pixelMap) => { wallpaper.setWallpaper(pixelMap, wallpaper.WallpaperType.WALLPAPER_SYSTEM).then(() => { console.log(`success to setWallpaper.`); }).catch((error) => { console.error(`failed to setWallpaper because: ${JSON.stringify(error)}`); }); }).catch((error) => { console.error(`failed to createPixelMap because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getFile(deprecated) getFile(wallpaperType: WallpaperType, callback: AsyncCallback<number>): void 获取指定类型的壁纸文件。 > **说明:** > > 从 API version 8开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<number> | 是 | 回调函数,调用成功则返回壁纸文件描述符ID,调用失败则返回error信息。 | **示例:** ```js wallpaper.getFile(wallpaper.WallpaperType.WALLPAPER_SYSTEM, (error, data) => { if (error) { console.error(`failed to getFile because: ${JSON.stringify(error)}`); return; } console.log(`success to getFile: ${JSON.stringify(data)}`); }); ``` ## wallpaper.getFile(deprecated) getFile(wallpaperType: WallpaperType): Promise<number> 获取指定类型的壁纸文件。 > **说明:** > > 从 API version 8开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<number> | 调用成功则返回壁纸文件描述符ID,调用失败则返回error信息。 | **示例:** ```js wallpaper.getFile(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then((data) => { console.log(`success to getFile: ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getFile because: ${JSON.stringify(error)}`); }); ``` ## wallpaper.getPixelMap(deprecated) getPixelMap(wallpaperType: WallpaperType, callback: AsyncCallback<image.PixelMap>): void; 获取壁纸图片的像素图。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | | callback | AsyncCallback<image.PixelMap> | 是 | 回调函数,调用成功则返回壁纸图片的像素图对象,调用失败则返回error信息。 | **示例:** ```js wallpaper.getPixelMap(wallpaper.WallpaperType.WALLPAPER_SYSTEM, function (error, data) { if (error) { console.error(`failed to getPixelMap because: ${JSON.stringify(error)}`); return; } console.log(`success to getPixelMap : ${JSON.stringify(data)}`); }); ``` ## wallpaper.getPixelMap(deprecated) getPixelMap(wallpaperType: WallpaperType): Promise<image.PixelMap> 获取壁纸图片的像素图。 > **说明:** > > 从 API version 7开始支持,从API version 9开始废弃。 **需要权限**:ohos.permission.GET_WALLPAPER **系统能力**: SystemCapability.MiscServices.Wallpaper **系统接口**:此接口为系统接口。 **参数:** | 参数名 | 类型 | 必填 | 说明 | | -------- | -------- | -------- | -------- | | wallpaperType | [WallpaperType](#wallpapertype) | 是 | 壁纸类型。 | **返回值:** | 类型 | 说明 | | -------- | -------- | | Promise<image.PixelMap> | 调用成功则返回壁纸图片的像素图对象,调用失败则返回error信息。 | **示例:** ```js wallpaper.getPixelMap(wallpaper.WallpaperType.WALLPAPER_SYSTEM).then((data) => { console.log(`success to getPixelMap : ${JSON.stringify(data)}`); }).catch((error) => { console.error(`failed to getPixelMap because: ${JSON.stringify(error)}`); }); ```