说明:Buffer中存放的是要进行旋转的原始图像,m_pImage中存放转换后的图像数据。
nHeight是图像的高度,我测试图像是1024;nWidth是图像的宽度,我测试图像是1400
nImageSize = nHeight*nWidth;
unsigned char *m_pImage= new unsigned char[nIamgeSize];
ZeroMemory(m_pImage,nIamgeSize);
//--------------------------------------------------//
LONG x,y;
for(y=0;y<nHeight;y++)//逆时针90度翻转
{
for(x=0;x<nWidth;x++)
{
m_pImage[y+(nWidth-x-1)*nHeight]=Buffer[x+y*nWidth];
}
}
int Temp = nWidth;
nWidth = nHeight;
nHeight = Temp;
//--------------------------------------------------//
LONG x,y;
for(y=0;y<nHeight;y++)//上下镜像
{
for(x=0;x<nWidth;x++)
{
m_pImage[x+(nHeight-y-1)*nWidth]=Buffer[x+y*nWidth];
}
}
//---------------------------------------------------//
LONG x,y;
for(y=0;y<nHeight;y++)//逆时针旋转180度
{
for(x=0;x<nWidth;x++)
{
m_pImage[(nHeight-y)*nWidth-1-x]=Buffer[x+y*nWidth];
}
}
//---------------------------------------------------//
LONG x,y;
for(y=0;y<nHeight;y++)//顺时针旋转90度
{
for(x=0;x<nWidth;x++)
{
m_pImage[nHeight*(x+1)-1-y]=Buffer[x+y*nWidth];
}
}
int Temp = nWidth;
nWidth = nHeight;
nHeight = Temp;
//--------------------------------------------------//
LONG x,y;
for(y=0;y<nHeight;y++)//水平镜像
{
for(x=0;x<nWidth;x++)
{
m_pImage[nWidth*(y+1)-1-x]=Buffer[x+y*nWidth];
}
}