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]; } }