0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

鸿蒙开发接口媒体:【@ohos.multimedia.image (图片处理)】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-05-31 16:58 次阅读

图片处理

说明: 本模块首批接口从API version 6开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 开发前请熟悉鸿蒙开发指导文档 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

导入模块

import image from '@ohos.multimedia.image';

image.createPixelMap8+

createPixelMap(colors: ArrayBuffer, options: InitializationOptions): Promise

通过属性创建PixelMap,通过Promise返回结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数

名称类型必填说明
colorsArrayBufferBGRA_8888格式的颜色数组。
options[InitializationOptions]创建像素的属性,包括透明度,尺寸,缩略值,像素格式和是否可编辑。

返回值:

类型说明
Promise<[PixelMap]>返回Pixelmap。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts)
    .then((pixelmap) = > {
        })

image.createPixelMap8+

createPixelMap(colors: ArrayBuffer, options: InitializationOptions, callback: AsyncCallback): void

通过属性创建PixelMap,通过回调函数返回结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

名称类型必填说明
colorsArrayBufferBGRA_8888格式的颜色数组。
options[InitializationOptions]属性。
callbackAsyncCallback<[PixelMap]>通过回调返回PixelMap对象。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts, (pixelmap) = > {
        })

PixelMap7+

图像像素类,用于读取或写入图像数据以及获取图像信息。在调用PixelMap的方法前,需要先通过createPixelMap创建一个PixelMap实例。

属性

系统能力: SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
isEditable7+boolean设定是否图像像素可被编辑。

readPixelsToBuffer7+

readPixelsToBuffer(dst: ArrayBuffer): Promise

读取图像像素数据,结果写入ArrayBuffer里,使用Promise形式返回。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
dstArrayBuffer缓冲区,函数执行结束后获取的图像像素数据写入到该内存区域内。

返回值:

类型说明
PromisePromise实例,用于获取结果,失败时返回错误信息

示例:

const readBuffer = new ArrayBuffer(400);
pixelmap.readPixelsToBuffer(readBuffer).then(() = > {
    console.log('Succeeded in reading image pixel data.');  //符合条件则进入 
}).catch(error = > {
    console.log('Failed to read image pixel data.');  //不符合条件则进入
})

readPixelsToBuffer7+

readPixelsToBuffer(dst: ArrayBuffer, callback: AsyncCallback): void

读取图像像素数据,结果写入ArrayBuffer里,使用callback形式返回。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
dstArrayBuffer缓冲区,函数执行结束后获取的图像像素数据写入到该内存区域内。
callbackAsyncCallback获取回调,失败时返回错误信息。

示例:

const readBuffer = new ArrayBuffer(400);
pixelmap.readPixelsToBuffer(readBuffer, (err, res) = > {
    if(err) {
        console.log('Failed to read image pixel data.');  //不符合条件则进入
    } else {
        console.log('Succeeded in reading image pixel data.');  //符合条件则进入
    }
})

readPixels7+

readPixels(area: PositionArea): Promise

读取区域内的图片数据,使用Promise形式返回读取结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
area[PositionArea]区域大小,根据区域读取。

返回值:

类型说明
PromisePromise实例,用于获取读取结果,失败时返回错误信息。

示例:

const area = new ArrayBuffer(400);
pixelmap.readPixels(area).then(() = > {
    console.log('Succeeded in reading the image data in the area.'); //符合条件则进入
}).catch(error = > {
    console.log('Failed to read the image data in the area.'); //不符合条件则进入
})

readPixels7+

readPixels(area: PositionArea, callback: AsyncCallback): void

读取区域内的图片数据,使用callback形式返回读取结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
area[PositionArea]区域大小,根据区域读取。
callbackAsyncCallback获取回调,失败时返回错误信息。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts, (err, pixelmap) = > {
    if(pixelmap == undefined){
        console.info('createPixelMap failed.');
    } else {
        const area = { pixels: new ArrayBuffer(8),
            offset: 0,
            stride: 8,
            region: { size: { height: 1, width: 2 }, x: 0, y: 0 }};
        pixelmap.readPixels(area, () = > {
            console.info('readPixels success');
        })
    }
})

writePixels7+

writePixels(area: PositionArea): Promise

将PixelMap写入指定区域内,使用Promise形式返回写入结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
area[PositionArea]区域,根据区域写入。

返回值:

类型说明
PromisePromise实例,用于获取写入结果,失败时返回错误信息。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts)
    .then( pixelmap = > {
        if (pixelmap == undefined) {
            console.info('createPixelMap failed.');
        }
        const area = { pixels: new ArrayBuffer(8),
            offset: 0,
            stride: 8,
            region: { size: { height: 1, width: 2 }, x: 0, y: 0 }
        }
        let bufferArr = new Uint8Array(area.pixels);
        for (var i = 0; i  bufferArr.length; i++) {
            bufferArr[i] = i + 1;
        }

        pixelmap.writePixels(area).then(() = > {
            const readArea = { pixels: new ArrayBuffer(8),
                offset: 0,
                stride: 8,
                // region.size.width + x  opts.width, region.size.height + y  opts.height
                region: { size: { height: 1, width: 2 }, x: 0, y: 0 }
            }        
        })
    }).catch(error = > {
        console.log('error: ' + error);
    })

writePixels7+

writePixels(area: PositionArea, callback: AsyncCallback): void

将PixelMap写入指定区域内,使用callback形式返回写入结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
area[PositionArea]区域,根据区域写入。
callback:AsyncCallback获取回调,失败时返回错误信息。

示例:

const area = new ArrayBuffer(400);
pixelmap.writePixels(area, (error) = > {
    if (error!=undefined) {
		console.info('Failed to write pixelmap into the specified area.');
	} else {
	    const readArea = {
            pixels: new ArrayBuffer(20),
            offset: 0,
            stride: 8,
            region: { size: { height: 1, width: 2 }, x: 0, y: 0 },
        }
	}
})

writeBufferToPixels7+

writeBufferToPixels(src: ArrayBuffer): Promise

读取缓冲区中的图片数据,结果写入PixelMap中,使用Promise形式返回。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
srcArrayBuffer图像像素数据。

返回值:

类型说明
PromisePromise实例,用于获取结果,失败时返回错误信息。

示例:

const color = new ArrayBuffer(96);
const pixelMap = new ArrayBuffer(400);
let bufferArr = new Unit8Array(color);
pixelMap.writeBufferToPixels(color).then(() = > {
    console.log("Succeeded in writing data from a buffer to a PixelMap.");
}).catch((err) = > {
    console.error("Failed to write data from a buffer to a PixelMap.");
})

writeBufferToPixels7+

writeBufferToPixels(src: ArrayBuffer, callback: AsyncCallback): void

读取缓冲区中的图片数据,结果写入PixelMap中,使用callback形式返回。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
srcArrayBuffer图像像素数据。
callbackAsyncCallback获取回调,失败时返回错误信息。

示例:

const color = new ArrayBuffer(96);
const pixelMap = new ArrayBuffer(400);
let bufferArr = new Unit8Array(color);
pixelMap.writeBufferToPixels(color, function(err) {
    if (err) {
        console.error("Failed to write data from a buffer to a PixelMap.");
        return;
    } else {
		console.log("Succeeded in writing data from a buffer to a PixelMap.");
	}
});

getImageInfo7+

getImageInfo(): Promise

获取图像像素信息,使用Promise形式返回获取的图像像素信息。

系统能力: SystemCapability.Multimedia.Image.Core

返回值:

类型说明
Promise<[ImageInfo]>Promise实例,用于异步获取图像像素信息,失败时返回错误信息。

示例:

const pixelMap = new ArrayBuffer(400);
pixelMap.getImageInfo().then(function(info) {
    console.log("Succeeded in obtaining the image pixel map information.");
}).catch((err) = > {
    console.error("Failed to obtain the image pixel map information.");
});

getImageInfo7+

getImageInfo(callback: AsyncCallback): void

获取图像像素信息,使用callback形式返回获取的图像像素信息。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

参数名类型必填说明
callbackAsyncCallback<[ImageInfo]>获取图像像素信息回调,异步返回图像像素信息,失败时返回错误信息。

示例:

pixelmap.getImageInfo((imageInfo) = > { 
    console.log("Succeeded in obtaining the image pixel map information..");
})

getBytesNumberPerRow7+

getBytesNumberPerRow(): number

获取图像像素每行字节数。

系统能力: SystemCapability.Multimedia.Image.Core

返回值:

类型说明
number图像像素的行字节数。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts, (err,pixelmap) = > {
    let rowCount = pixelmap.getBytesNumberPerRow();
})

getPixelBytesNumber7+

getPixelBytesNumber(): number

获取图像像素的总字节数。

系统能力: SystemCapability.Multimedia.Image.Core

返回值:

类型说明
number图像像素的总字节数。

示例:

let pixelBytesNumber = pixelmap.getPixelBytesNumber();

release7+

release():Promise

释放PixelMap对象,使用Promise形式返回释放结果。

系统能力: SystemCapability.Multimedia.Image.Core

返回值:

类型说明
Promise异步返回释放结果。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts, (pixelmap) = > {
    pixelmap.release().then(() = > {
	    console.log('Succeeded in releasing pixelmap object.');
    }).catch(error = > {
	    console.log('Failed to release pixelmap object.');
    })
})

release7+

release(callback: AsyncCallback): void

释放PixelMap对象,使用callback形式返回释放结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

名称类型必填说明
callbackAsyncCallback异步返回释放结果。

示例:

const color = new ArrayBuffer(96);
let bufferArr = new Unit8Array(color);
let opts = { editable: true, pixelFormat: 3, size: { height: 4, width: 6 } }
image.createPixelMap(color, opts, (pixelmap) = > {
    pixelmap.release().then(() = > {
	    console.log('Succeeded in releasing pixelmap object.');
    }).catch(error = > {
	    console.log('Failed to release pixelmap object.');
    })
})

image.createImageSource

createImageSource(uri: string): ImageSource

通过传入的uri创建图片源实例。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
uristring图片路径,当前仅支持应用沙箱路径。

返回值:

类型说明
[ImageSource]返回ImageSource类实例,失败时返回undefined。

示例:

let path = this.context.getApplicationContext().fileDirs + "test.jpg";
const imageSourceApi = image.createImageSource(path);

image.createImageSource7+

createImageSource(fd: number): ImageSource

通过传入文件描述符来创建图片源实例。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
fdnumber文件描述符fd。

返回值:

类型说明
[ImageSource]返回ImageSource类实例,失败时返回undefined。

示例:

const imageSourceApi = image.createImageSource(0)

image.createImageSource9+

createImageSource(buf: ArrayBuffer): ImageSource

通过缓冲区创建图片源实例。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
bufArrayBuffer图像缓冲区数组。

示例:

const buf = new ArrayBuffer(96);
image.createImageSource(buf, () = > { })

image.CreateIncrementalSource9+

function CreateIncrementalSource(buf: ArrayBuffer, options?: SourceOptions): ImageSource

通过缓冲区以增量的方式创建图片源实例。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
bufArrayBuffer增量数据。
options[SourceOptions]图片属性,包括图片序号与默认属性值。

返回值:

类型说明
[ImageSource]返回图片源,失败时返回undefined。

示例:

const buf = new ArrayBuffer(96);
const imageSourceApi = image.createIncrementalSource(buf);

ImageSource

图片源类,用于获取图片相关信息。在调用ImageSource的方法前,需要先通过createImageSource构建一个ImageSource实例。

属性

系统能力: SystemCapability.Multimedia.Image.ImageSource

名称类型可读可写说明
supportedFormatsArray支持的图片格式,包括:png,jpeg,wbmp,bmp,gif,webp,heif等。

getImageInfo

getImageInfo(index: number, callback: AsyncCallback): void

获取指定序号的图片信息,使用callback形式返回图片信息。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
indexnumber创建图片源时的序号。
callbackAsyncCallback<[ImageInfo]>获取图片信息回调,异步返回图片信息对象。

示例:

imageSourceApi.getImageInfo(0,(error, imageInfo) = > { 
    if(error) {
        console.log('getImageInfo failed.');
    } else {
        console.log('getImageInfo succeeded.');
    }
})

getImageInfo

getImageInfo(callback: AsyncCallback): void

获取图片信息,使用callback形式返回图片信息。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
callbackAsyncCallback<[ImageInfo]>获取图片信息回调,异步返回图片信息对象。

示例:

imageSourceApi.getImageInfo(imageInfo = > { 
    console.log('Succeeded in obtaining the image information.');
})

getImageInfo

getImageInfo(index?: number): Promise

获取图片信息,使用Promise形式返回图片信息。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
indexnumber创建图片源时的序号,不选择时默认为0。

返回值:

类型说明
Promise<[ImageInfo]>返回获取到的图片信息。

示例:

imageSourceApi.getImageInfo(0)
    .then(imageInfo = > {
		console.log('Succeeded in obtaining the image information.');
	}).catch(error = > {
		console.log('Failed to obtain the image information.');
	})

getImageProperty7+

getImageProperty(key:string, options?: GetImagePropertyOptions): Promise

获取图片中给定索引处图像的指定属性键的值,用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
keystring图片属性名。
options[GetImagePropertyOptions]图片属性,包括图片序号与默认属性值。

返回值:

类型说明
PromisePromise实例,用于异步获取图片属性值,如获取失败则返回属性默认值。

示例:

imageSourceApi.getImageProperty("BitsPerSample")
    .then(data = > {
		console.log('Succeeded in getting the value of the specified attribute key of the image.');
	})

getImageProperty7+

getImageProperty(key:string, callback: AsyncCallback): void

获取图片中给定索引处图像的指定属性键的值,用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
keystring图片属性名。
callbackAsyncCallback获取图片属性回调,返回图片属性值,如获取失败则返回属性默认值。

示例:

imageSourceApi.getImageProperty("BitsPerSample",(error,data) = > { 
    if(error) {
        console.log('Failed to get the value of the specified attribute key of the image.');
    } else {
        console.log('Succeeded in getting the value of the specified attribute key of the image.');
    }
})

getImageProperty7+

getImageProperty(key:string, options: GetImagePropertyOptions, callback: AsyncCallback): void

获取图片指定属性键的值,callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
keystring图片属性名。
options[GetImagePropertyOptions]图片属性,包括图片序号与默认属性值。
callbackAsyncCallback获取图片属性回调,返回图片属性值,如获取失败则返回属性默认值。

示例:

const property = new ArrayBuffer(400);
imageSourceApi.getImageProperty("BitsPerSample",property,(error,data) = > { 
    if(error) {
        console.log('Failed to get the value of the specified attribute key of the image.');
    } else {
        console.log('Succeeded in getting the value of the specified attribute key of the image.');
    }
})

modifyImageProperty9+

modifyImageProperty(key: string, value: string): Promise

通过指定的键修改图片属性的值,使用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
keystring图片属性名。
valuestring属性值。

返回值:

类型说明
PromisePromise实例,异步返回结果。

示例:

imageSourceApi.modifyImageProperty("ImageWidth", "abc")
            .then(() = > {
                const w = imageSourceApi.getImageProperty("ImageWidth")
                console.info('w', w);
            })

modifyImageProperty9+

modifyImageProperty(key: string, value: string, callback: AsyncCallback): void

通过指定的键修改图片属性的值,callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

参数名类型必填说明
keystring图片属性名。
valuestring属性值。
callbackAsyncCallback修改属性值,callback返回结果。

示例:

imageSourceApi.modifyImageProperty("ImageWidth", "abc",() = > {})

updateData9+

updateData(buf: ArrayBuffer, isFinished: boolean, value: number, length: number): Promise

更新增量数据,使用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
bufArrayBuffer增量数据。
isFinishedboolean是否更新完。
valuenumber偏移量。
lengthnumber数组长。

返回值:

类型说明
PromisePromise实例,异步返回结果。

示例:

const array = new ArrayBuffer(100);
imageSourceIncrementalSApi.updateData(array, false, 0, 10).then(data = > {
            console.info('Succeeded in updating data.');
        })

updateData9+

updateData(buf: ArrayBuffer, isFinished: boolean, value: number, length: number, callback: AsyncCallback): void

更新增量数据,callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
bufArrayBuffer增量数据。
isFinishedboolean是否更新完。
valuenumber偏移量。
lengthnumber数组长。
callbackAsyncCallback回调表示成功或失败。

示例:

const array = new ArrayBuffer(100);
imageSourceIncrementalSApi.updateData(array, false, 0, 10,(error,data )= > {
            if(data !== undefined){
                console.info('Succeeded in updating data.');     
            }
		})

createPixelMap7+

createPixelMap(options?: DecodingOptions): Promise

通过图片解码参数创建PixelMap对象。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
options[DecodingOptions]解码参数。

返回值:

类型说明
Promise<[PixelMap]>异步返回Promise对象。

示例:

imageSourceApi.createPixelMap().then(pixelmap = > {
    console.log('Succeeded in creating pixelmap object through image decoding parameters.');
}).catch(error = > {
    console.log('Failed to create pixelmap object through image decoding parameters.');
})

createPixelMap7+

createPixelMap(callback: AsyncCallback): void

通过默认参数创建PixelMap对象,使用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
callbackAsyncCallback<[PixelMap]>通过回调返回PixelMap对象。

示例:

imageSourceApi.createPixelMap(pixelmap = > { 
    console.log('Succeeded in creating pixelmap object.');
}).catch(error = > {
    console.log('Failed to create pixelmap object.');
})

createPixelMap7+

createPixelMap(options: DecodingOptions, callback: AsyncCallback): void

通过图片解码参数创建PixelMap对象。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
options[DecodingOptions]解码参数。
callbackAsyncCallback<[PixelMap]>通过回调返回PixelMap对象。

示例:

const decodingOptions = new ArrayBuffer(400);
imageSourceApi.createPixelMap(decodingOptions, pixelmap = > { 
    console.log('Succeeded in creating pixelmap object.');
})

release

release(callback: AsyncCallback): void

释放图片源实例,使用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

参数:

名称类型必填说明
callbackAsyncCallback资源释放回调,失败时返回错误信息。

示例:

imageSourceApi.release(() = > { 
    console.log('release succeeded.');
})

release

release(): Promise

释放图片源实例,使用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageSource

返回值:

类型说明
PromisePromise实例,异步返回结果。

示例:

imageSourceApi.release().then(()= >{
    console.log('Succeeded in releasing the image source instance.');
}).catch(error = > {
    console.log('Failed to release the image source instance.');
})

image.createImagePacker

createImagePacker(): ImagePacker

创建ImagePacker实例。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

返回值:

类型说明
[ImagePacker]返回ImagePacker实例。

示例:

const imagePackerApi = image.createImagePacker();

ImagePacker

图片打包器类,用于图片压缩和打包。在调用ImagePacker的方法前,需要先通过createImagePacker构建一个ImagePacker实例。

属性

系统能力: SystemCapability.Multimedia.Image.ImagePacker

名称类型可读可写说明
supportedFormatsArray图片打包支持的格式,jpeg。

packing

packing(source: ImageSource, option: PackingOption, callback: AsyncCallback): void

图片压缩或重新打包,使用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

参数:

参数名类型必填说明
source[ImageSource]打包的图片源。
option[PackingOption]设置打包参数。
callbackAsyncCallback获取图片打包回调,返回打包后数据。

示例:

let packOpts = { format:"image/jpeg", quality:98 };
const imageSourceApi = new ArrayBuffer(400);
imagePackerApi.packing(imageSourceApi, packOpts, data = > {})

packing

packing(source: ImageSource, option: PackingOption): Promise

图片压缩或重新打包,使用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

参数:

参数名类型必填说明
source[ImageSource]打包的图片源。
option[PackingOption]设置打包参数。

返回值:

类型说明
PromisePromise实例,用于异步获取压缩或打包后的数据。

示例:

let packOpts = { format:"image/jpeg", quality:98 }
const imageSourceApi = new ArrayBuffer(400);
imagePackerApi.packing(imageSourceApi, packOpts)
    .then( data = > {
        console.log('packing succeeded.');
	}).catch(error = > {
	    console.log('packing failed.');
	})

packing8+

packing(source: PixelMap, option: PackingOption, callback: AsyncCallback): void

图片压缩或重新打包,使用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

参数:

参数名类型必填说明
source[PixelMap]打包的PixelMap资源。
option[PackingOption]设置打包参数。
callbackAsyncCallback获取图片打包回调,返回打包后数据。

示例:

let packOpts = { format:"image/jpeg", quality:98 }
const pixelMapApi = new ArrayBuffer(400);
imagePackerApi.packing(pixelMapApi, packOpts, data = > { 
    console.log('Succeeded in packing the image.');
}).catch(error = > {
	console.log('Failed to pack the image.');
})

packing8+

packing(source: PixelMap, option: PackingOption): Promise

图片压缩或重新打包,使用Promise形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

参数:

参数名类型必填说明
source[PixelMap]打包的PixelMap源。
option[PackingOption]设置打包参数。

返回值:

类型说明
PromisePromise实例,用于异步获取压缩或打包后的数据。

示例:

let packOpts = { format:"image/jpeg", quality:98 }
const pixelMapApi = new ArrayBuffer(400);
imagePackerApi.packing(pixelMapApi, packOpts)
    .then( data = > {
	    console.log('Succeeded in packing the image.');
	}).catch(error = > {
	    console.log('Failed to pack the image..');
	})

release

release(callback: AsyncCallback): void

释放图片打包实例,使用callback形式返回结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

参数:

参数名类型必填说明
callbackAsyncCallback释放回调,失败时返回错误信息。

示例:

imagePackerApi.release(()= >{ 
    console.log('Succeeded in releasing image packaging.');
})

release

release(): Promise

释放图片打包实例,使用Promise形式返回释放结果。

系统能力: SystemCapability.Multimedia.Image.ImagePacker

返回值:

类型说明
PromisePromise实例,用于异步获取释放结果,失败时返回错误信息。

示例:

imagePackerApi.release().then(()= >{
    console.log('Succeeded in releasing image packaging.');
}).catch((error)= >{ 
    console.log('Failed to release image packaging.'); 
})

image.createImageReceiver9+

createImageReceiver(width: number, height: number, format: number, capacity: number): ImageReceiver

通过宽、高、图片格式、容量创建ImageReceiver实例。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
widthnumber图像的默认宽度。
heightnumber图像的默认高度。
formatnumber图像格式。
capacitynumber同时访问的最大图像数。

返回值:

类型说明
[ImageReceiver]如果操作成功,则返回ImageReceiver实例。

示例:

var receiver = image.createImageReceiver(8192, 8, 4, 8);

ImageReceiver9+

图像接收类,用于获取组件surface id,接收最新的图片和读取下一张图片,以及释放ImageReceiver实例。

在调用以下方法前需要先创建ImageReceiver实例。

属性

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.ImageReceiver

名称类型可读可写说明
size9+[Size]图片大小。
capacity9+number同时访问的图像数。
format9+[ImageFormat]图像格式。

getReceivingSurfaceId9+

getReceivingSurfaceId(callback: AsyncCallback): void

用于获取一个surface id供Camera或其他组件使用。使用callback返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
callbackAsyncCallback回调函数,返回surface id。

示例:

receiver.getReceivingSurfaceId((err, id) = > { 
    if(err) {
        console.log('getReceivingSurfaceId failed.');
    } else {
        console.log('getReceivingSurfaceId succeeded.');
    }
});

getReceivingSurfaceId9+

getReceivingSurfaceId(): Promise

用于获取一个surface id供Camera或其他组件使用。使用promise返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

返回值:

类型说明
Promise异步返回surface id。

示例:

receiver.getReceivingSurfaceId().then( id = > { 
    console.log('getReceivingSurfaceId succeeded.');
}).catch(error = > {
    console.log('getReceivingSurfaceId failed.');
})

readLatestImage9+

readLatestImage(callback: AsyncCallback): void

从ImageReceiver读取最新的图片,并使用callback返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
callbackAsyncCallback<[Image]>回调函数,返回最新图像。

示例:

receiver.readLatestImage((err, img) = > { 
    if(err) {
        console.log('readLatestImage failed.');
    } else {
        console.log('readLatestImage succeeded.');
    }
});

readLatestImage9+

readLatestImage(): Promise

从ImageReceiver读取最新的图片,并使用promise返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

返回值:

类型说明
Promise<[Image]>异步返回最新图片。

示例:

receiver.readLatestImage().then(img = > {
    console.log('readLatestImage succeeded.');
}).catch(error = > {
    console.log('readLatestImage failed.');
})

readNextImage9+

readNextImage(callback: AsyncCallback): void

从ImageReceiver读取下一张图片,并使用callback返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
callbackAsyncCallback<[Image]>回调函数,返回下一张图片。

示例:

receiver.readNextImage((err, img) = > { 
    if(err) {
        console.log('readNextImage failed.');
    } else {
        console.log('readNextImage succeeded.');
    }
});

readNextImage9+

readNextImage(): Promise

从ImageReceiver读取下一张图片,并使用promise返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

返回值:

类型说明
Promise<[Image]>异步返回下一张图片。

示例:

receiver.readNextImage().then(img = > {
    console.log('readNextImage succeeded.');
}).catch(error = > {
    console.log('readNextImage failed.');
})

on('imageArrival')9+

on(type: 'imageArrival', callback: AsyncCallback): void

接收图片时注册回调。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
typestring注册事件的类型,固定为'imageArrival',接收图片时触发。
callbackAsyncCallback注册的事件回调。

示例:

receiver.on('imageArrival', () = > {})

release9+

release(callback: AsyncCallback): void

释放ImageReceiver实例并使用回调返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

参数:

名称类型必填说明
callbackAsyncCallback回调函数,返回操作结果。

示例:

receiver.release(() = > {})

release9+

release(): Promise

释放ImageReceiver实例并使用promise返回结果。

系统能力: SystemCapability.Multimedia.Image.ImageReceiver

返回值:

类型说明
Promise异步返回操作结果。

示例:

receiver.release().then(() = > {
    console.log('release succeeded.');
}).catch(error = > {
    console.log('release failed.');
})

Image9+

提供基本的图像操作,包括获取图像信息、读写图像数据。调用[readNextImage]和[readLatestImage]接口时会返回image。

属性

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
clipRect9+[Region]要裁剪的图像区域。
size9+[Size]图像大小。
format9+number图像格式,参考[PixelMapFormat]。

getComponent9+

getComponent(componentType: ComponentType, callback: AsyncCallback): void

根据图像的组件类型从图像中获取组件缓存并使用callback返回结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

名称类型必填说明
componentType[ComponentType]图像的组件类型。
callbackAsyncCallback<[Component]>用于返回组件缓冲区。

示例:

img.getComponent(4, (err, component) = > {
    if(err) {
        console.log('getComponent failed.');
    } else {
        console.log('getComponent succeeded.');
    }
})

getComponent9+

getComponent(componentType: ComponentType): Promise

根据图像的组件类型从图像中获取组件缓存并使用Promise方式返回结果。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

名称类型必填说明
componentType[ComponentType]图像的组件类型。

返回值:

类型说明
Promise<[Component]>用于返回组件缓冲区的promise实例。

示例:

img.getComponent(4).then(component = > { })

release9+

release(callback: AsyncCallback): void

释放当前图像并使用callback返回结果。

在接收另一个图像前必须先释放对应资源。

系统能力: SystemCapability.Multimedia.Image.Core

参数:

名称类型必填说明
callbackAsyncCallback返回操作结果。

示例:

img.release(() = >{ 
    console.log('release succeeded.');
}).catch(error = > {
    console.log('release failed.');
})

release9+

release(): Promise

释放当前图像并使用Promise方式返回结果。

在接收另一个图像前必须先释放对应资源。

系统能力: SystemCapability.Multimedia.Image.Core

返回值:

类型说明
Promisepromise返回操作结果。

示例:

img.release().then(() = >{
    console.log('release succeeded.');
}).catch(error = > {
    console.log('release failed.');
})

PositionArea7+

表示图片指定区域内的数据。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
pixelsArrayBuffer像素。
offsetnumber偏移量。
stridenumber像素间距,stride >= region.size.width*4。
region[Region]区域,按照区域读写。写入的区域宽度加X坐标不能大于原图的宽度,写入的区域高度加Y坐标不能大于原图的高度

ImageInfo

表示图片信息。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
size[Size]图片大小。

Size

表示图片尺寸。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
heightnumber输出图片的高。
widthnumber输出图片的宽。

PixelMapFormat7+

枚举,图片像素格式。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称默认值描述
UNKNOWN0未知格式。
RGBA_88883格式为RGBA_8888。
RGB_5652格式为RGB_565。

AlphaType9+

枚举,图像的透明度类型。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称默认值描述
UNKNOWN0未知透明度。
OPAQUE1没有alpha或图片全透明。
PREMUL2RGB前乘alpha。
UNPREMUL3RGB不前乘alpha。

ScaleMode9+

枚举,图像的缩放模式。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称默认值描述
CENTER_CROP1缩放图像以填充目标图像区域并居中裁剪区域外的效果。
FIT_TARGET_SIZE2图像适合目标尺寸的效果。

InitializationOptions8+

PixelMap的初始化选项。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Code

名称类型可读可写说明
alphaType9+[AlphaType]透明度。
editableboolean是否可编辑。
pixelFormat[PixelMapFormat]像素格式。
scaleMode9+[ScaleMode]缩略值。
size[Size]创建图片大小。

DecodingOptions7+

图像解码设置选项。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.ImageSource

名称类型可读可写说明
sampleSizenumber缩略图采样大小。
rotatenumber旋转角度。
editableboolean是否可编辑。
desiredSize[Size]期望输出大小。
desiredRegion[Region]解码区域。
desiredPixelFormat[PixelMapFormat]解码的像素格式。
indexnumber解码图片序号。

Region7+

表示区域信息。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
size[Size]区域大小。
xnumber区域横坐标。
ynumber区域纵坐标。

PackingOption

表示图片打包选项。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.ImagePacker

名称类型可读可写说明
formatstring目标格式。
qualitynumberJPEG编码中设定输出图片质量的参数,取值范围为1-100。

GetImagePropertyOptions7+

表示查询图片属性的索引。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.ImageSource

名称类型可读可写说明
indexnumber图片序号。
defaultValuestring默认属性值。

PropertyKey7+

枚举,Exif(Exchangeable image file format)图片信息。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称默认值说明
BITS_PER_SAMPLE"BitsPerSample"每个像素比特数。
ORIENTATION"Orientation"图片方向。
IMAGE_LENGTH"ImageLength"图片长度。
IMAGE_WIDTH"ImageWidth"图片宽度。
GPS_LATITUDE"GPSLatitude"图片纬度。
GPS_LONGITUDE"GPSLongitude"图片经度。
GPS_LATITUDE_REF"GPSLatitudeRef"纬度引用,例如N或S。
GPS_LONGITUDE_REF"GPSLongitudeRef"经度引用,例如W或E。

ImageFormat9+

枚举,图片格式。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称默认值描述
YCBCR_422_SP1000YCBCR422半平面格式。
JPEG2000JPEG编码格式。

ComponentType9+

枚举,图像的组件类型。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.ImageReceiver

名称默认值描述
YUV_Y1亮度信息。
YUV_U2色度信息。
YUV_V3色度信息。
JPEG4Jpeg 类型。

Component9+

描述图像颜色分量。

系统能力: 以下各项对应的系统能力均为SystemCapability.Multimedia.Image.Core

名称类型可读可写说明
componentType[ComponentType]组件类型。
rowStridenumber行距。
pixelStridenumber像素间距。
byteBufferArrayBuffer组件缓冲区。

ResponseCode

编译错误返回的响应码。

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

名称HarmonyOSOpenHarmony鸿蒙文档籽料:mau123789是v直接拿说明
ERR_MEDIA_INVALID_VALUE-1无效大小。
SUCCESS0操作成功。
ERROR62980096操作失败。
ERR_IPC62980097ipc错误。
ERR_SHAMEM_NOT_EXIST62980098共享内存错误。
ERR_SHAMEM_DATA_ABNORMAL62980099共享内存错误。
ERR_IMAGE_DECODE_ABNORMAL62980100图像解码错误。
ERR_IMAGE_DATA_ABNORMAL62980101图像输入数据错误。
ERR_IMAGE_MALLOC_ABNORMAL62980102图像malloc错误。
ERR_IMAGE_DATA_UNSUPPORT62980103不支持图像类型。
ERR_IMAGE_INIT_ABNORMAL62980104图像初始化错误。
ERR_IMAGE_GET_DATA_ABNORMAL62980105图像获取数据错误。
ERR_IMAGE_TOO_LARGE62980106图像数据太大。
ERR_IMAGE_TRANSFORM62980107图像转换错误。
ERR_IMAGE_COLOR_CONVERT62980108图像颜色转换错误。
ERR_IMAGE_CROP62980109裁剪错误。
ERR_IMAGE_SOURCE_DATA62980110图像源数据错误。
ERR_IMAGE_SOURCE_DATA_INCOMPLETE62980111图像源数据不完整。
ERR_IMAGE_MISMATCHED_FORMAT62980112图像格式不匹配。
ERR_IMAGE_UNKNOWN_FORMAT62980113图像未知格式。
ERR_IMAGE_SOURCE_UNRESOLVED62980114图像源未解析。
ERR_IMAGE_INVALID_PARAMETER62980115图像无效参数。
ERR_IMAGE_DECODE_FAILED62980116解码失败。
ERR_IMAGE_PLUGIN_REGISTER_FAILED62980117注册插件失败。
ERR_IMAGE_PLUGIN_CREATE_FAILED62980118创建插件失败。
ERR_IMAGE_ENCODE_FAILED62980119图像编码失败。
ERR_IMAGE_ADD_PIXEL_MAP_FAILED62980120图像添加像素映射失败。
ERR_IMAGE_HW_DECODE_UNSUPPORT62980121不支持图像硬件解码。
ERR_IMAGE_DECODE_HEAD_ABNORMAL62980122图像解码头错误。
ERR_IMAGE_DECODE_EXIF_UNSUPPORT62980123图像解码exif取消支持。
ERR_IMAGE_PROPERTY_NOT_EXIST62980124图像属性不存在;错误代码被媒体占用,图像从150开始。
ERR_IMAGE_READ_PIXELMAP_FAILED62980246读取像素地图失败。
ERR_IMAGE_WRITE_PIXELMAP_FAILED62980247写入像素映射失败。
ERR_IMAGE_PIXELMAP_NOT_ALLOW_MODIFY62980248pixelmap不允许修改。
ERR_IMAGE_CONFIG_FAILED62980259配置错误。
审核编辑 黄宇
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    8422

    浏览量

    150666
  • 图片处理
    +关注

    关注

    0

    文章

    16

    浏览量

    6841
  • 鸿蒙
    +关注

    关注

    57

    文章

    2301

    浏览量

    42666
收藏 人收藏

    评论

    相关推荐

    鸿蒙开发接口媒体:【@ohos.multimedia.audio (音频管理)】

    音频管理提供管理音频的一些基础能力,包括对音频音量、音频设备的管理,以及对音频数据的采集和渲染等。
    的头像 发表于 05-31 09:53 2146次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b><b class='flag-5'>接口</b><b class='flag-5'>媒体</b>:【@<b class='flag-5'>ohos.multimedia</b>.audio (音频管理)】

    鸿蒙开发接口媒体:【@ohos.multimedia.camera (相机管理)】

    本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
    的头像 发表于 05-31 09:42 1372次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b><b class='flag-5'>接口</b><b class='flag-5'>媒体</b>:【@<b class='flag-5'>ohos.multimedia</b>.camera (相机管理)】

    鸿蒙媒体开发【简述】

    ):提供音量管理、音频路由管理、混音管理接口与服务。 视频(media):提供音视频解压播放、压缩录制接口与服务。 图片image):提供图片
    发表于 02-28 17:53

    基于ArkTS语言的OpenHarmony APP应用开发图片处理

    、@ohos.multimedia.image 本模块提供图片处理效果,包括通过属性创建PixelMap、读取图像像素数据、读取区域内的图片数据等。 详细请参考:官方文档 2.6、@
    发表于 09-19 14:23

    HarmonyOS API Version 7版本特性说明

    收藏、回收站等功能。@ohos.multimedia.image提供图片的解码、打包、位图处理等功能。以上就是本期全部内容,“JS API参考文档”。
    发表于 11-30 15:19

    HarmonyOS API Version 7版本特性说明

    、回收站等功能。@ohos.multimedia.image提供图片的解码、打包、位图处理等功能。以上就是本期全部内容。
    发表于 12-01 10:35

    鸿蒙开源第三方组件资料合集

    1、鸿蒙开源第三方组件——日志工具组件Timber_ohosTimber_ohos是一个带有小型可扩展API的日志工具组件,它可以给开发者提供统一的API接口,来记录不同类型的日志,帮
    发表于 03-23 09:53

    ImageKnife组件,让小白也能轻松搞定图片开发

    \\\'@ohos.multimedia.image\\\'导入ArkUI开发框架的图片能力,并调用createImageSource()方法获取,实现代码如下: import image
    发表于 04-28 11:05

    基于安卓平台的图片裁切组件已实现鸿蒙化迁移和重构

      基于安卓平台的图片裁切组件 crop_image_layout,实现了鸿蒙化迁移和重构,代码已经开源,目前已经获得了很多人的 Star 和 Fork ,欢迎各位下载使用并提出宝贵意见
    的头像 发表于 11-10 09:22 1512次阅读
    基于安卓平台的<b class='flag-5'>图片</b>裁切组件已实现<b class='flag-5'>鸿蒙</b>化迁移和重构

    鸿蒙HarmonyOS引用图片的方法

    前言 Image通过调用接口来创建,接口调用形式如下:   Image(src: string | Resource | media.PixelMap)   该
    的头像 发表于 02-01 14:35 903次阅读
    <b class='flag-5'>鸿蒙</b>HarmonyOS引用<b class='flag-5'>图片</b>的方法

    鸿蒙开发图形图像——@ohos.effectKit (图像效果)

        import effectKit from '@ohos.effectKit';     effectKit.createEffect createEffect(source: image.Pix
    的头像 发表于 02-22 16:08 334次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>图形图像——@<b class='flag-5'>ohos</b>.effectKit (图像效果)

    鸿蒙开发UI界面——@ohos.mediaquery (媒体查询)

    导入模块   import mediaquery from '@ohos.mediaquery'   mediaquery.matchMediaSync matchMediaSync
    的头像 发表于 02-22 16:46 704次阅读

    鸿蒙开发实战:【文件管理】

    .fileio] 、[@ohos.file.fs]、[@ohos.app.ability.contextConstant] 等接口,实现了增添文件、删除文件、查找指定类型文件文件、复制并移动文件、切换加密分区和预览
    的头像 发表于 03-20 21:57 580次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b>实战:【文件管理】

    鸿蒙开发接口媒体:【@ohos.multimedia.media (媒体服务)】

    媒体子系统为开发者提供一套简单且易于理解的接口,使得开发者能够方便接入系统并使用系统的媒体资源。
    的头像 发表于 06-06 11:03 685次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b><b class='flag-5'>接口</b><b class='flag-5'>媒体</b>:【@<b class='flag-5'>ohos.multimedia</b>.media (<b class='flag-5'>媒体</b>服务)】

    鸿蒙开发接口媒体:【@ohos.multimedia.medialibrary (媒体库管理)】

    获取媒体库的实例,用于访问和修改用户等个人媒体数据信息(如音频、视频、图片、文档等)。
    的头像 发表于 06-03 11:52 1013次阅读
    <b class='flag-5'>鸿蒙</b><b class='flag-5'>开发</b><b class='flag-5'>接口</b><b class='flag-5'>媒体</b>:【@<b class='flag-5'>ohos.multimedia</b>.medialibrary (<b class='flag-5'>媒体</b>库管理)】