如何在VC中制作旋转图片效果
我要制作一个音量旋钮,现在的思路是:利用我所截取的图片,然后根据鼠标的事件响应,然后来实现位图的旋转。但是我没有学过数字图像,望哪位大侠指教一下该怎么做,最好提供源码进行...
我要制作一个音量旋钮,现在的思路是:利用我所截取的图片,然后根据鼠标的事件响应,然后来实现位图的旋转。但是我没有学过数字图像,望哪位大侠指教一下该怎么做,最好提供源码进行参考。
展开
展开全部
// RotateDIB - Create a new bitmap with rotated image
// Returns - Returns new bitmap with rotated image
// hDIB - Device-independent bitmap to rotate
// fDegrees - Angle of rotation in degree
// clrBack - Color of pixels in the resulting bitmap that do
// not get covered by source pixels
HDIB RotateDIB(HDIB hDIB, double fDegrees, COLORREF clrBack)
{
WaitCursorBegin();
// Get source bitmap info
LPBITMAPINFO lpBmInfo = (LPBITMAPINFO)GlobalLock(hDIB);
int bpp = lpBmInfo->bmiHeader.biBitCount; // Bits per pixel
int nColors = lpBmInfo->bmiHeader.biClrUsed ? lpBmInfo->bmiHeader.biClrUsed :
1 << bpp;
int nWidth = lpBmInfo->bmiHeader.biWidth;
int nHeight = lpBmInfo->bmiHeader.biHeight;
int nRowBytes = ((((nWidth * bpp) + 31) & ~31) / 8);
// Make sure height is positive and biCompression is BI_RGB or BI_BITFIELDS
DWORD compression = lpBmInfo->bmiHeader.biCompression;
if( nHeight < 0 || (compression!=BI_RGB))
{
GlobalUnlock(hDIB);
WaitCursorEnd();
return NULL;
}
LPBYTE lpDIBBits = FindDIBBits((LPBYTE)lpBmInfo);
// Convert angle degree to radians
#define PI 3.1415926
double radians = (fDegrees/90.0)*(PI/2);
// Compute the cosine and sine only once
float cosine = (float)cos(radians);
float sine = (float)sin(radians);
// Compute dimensions of the resulting bitmap
// First get the coordinates of the 3 corners other than origin
int x1 = (int)(-nHeight * sine);
int y1 = (int)(nHeight * cosine);
int x2 = (int)(nWidth * cosine - nHeight * sine);
int y2 = (int)(nHeight * cosine + nWidth * sine);
int x3 = (int)(nWidth * cosine);
int y3 = (int)(nWidth * sine);
int minx = min(0,min(x1, min(x2,x3)));
int miny = min(0,min(y1, min(y2,y3)));
int maxx = max(x1, max(x2,x3));
int maxy = max(y1, max(y2,y3));
int w = maxx - minx;
int h = maxy - miny;
// Create a DIB to hold the result
int nResultRowBytes = ((((w * bpp) + 31) & ~31) / 8);
long len = nResultRowBytes * h;
int nHeaderSize = ((LPBYTE)lpDIBBits-(LPBYTE)lpBmInfo) ;
HANDLE hDIBResult = GlobalAlloc(GHND,len+nHeaderSize);
// Initialize the header information
LPBITMAPINFO lpBmInfoResult = (LPBITMAPINFO)GlobalLock(hDIBResult);
memcpy( (void*)lpBmInfoResult, (void*)lpBmInfo, nHeaderSize);
lpBmInfoResult->bmiHeader.biWidth = w;
lpBmInfoResult->bmiHeader.biHeight = h;
lpBmInfoResult->bmiHeader.biSizeImage = len;
LPBYTE lpDIBBitsResult = FindDIBBits((LPBYTE)lpBmInfoResult);
// Get the back color value (index)
ZeroMemory( lpDIBBitsResult, len );
DWORD dwBackColor;
switch(bpp)
{
case 1: //Monochrome
if( clrBack == RGB(255,255,255) )
memset( lpDIBBitsResult, 0xff, len );
break;
case 4:
case 8: //Search the color table
int i;
for(i = 0; i < nColors; i++ )
{
if( lpBmInfo->bmiColors[i].rgbBlue == GetBValue(clrBack)
&& lpBmInfo->bmiColors[i].rgbGreen == GetGValue(clrBack)
&& lpBmInfo->bmiColors[i].rgbRed == GetRValue(clrBack) )
{
if(bpp==4) i = i | i<<4;
memset( lpDIBBitsResult, i, len );
break;
}
}
// If not match found the color remains black
break;
case 16:
// Windows95 supports 5 bits each for all colors or 5 bits for red & blue
// and 6 bits for green - Check the color mask for RGB555 or RGB565
if( *((DWORD*)lpBmInfo->bmiColors) == 0x7c00 )
{
// Bitmap is RGB555
dwBackColor = ((GetRValue(clrBack)>>3) << 10) +
((GetRValue(clrBack)>>3) << 5) +
(GetBValue(clrBack)>>3) ;
}
else
{
// Bitmap is RGB565
dwBackColor = ((GetRValue(clrBack)>>3) << 11) +
((GetRValue(clrBack)>>2) << 5) +
(GetBValue(clrBack)>>3) ;
}
break;
case 24:
case 32:
dwBackColor = (((DWORD)GetRValue(clrBack)) << 16) |
(((DWORD)GetGValue(clrBack)) << 8) |
(((DWORD)GetBValue(clrBack)));
break;
}
// Returns - Returns new bitmap with rotated image
// hDIB - Device-independent bitmap to rotate
// fDegrees - Angle of rotation in degree
// clrBack - Color of pixels in the resulting bitmap that do
// not get covered by source pixels
HDIB RotateDIB(HDIB hDIB, double fDegrees, COLORREF clrBack)
{
WaitCursorBegin();
// Get source bitmap info
LPBITMAPINFO lpBmInfo = (LPBITMAPINFO)GlobalLock(hDIB);
int bpp = lpBmInfo->bmiHeader.biBitCount; // Bits per pixel
int nColors = lpBmInfo->bmiHeader.biClrUsed ? lpBmInfo->bmiHeader.biClrUsed :
1 << bpp;
int nWidth = lpBmInfo->bmiHeader.biWidth;
int nHeight = lpBmInfo->bmiHeader.biHeight;
int nRowBytes = ((((nWidth * bpp) + 31) & ~31) / 8);
// Make sure height is positive and biCompression is BI_RGB or BI_BITFIELDS
DWORD compression = lpBmInfo->bmiHeader.biCompression;
if( nHeight < 0 || (compression!=BI_RGB))
{
GlobalUnlock(hDIB);
WaitCursorEnd();
return NULL;
}
LPBYTE lpDIBBits = FindDIBBits((LPBYTE)lpBmInfo);
// Convert angle degree to radians
#define PI 3.1415926
double radians = (fDegrees/90.0)*(PI/2);
// Compute the cosine and sine only once
float cosine = (float)cos(radians);
float sine = (float)sin(radians);
// Compute dimensions of the resulting bitmap
// First get the coordinates of the 3 corners other than origin
int x1 = (int)(-nHeight * sine);
int y1 = (int)(nHeight * cosine);
int x2 = (int)(nWidth * cosine - nHeight * sine);
int y2 = (int)(nHeight * cosine + nWidth * sine);
int x3 = (int)(nWidth * cosine);
int y3 = (int)(nWidth * sine);
int minx = min(0,min(x1, min(x2,x3)));
int miny = min(0,min(y1, min(y2,y3)));
int maxx = max(x1, max(x2,x3));
int maxy = max(y1, max(y2,y3));
int w = maxx - minx;
int h = maxy - miny;
// Create a DIB to hold the result
int nResultRowBytes = ((((w * bpp) + 31) & ~31) / 8);
long len = nResultRowBytes * h;
int nHeaderSize = ((LPBYTE)lpDIBBits-(LPBYTE)lpBmInfo) ;
HANDLE hDIBResult = GlobalAlloc(GHND,len+nHeaderSize);
// Initialize the header information
LPBITMAPINFO lpBmInfoResult = (LPBITMAPINFO)GlobalLock(hDIBResult);
memcpy( (void*)lpBmInfoResult, (void*)lpBmInfo, nHeaderSize);
lpBmInfoResult->bmiHeader.biWidth = w;
lpBmInfoResult->bmiHeader.biHeight = h;
lpBmInfoResult->bmiHeader.biSizeImage = len;
LPBYTE lpDIBBitsResult = FindDIBBits((LPBYTE)lpBmInfoResult);
// Get the back color value (index)
ZeroMemory( lpDIBBitsResult, len );
DWORD dwBackColor;
switch(bpp)
{
case 1: //Monochrome
if( clrBack == RGB(255,255,255) )
memset( lpDIBBitsResult, 0xff, len );
break;
case 4:
case 8: //Search the color table
int i;
for(i = 0; i < nColors; i++ )
{
if( lpBmInfo->bmiColors[i].rgbBlue == GetBValue(clrBack)
&& lpBmInfo->bmiColors[i].rgbGreen == GetGValue(clrBack)
&& lpBmInfo->bmiColors[i].rgbRed == GetRValue(clrBack) )
{
if(bpp==4) i = i | i<<4;
memset( lpDIBBitsResult, i, len );
break;
}
}
// If not match found the color remains black
break;
case 16:
// Windows95 supports 5 bits each for all colors or 5 bits for red & blue
// and 6 bits for green - Check the color mask for RGB555 or RGB565
if( *((DWORD*)lpBmInfo->bmiColors) == 0x7c00 )
{
// Bitmap is RGB555
dwBackColor = ((GetRValue(clrBack)>>3) << 10) +
((GetRValue(clrBack)>>3) << 5) +
(GetBValue(clrBack)>>3) ;
}
else
{
// Bitmap is RGB565
dwBackColor = ((GetRValue(clrBack)>>3) << 11) +
((GetRValue(clrBack)>>2) << 5) +
(GetBValue(clrBack)>>3) ;
}
break;
case 24:
case 32:
dwBackColor = (((DWORD)GetRValue(clrBack)) << 16) |
(((DWORD)GetGValue(clrBack)) << 8) |
(((DWORD)GetBValue(clrBack)));
break;
}
博思aippt
2024-07-20 广告
2024-07-20 广告
**AI一键生成PPT免费版**为满足广大用户的需求,我们博思云创科技特推出AI一键生成PPT免费版。用户只需简单输入需求,AI技术便能智能分析并快速生成高质量PPT。此版本功能强大且易于操作,无需专业设计技能,即可轻松打造出令人满意的演示...
点击进入详情页
本回答由博思aippt提供
展开全部
正式的位图旋转,需要用算法处理,推荐关键字:双线形内插法,
网上应该有描述和代码。
不过你这个用途,估计旋钮本身是否是圆形的?
可以考虑用更简单的方式做,例如背景是一个圆形按钮,上面用一个
小圆表示音量刻度,鼠标拖动时重画小圆的位置即可。
两种方法后者做起来快,前者你要调查调查了。
网上应该有描述和代码。
不过你这个用途,估计旋钮本身是否是圆形的?
可以考虑用更简单的方式做,例如背景是一个圆形按钮,上面用一个
小圆表示音量刻度,鼠标拖动时重画小圆的位置即可。
两种方法后者做起来快,前者你要调查调查了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
算那个,还不如做一系列各角度的位图,跟据角度调用好了。。。。。。
反正音量调节旋钮不会很大,看不出来的。。。。。。。
反正音量调节旋钮不会很大,看不出来的。。。。。。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询