ffmpeg之sws_scale函数的用法-具体应用

本文介绍如何使用FFmpeg的swscale库进行图像格式转换和缩放操作。通过实例展示了如何初始化SwsContext,选择合适的缩放方法,并利用sws_scale()函数实现具体的图像处理任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 如果想將某個PixelFormat轉換至另一個PixelFormat,例如,將YUV420P轉換成YUYV422,或是想變換圖的大小,都可以使用swscale達成。

其中,PixelFormat 的列表在 libavutil/pixfmt.h 內定義。

swscale的用法可以參考libswscale/swscale-example.c的sample code。主要function有三個
sws_getContext() 
sws_scale() 
sws_freeContext() 

其中,我們可以把sws_getContext() 看成初始化函數,把sws_freeContext()看成結束函數。這兩個函數分別在起始及結束各執行一次即可。

真正主要的函數,是sws_scale()。

sws_getContext() 的宣告如下

SwsContext *sws_getContext(int srcW, int srcH, enum PixelFormat srcFormat, int dstW, int dstH, enum PixelFormat dstFormat, int flags, SwsFilter *srcFilter, SwsFilter *dstFilter, const double *param)

總共有十個參數,其中,較重要的是前七個; 
前三個參數分別代表 source 的寬、高及PixelFormat; 
四到六個參數分別代表 destination 的寬、高及PixelFormat; 
第七個參數則代表要使用哪種scale的方法;此參數可用的方法可在 libswscale/swscale.h 內找到。

最後三個參數,如無使用,可以都填上NULL。

sws_getContext會回傳一個 SwsContext struct,我們可以把這個 struct 看成是個 handler,之後的sws_scale和sws_freeContext皆會用到。

以下是一個sws_getContext的簡單例子:

struct SwsContext *img_convert_ctx; 
img_convert_ctx = sws_getContext(in_width, in_height, PIX_FMT_YUV420P, 
out_width, out_height, PIX_FMT_YUV420P, SWS_POINT, 
NULL, NULL, NULL);

一開始,我們宣告img_convert_ctx 為指向 SwsContext 的一個 pointer;接著,我們將 sws_getContext 的回傳值賦予給img_convert_ctx。

注意sws_getContext的參數;in_width及in_height分別代表 source 的寬及高,out_width及out_height分別代表轉換後的寬與高;input 和 output 的 PixelFormat 皆為 YUV420P;使用SWS_POINT的scale方法。

初始化完成後,接著就要進行主要的 scale 動作;我們透過 sws_scale() 完成。sws_scale() 的宣告如下

int sws_scale(SwsContext *c, uint8_t* src[], int srcStride[], int srcSliceY, int srcSliceH, uint8_t* dst[], int dstStride[])

總共有七個參數; 
第一個參數即是由 sws_getContext 所取得的參數。 
第二個 src 及第六個 dst 分別指向input 和 output 的 buffer。 
第三個 srcStride 及第七個 dstStride 分別指向 input 及 output 的 stride;如果不知道什麼是 stride,姑且可以先把它看成是每一列的 byte 數。
第四個 srcSliceY,就註解的意思來看,是指第一列要處理的位置;這裡我是從頭處理,所以直接填0。想知道更詳細說明的人,可以參考 swscale.h 的註解。
第五個srcSliceH指的是 source slice 的高度。

舉一個例子如下

sws_scale(img_convert_ctx, inbuf, inlinesize, 0, in_height, outbuf, outlinesize);

這裡應該比較好懂,可以參考上面的參數說明。

最後,全部處理完後,需呼叫sws_freeContext() 結束。用法很簡單,把sws_getContext 取得的參數填入即可。如下

sws_freeContext(img_convert_ctx);

最後再整理一次,要使用swscale,只要使用 sws_getContext() 進行初始化、sws_scale() 進行主要轉換、sws_freeContext() 結束,即可完成全部動作。


ffmpeg是一个开源的多媒体处理工具,而sws_scaleffmpeg中用于图像缩放和像素格式转换的函数sws_scale函数位于libswscale库中,主要用于将图像从一个尺寸缩放到另一个尺寸,同时可以将图像的像素格式进行转换。 下面是sws_scale函数的基本用法和参数详解: ```c #include <libswscale/swscale.h> struct SwsContext *sws_getContext(int srcW, int srcH, enum AVPixelFormat srcFormat, int dstW, int dstH, enum AVPixelFormat dstFormat, int flags, SwsFilter *srcFilter, SwsFilter *dstFilter, const double *param); int sws_scale(struct SwsContext *c, const uint8_t *const srcSlice[], const int srcStride[], int srcSliceY, int srcSliceH, uint8_t *const dst[], const int dstStride[]); ``` ### 参数详解 1. **sws_getContext**: - `srcW`:源图像的宽度。 - `srcH`:源图像的高度。 - `srcFormat`:源图像的像素格式。 - `dstW`:目标图像的宽度。 - `dstH`:目标图像的高度。 - `dstFormat`:目标图像的像素格式。 - `flags`:缩放算法标志,例如SWS_FAST_BILINEAR、SWS_BILINEAR、SWS_POINT等。 - `srcFilter`:源图像滤波器(通常为NULL)。 - `dstFilter`:目标图像滤波器(通常为NULL)。 - `param`:缩放参数(通常为NULL)。 2. **sws_scale**: - `c`:由sws_getContext返回的SwsContext上下文。 - `srcSlice[]`:源图像数据数组。 - `srcStride[]`:源图像的步长数组。 - `srcSliceY`:源图像的起始切片行。 - `srcSliceH`:源图像的切片高度。 - `dst[]`:目标图像数据数组。 - `dstStride[]`:目标图像的步长数组。 ### 使用步骤 1. 调用sws_getContext函数创建一个SwsContext上下文。 2. 调用sws_scale函数进行图像缩放和像素格式转换。 3. 处理完成后,调用sws_freeContext函数释放SwsContext上下文。 ### 示例代码 ```c #include <libswscale/swscale.h> #include <libavutil/imgutils.h> // 创建SwsContext struct SwsContext *sws_ctx = sws_getContext(src_width, src_height, src_format, dst_width, dst_height, dst_format, SWS_BILINEAR, NULL, NULL, NULL); // 分配目标图像缓冲区 uint8_t *dst_data[4]; int dst_linesize[4]; av_image_alloc(dst_data, dst_linesize, dst_width, dst_height, dst_format, 1); // 进行图像缩放和像素格式转换 sws_scale(sws_ctx, src_data, src_linesize, 0, src_height, dst_data, dst_linesize); // 处理完成后释放资源 av_freep(&dst_data[0]); sws_freeContext(sws_ctx); ``` 通过以上步骤,你可以使用sws_scale函数进行图像缩放和像素格式转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值