下载
中文
注册

功能及约束说明

功能说明

PNGD(PNG Decoder)功能:实现PNG格式图片的硬件解码。

PNGD在解码图片时,支持按源图片格式解码。源图片格式解码是指解码前后图片的编码格式保持一致,例如解码前输入图片格式为RGB,解码后输出图片格式为RGB888。

如果不清楚PNG源图片格式、但想使用源格式解码时,有以下两种方式:

  • 在调用PNGD解码接口时,直接将输出图片格式配置为HI_PIXEL_FORMAT_UNKNOWN,输出格式默认按源图片格式输出。此种方式,由于不知道输出图片格式,因此需要用户申请尽量大的内存,防止内存不够,无法存放输出图片。

    输入图片格式

    操作

    实际输出图片格式

    RGB/GRAY

    将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN

    RGB888

    RGBA/AGRAY

    将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN

    RGBA8888

  • 先调用acl.himpi.png_get_image_info接口根据传入的PNG源图片,获取按源图解码时的输出图片的宽、高、宽stride、高stride、解码输出内存大小、图片格式等信息后,再调用PNGD解码接口,使用通过acl.himpi.png_get_image_info接口获取的图片格式来设置输出图片格式。

图片分辨率约束

  • 输入图片分辨率:

    最大分辨率4096*4096,最小分辨率32*32。

  • 输出图片分辨率

    PNGD只对图片解码,不会改变图片分辨率,因此输出与输入的图片分辨率保持一致。

图片格式、宽高对齐、内存约束

实现图片解码功能时,需调用acl.himpi.dvpp_malloc接口申请Device上的输入、输出内存,调用acl.himpi.dvpp_free接口释放输入、输出内存,这部分内存的生命周期由用户自行管理。

  • 输入内存的大小就是指实际的输入图片所占用的大小。
  • 输出内存的大小参见下表中的计算公式。

    若不确定输出格式、将输出图片格式设置为HI_PIXEL_FORMAT_UNKNOWN时:

    • 宽stride:

      如果输入图片是RGB或GRAY格式,则宽stride为输出图片的宽先向上128对齐后再乘以3的值;如果输入图片是RGBA或AGRAY格式,则宽stride为输出图片的宽先向上128对齐后再乘以4的值。

    • 高stride:为输出图片的高向上16对齐后的值。
    • 输出图片格式的定义请参见hi_pixel_format,宽stride、高stride等概念请参见基本概念
    • 如果用户将宽stride、高stride设置为0,传入对应的接口,PNGD内部在处理时,会默认根据输出图片格式将宽stride向上128对齐、高stride向上16对齐。
表1 图片格式、宽高对齐、内存大小约束

输入图片格式

输出图片格式

输出图片宽、高对齐要求

输出图片宽stride、高stride、内存大小要求

RGB

RGB888

无对齐要求

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

GRAY

RGB888

RGBA

RGB888

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

RGBA8888 8bit

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以4的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

AGRAY

RGB888

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以3的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

RGBA8888 8bit

宽stride为宽向上1对齐、或16对齐、或128对齐后再乘以4的值。

高stride的取值范围:[输出图片的高, 输出图片的高向上128对齐]。

内存大小(单位Byte)= 宽stride * 高stride

其它约束

PNGD只支持对完整PNG图片进行解码,不支持将一张PNG图片分割成多个数据包后,由PNGD解码。