代码如下// TestWhyBlack.cpp : 定义应用程序的入口点。
//#include "stdafx.h"
#include "TestWhyBlack.h"
#include <math.h>
#define MAX_LOADSTRING 100
#define PI 3.1415926
#define TWOPI 2*PI
// 全局变量:
HINSTANCE hInst; // 当前实例
TCHAR szTitle[MAX_LOADSTRING]; // 标题栏文本
TCHAR szWindowClass[MAX_LOADSTRING]; // 主窗口类名
HDC memDc;
HBITMAP hBitmap;
HBRUSH hGBrush = CreateSolidBrush(0x0000ff00);
HPEN hBPen = CreatePen(PS_SOLID,1,0x00000000);// 此代码模块中包含的函数的前向声明:
ATOM MyRegisterClass(HINSTANCE hInstance);
BOOL InitInstance(HINSTANCE, int);
LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
INT_PTR CALLBACK About(HWND, UINT, WPARAM, LPARAM);
VOID CALLBACK TimerProgressPro(HWND hwnd,UINT message,UINT iTimerID,DWORD dwTime);
int APIENTRY _tWinMain(HINSTANCE hInstance,
                     HINSTANCE hPrevInstance,
                     LPTSTR    lpCmdLine,
                     int       nCmdShow)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);  // TODO: 在此放置代码。
MSG msg;
HACCEL hAccelTable; // 初始化全局字符串
LoadString(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);
LoadString(hInstance, IDC_TESTWHYBLACK, szWindowClass, MAX_LOADSTRING);
MyRegisterClass(hInstance); // 执行应用程序初始化:
if (!InitInstance (hInstance, nCmdShow))
{
return FALSE;
} hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_TESTWHYBLACK)); // 主消息循环:
while (GetMessage(&msg, NULL, 0, 0))
{
if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
} return (int) msg.wParam;
}//
//  函数: MyRegisterClass()
//
//  目的: 注册窗口类。
//
//  注释:
//
//    仅当希望
//    此代码与添加到 Windows 95 中的“RegisterClassEx”
//    函数之前的 Win32 系统兼容时,才需要此函数及其用法。调用此函数十分重要,
//    这样应用程序就可以获得关联的
//    “格式正确的”小图标。
//
ATOM MyRegisterClass(HINSTANCE hInstance)
{
WNDCLASSEX wcex; wcex.cbSize = sizeof(WNDCLASSEX); wcex.style = CS_HREDRAW | CS_VREDRAW;
wcex.lpfnWndProc = WndProc;
wcex.cbClsExtra = 0;
wcex.cbWndExtra = 0;
wcex.hInstance = hInstance;
wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_TESTWHYBLACK));
wcex.hCursor = LoadCursor(NULL, IDC_ARROW);
wcex.hbrBackground = CreateSolidBrush(0x00000000);
wcex.lpszMenuName = MAKEINTRESOURCE(IDC_TESTWHYBLACK);
wcex.lpszClassName = szWindowClass;
wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL)); return RegisterClassEx(&wcex);
}//
//   函数: InitInstance(HINSTANCE, int)
//
//   目的: 保存实例句柄并创建主窗口
//
//   注释:
//
//        在此函数中,我们在全局变量中保存实例句柄并
//        创建和显示主程序窗口。
//
BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
{
   HWND hWnd;   hInst = hInstance; // 将实例句柄存储在全局变量中   hWnd = CreateWindow(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,
      CW_USEDEFAULT, 0, 400, 400, NULL, NULL, hInstance, NULL);   if (!hWnd)
   {
      return FALSE;
   }   ShowWindow(hWnd, nCmdShow);
   UpdateWindow(hWnd);   return TRUE;
}//
//  函数: WndProc(HWND, UINT, WPARAM, LPARAM)
//
//  目的: 处理主窗口的消息。
//
//  WM_COMMAND - 处理应用程序菜单
//  WM_PAINT - 绘制主窗口
//  WM_DESTROY - 发送退出消息并返回
//
//
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
int wmId, wmEvent;
PAINTSTRUCT ps;
HDC hdc; static RECT rect;
static int cxClient,cyClient;
switch (message)
{
case WM_CREATE:
/*hdc = GetDC(hWnd);
memDc = CreateCompatibleDC(hdc);
CreateCompatibleBitmap(hdc,cxClient,cyClient);
*/
SetTimer(hWnd,1,150,TimerProgressPro);
break;
case WM_SIZE:
cxClient = LOWORD(lParam);
cyClient = HIWORD(lParam);
break;
case WM_COMMAND:
wmId    = LOWORD(wParam);
wmEvent = HIWORD(wParam);
// 分析菜单选择:
switch (wmId)
{
case IDM_ABOUT:
DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
break;
case IDM_EXIT:
DestroyWindow(hWnd);
break;
default:
return DefWindowProc(hWnd, message, wParam, lParam);
}
break;
case WM_PAINT:
hdc = BeginPaint(hWnd, &ps);
// TODO: 在此添加任意绘图代码...
BitBlt(hdc,0,0,600,600,memDc,0,0,SRCCOPY);
EndPaint(hWnd, &ps);
break;
case WM_DESTROY:
KillTimer(hWnd,1);
PostQuitMessage(0);
break;
default:
return DefWindowProc(hWnd, message, wParam, lParam);
}
return 0;
}// “关于”框的消息处理程序。
INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
UNREFERENCED_PARAMETER(lParam);
switch (message)
{
case WM_INITDIALOG:
return (INT_PTR)TRUE; case WM_COMMAND:
if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
{
EndDialog(hDlg, LOWORD(wParam));
return (INT_PTR)TRUE;
}
break;
}
return (INT_PTR)FALSE;
}
void RotatePoint(POINT *pt1,int iNum,int iAngle)
{
int i;
POINT ptTemp;
for(i=0;i<iNum;i++)
{
ptTemp.x=(int)(pt1[i].x * cos(TWOPI*iAngle/360) + pt1[i].y*sin(TWOPI*iAngle/360));
ptTemp.y=(int)(pt1[i].y*cos(TWOPI*iAngle/360) - pt1[i].x*sin(TWOPI*iAngle/360));
pt1[i]=ptTemp;
}
}
VOID CALLBACK TimerProgressPro(HWND hwnd,UINT message,UINT iTimerID,DWORD dwTime)
{
HDC hdc = GetDC(hwnd);
memDc = CreateCompatibleDC(hdc);
hBitmap = CreateCompatibleBitmap(hdc,600,600);
SelectObject(memDc,hBitmap);
int i = 0;
static int iAngle = 0;
static int Radiu = 150;
iAngle > 360?iAngle %= 360:iAngle ++;
POINT IconPt[5] = {
0,Radiu,
(int)(sin(36*PI/180)*Radiu),-(int)(cos(36*PI/180)*Radiu),
-(int)(cos(18*PI/180)*Radiu),(int)(sin(18*PI/180)*Radiu),
(int)(cos(18*PI/180)*Radiu),(int)(sin(18*PI/180)*Radiu),
-(int)(sin(36*PI/180)*Radiu), - (int)(cos(36*PI/180)*Radiu)
};
RotatePoint(IconPt,5,iAngle);
for (i = 0;i < 5;i++)
{
IconPt[i].x += Radiu + 24;
IconPt[i].y = -IconPt[i].y + Radiu + 24;
}
SelectObject(memDc,hBPen);
SelectObject(memDc,hGBrush);
SetPolyFillMode(memDc,ALTERNATE);
Polygon(memDc,IconPt,5);
ReleaseDC(hwnd,hdc);
InvalidateRect(hwnd,NULL,TRUE);
}

解决方案 »

  1.   

    做如下修改试试:    case WM_CREATE:
            hdc = GetDC(hWnd);
            memDc = CreateCompatibleDC(hdc);
       //   CreateCompatibleBitmap(hdc,cxClient,cyClient);
            
            SetTimer(hWnd,1,150,TimerProgressPro);.........VOID CALLBACK TimerProgressPro(HWND hwnd,UINT message,UINT iTimerID,DWORD dwTime)
    {
     // HDC hdc = GetDC(hwnd);
     // memDc = CreateCompatibleDC(hdc);
        hBitmap = CreateCompatibleBitmap(hdc,600,600);
        DeleteObject(SelectObject(memDc,hBitmap));
    .........
      

  2.   

    HDC hdc = GetDC(hwnd);
        memDc = CreateCompatibleDC(hdc);
        hBitmap = CreateCompatibleBitmap(hdc,600,600);
        SelectObject(memDc,hBitmap);这些创建的资源,必须有对应的删除,GDI资源是有限资源,你可以用任务管理器查看你的进程是不是GDI资源不停的增加,到最后,申请不到了,当然变黑了!
      

  3.   

    SelectObject(memDc,hBPen);
    SelectObject(memDc,hGBrush);
        SetPolyFillMode(memDc,ALTERNATE);
        Polygon(memDc,IconPt,5);
        ReleaseDC(hwnd,hdc);
    这段代码这样改:
        HBITMAP oldbmp = SelectObject(memDc,hBitmap);
    ...............     HPEN oldpen = SelectObject(memDc,hBPen);
        HBRUSH oldbrush = SelectObject(memDc,hGBrush);
        int oldmode = SetPolyFillMode(memDc,ALTERNATE);
        Polygon(memDc,IconPt,5);
        SelectObject(memDc,oldpen );
        SelectObject(memDc,oldbrush );
        SelectObject(memDc,oldbmp );
        SetPolyFillMode(memDc,oldmode );
        DeleteObject(hBitmap);
        DeleteDC(memDc);
        ReleaseDC(hwnd,hdc);
      

  4.   

    GDI果然这样就不增加了,太好了,我再试试
      

  5.   

    使用:
    sprintf(prompt,"%d\n",IconPt[i].x);
    OutputDebugString(prompt);
    调调看