所以我正在实现我自己的双线性缩放版本,并将结果与 FFMPEG 和 ImageMagick 进行比较。这些工具创建了我的图像的缩放版本,但似乎结果不是仅通过应用插值操作获得的,似乎结果在缩放后受到模糊以消除锯齿。这就是我的意思。
这是原始图像(6x6 yuv422p):
如您所见,只有黑白列。在使用双线性过滤器进行缩放操作后,我得到了黑色和白色之间的灰色列,这是预期的。这是我的结果:
我的图像(12x12 yuv422p):
现在问题是FFMPEG的结果。正如我接下来将展示的,FFMPEG 创建一个只有黑白列的图像,其余的只是灰色阴影,这对于双线性过滤没有意义。
FFMPEG 图像(12x12 yuv422p):
有人可以告诉我FFMPEG在这种情况下的作用吗?
// Iterate through each line
for(int lin = 0; lin < dstHeight; lin++){
// Get line in original image
int linOrig = lin / scaleHeightRatio;
float linOrigRemainder = fmod(lin, scaleHeightRatio);
float linDist = linOrigRemainder / scaleHeightRatio;
// For border pixels
int linIndexA = linOrig;
int linIndexB = linOrig + 1;
if(linIndexB >= srcHeight)
linIndexB = linIndexA;
linIndexA *= srcWidth;
linIndexB *= srcWidth;
// Iterate through each column
for(int col = 0; col < dstWidth; col++){
// Get column in original image
int colOrig = col / scaleWidthRatio;
float colOrigRemainder = fmod(col, scaleWidthRatio);
float colDist = colOrigRemainder / scaleWidthRatio;
// If same position as an original pixel
if(linOrigRemainder == 0 && colOrigRemainder == 0){
// Original pixel to the result
dstSlice[0][lin * dstWidth + col] = srcSlice[0][linOrig * srcWidth + colOrig];
dstSlice[1][lin * dstWidth + col] = srcSlice[1][linOrig * srcWidth + colOrig];
dstSlice[2][lin * dstWidth + col] = srcSlice[2][linOrig * srcWidth + colOrig];
// Continue processing following pixels
continue;
}
// For border pixels
int colIndexA = colOrig;
int colIndexB = colOrig + 1;
if(colIndexB >= srcWidth)
colIndexB = colIndexA;
// Perform interpolation
}
}