-->

Меню

четверг, 13 апреля 2017 г.

Программа "разноцветные плитки"

При нажатии на левую кнопку мыши :
При нажатии на правую кнопку мыши(с каждым нажатием цвета плиток будут менятся) :

Для создания такой программы нужно скачать файл Program2015.rar 
Разархивируем его в рабочую папку 
Запускаем 
Редактируем файл ProgramDlg.h . Открываем его : View->Solution Explorer->Program->Header Files->ProgramDlg.h
Добавляем переменные и отдел public 

Открываем View->Solution Explorer->Program->Source Files->ProgramDlg.cpp , удаляем содержимое и копируем вместо него код приведённый ниже.



// ProgramDlg.cpp : файл реализации
//

#include "stdafx.h"
#include "Program.h"
#include "ProgramDlg.h"
#include "afxdialogex.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// диалоговое окно CProgramDlg



CProgramDlg::CProgramDlg(CWnd* pParent /*=NULL*/)
: CDialog(IDD_PROGRAM_DIALOG, pParent)
{
m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CProgramDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);

fg = true;

SetWindowTextW(L"Program");
}

BEGIN_MESSAGE_MAP(CProgramDlg, CDialog)
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
END_MESSAGE_MAP()


// обработчики сообщений CProgramDlg

\
BOOL CProgramDlg::OnInitDialog()
{
CDialog::OnInitDialog();

// Задает значок для этого диалогового окна.  Среда делает это автоматически,
//  если главное окно приложения не является диалоговым
SetIcon(m_hIcon, TRUE); // Крупный значок
SetIcon(m_hIcon, FALSE); // Мелкий значок

// TODO: добавьте дополнительную инициализацию

return TRUE;  // возврат значения TRUE, если фокус не передан элементу управления
}

// При добавлении кнопки свертывания в диалоговое окно нужно воспользоваться приведенным ниже кодом,
//  чтобы нарисовать значок.  Для приложений MFC, использующих модель документов или представлений,
//  это автоматически выполняется рабочей областью.

void CProgramDlg::OnPaint()
{
if (IsIconic())
{
CPaintDC dc(this); // контекст устройства для рисования

SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);

// Выравнивание значка по центру клиентского прямоугольника
int cxIcon = GetSystemMetrics(SM_CXICON);
int cyIcon = GetSystemMetrics(SM_CYICON);
CRect rect;
GetClientRect(&rect);
int x = (rect.Width() - cxIcon + 1) / 2;
int y = (rect.Height() - cyIcon + 1) / 2;

// Нарисуйте значок
dc.DrawIcon(x, y, m_hIcon);
}
else
{
CClientDC dc(this);
GetClientRect(&rc);
int x1, y1, x2, y2;

c[0] = 0x0009FFE9;
c[1] = 0x0000DDFF;
c[2] = 0x00E16941;
c[3] = 0x00C4563D;

dx = abs(rc.right - rc.left) / 5;
dy = abs(rc.bottom - rc.top) / 5;

//HPEN hPenOxy, hOldPen;
int p = 0;
int pp = 0;
for (k = 0; k < 5; k++)
{
for (i = 0; i < 5; i++)
{
if (pp % 2 == 0)
{
p = 0;
}
else
{
p = 2;
}
hPenOxy = CreatePen(PS_SOLID, 6, c[p]);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(c[p]);
oldm = (HBRUSH)dc.SelectObject(m);

x1 = rc.left + k*dx;
y1 = rc.top + i*dy;
x2 = rc.left + (k + 1)*dx;
y2 = rc.top + (i + 1)*dy;

dc.Rectangle(x1, y1, x2, y2);
pp++;
}
}

DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);

CDialog::OnPaint();
}
}

// Система вызывает эту функцию для получения отображения курсора при перемещении
//  свернутого окна.
HCURSOR CProgramDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}





Редактируем вставленный код:

Дописываем библиотеку

Удаляем цвета, чтобы этот блог выглядел, как на приведённом ниже изображении
Добавляем функции:


Вырезаем содержимое процедуры OnPaint()
Создаем процедуру void CProgramDlg::zastavka()

Вставляем в неё :

CClientDC dc(this);
GetClientRect(&rc);

dx = abs(rc.right - rc.left) / 5;
dy = abs(rc.bottom - rc.top) / 5;

int pp = 0;
for (k = 0; k < 5; k++)
{
for (i = 0; i < 5; i++)

{

if (pp % 2 == 0)
{
cf = 0x0000DDFF;
ck = 0x00C4563D;

}
else
{
ck = 0x0000DDFF;
cf = 0x00C4563D;

}
hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);

x1 = rc.left + k*dx;
y1 = rc.top + i*dy;
x2 = rc.left + (k + 1)*dx;
y2 = rc.top + (i + 1)*dy;

dc.Rectangle(x1, y1, x2, y2);
pp++;
}
}

DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);

  Создаем процедуру void CProgramDlg::rndcolor() 
Вставляем в неё :
CClientDC dc(this);
GetClientRect(&rc);

dx = abs(rc.right - rc.left) / 8;
dy = abs(rc.bottom - rc.top) / 8;


for (k = 0; k < 8; k++)
{
for (i = 0; i < 8; i++)
{
cx = rand() % 255;
cy = rand() % 255;
cz = rand() % 255;
cf = RGB(cx, cy, cz);


cx = rand() % 255;
cy = rand() % 255;
cz = rand() % 255;
ck = RGB(cx, cy, cz);


hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);

x1 = rc.left + k*dx;
y1 = rc.top + i*dy;
x2 = rc.left + (k + 1)*dx;
y2 = rc.top + (i + 1)*dy;

dc.Rectangle(x1, y1, x2, y2);

}
}

DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);


Добавляем функции OnRButtonDown и OnLButtonDown
В функции добавляем выделенные строки:


Программа готова !
Источник сайт