Z形重排

    DCT后,需要按Z形扫描规则,由阵列(两维数组)转为一维数组,供压缩用。

Z形扫描示意图:

图中可以看出,由左上侧开始,到右下侧结束,Z形由此而来。

实现思路:由两维数组(阵列)转一维数组,通过两维循环,取出输入阵列数据,传递至由Z数组指向的,一维数组的地址位置。

源程序如下:

const unsigned char Zigzag[8][8] = 
{
   0,  1,  5,  6, 14, 15, 27, 28,
   2,  4,  7, 13, 16, 26, 29, 42,
   3,  8, 12, 17, 25, 30, 41, 43,
   9, 11, 18, 24, 31, 40, 44, 53,
  10, 19, 23, 32, 39, 45, 52, 54,
  20, 22, 33, 38, 46, 51, 55, 60,
  21, 34, 37, 47, 50, 56, 59, 61,
  35, 36, 48, 49, 57, 58, 62, 63
};

void __fastcall ZigScan_8x8(int czOutPut[], int czInPut[][8])//Z变换
{
   for(int i = 0; i < 8; i++)
   for(int j = 0; j < 8; j++)
      {
         czOutPut[Zigzag[i][j]] = czInPut[i][j];
      }
}

猜你喜欢

转载自www.cnblogs.com/hbg200/p/8995992.html
z