С++ Радужные квадраты

Всем привет! Сегодня мы сделаем легкую программу в С++ , при запуске которой,у нас высветятся квадратики и они будут разрисованы по спектру(или радуге).    Приступим...

Для начала нам нужно зайти в сам MicosoftVisualStudio.Далее выбираем MFC Application(с любым названием).У нас появилась основная конструкция программы.
Открываем   Вид-Обозреватель решений. Для нашей программы нам нужны 2 файла,это:
ProgramDlg.h   i  ProgramDlg.cpp  >>>

Открываем ProgramDlg.h и опускаемся в самый низ системного кода. Отодвигаем  };   вниз и в верху пишем:


// Реализация
protected:
HICON m_hIcon;

// Созданные функции схемы сообщений
virtual BOOL OnInitDialog();
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()

private:

HPEN hPenOxy, hOldPen;
HBRUSH m, oldm, brush;
HPEN pen;

COLORREF cf, c[25];

CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[12];

CString ms, t, z;
int x, y, x1, y1, x2, y2;
int Matrix[50][50];
int RH, RW, k, i, j, cx, cy, dx, dy;
bool fg;





Это только часть кода,полный код:

class CProgramDlg : public CDialog
{
// Создание
public:
CProgramDlg(CWnd* pParent = NULL); // стандартный конструктор

// Данные диалогового окна
#ifdef AFX_DESIGN_TIME
enum { IDD = IDD_PROGRAM_DIALOG };
#endif

protected:
virtual void DoDataExchange(CDataExchange* pDX); // поддержка DDX/DDV


// Реализация
protected:
HICON m_hIcon;

// Созданные функции схемы сообщений
virtual BOOL OnInitDialog();
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()

private:

HPEN hPenOxy, hOldPen;
HBRUSH m, oldm, brush;
HPEN pen;

COLORREF cf, c[25];

CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[12];

CString ms, t, z;
int x, y, x1, y1, x2, y2;
int Matrix[50][50];
int RH, RW, k, i, j, cx, cy, dx, dy;
bool fg;


};





Теперь открываем файл ProgramDlg.cpp.

Находим строку: CDialog::DoDataExchange(pDX);   и под ней пишем :

        c[0] = 0x000000FF;
c[1] = 0x0000A5FF;
c[2] = 0x0000DDFF;
c[3] = 0x00008000;                          
c[4] = 0x00FFFF00;                          
c[5] = 0x008B0000;                          
c[6] = 0x00E94EB3;


fg = true;

SetWindowTextW(L"Program");
}


Теперь опускаемся вниз и находим строку :   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);

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

for (k = 0; k < 7; k++)
{

// w.left = rc.left + k*dx;
//w.right = rc.left+(k+1)*dx;
w.top = rc.top+k*dy;
w.bottom = rc.top+(k+1)*dy;
w.left = rc.left;
w.right = rc.right;
//w.top = rc.top;
//w.bottom = rc.bottom;
dc.FillSolidRect(&w, c[k]);

}
hPenOxy = CreatePen(PS_SOLID, 8, RGB(255,255,255));//создаем кисть цветом "crOxy"
hOldPen = (HPEN)SelectObject(dc, hPenOxy);

for (k = 0; k < 7; k++)
{
dc.MoveTo(rc.left + k*dx, rc.top);
dc.LineTo(rc.left + k*dx, rc.bottom);

dc.MoveTo(rc.left, rc.top + k*dy);
dc.LineTo(rc.right, rc.top + k*dy);

}
CDialog::OnPaint();
}
}





Код готов! Нажимаем Локальный отладчик Windows. Получается вот такая программа :



Теперь, ОБРАТИТЕ ВНИМАНИЕ на строчки :

{

// w.left = rc.left + k*dx;
//w.right = rc.left+(k+1)*dx;
w.top = rc.top+k*dy;
w.bottom = rc.top+(k+1)*dy;
w.left = rc.left;
w.right = rc.right;
//w.top = rc.top;
//w.bottom = rc.bottom;
dc.FillSolidRect(&w, c[k]);

}

Их может быть 2 вида :

1 Вид  = Обычный
КОД :

{

// w.left = rc.left + k*dx;
//w.right = rc.left+(k+1)*dx;
w.top = rc.top+k*dy;
w.bottom = rc.top+(k+1)*dy;
w.left = rc.left;
w.right = rc.right;
//w.top = rc.top;
//w.bottom = rc.bottom;
dc.FillSolidRect(&w, c[k]);

}



2 Вид = Ступеньки
КОД:

{

        w.left = rc.left + k*dx;
w.right = rc.left+(k+1)*dx;
w.top = rc.top+k*dy;
w.bottom = rc.top+(k+1)*dy;
//w.left = rc.left;
//w.right = rc.right;
//w.top = rc.top;
//w.bottom = rc.bottom;
dc.FillSolidRect(&w, c[k]);

}



Теперь все готово! И есть 2 вида программы(выбирайте какой захотите), но полной программой считается ( 1 Вид),так как это и есть нашей сегодняшней целью.А ( Вид 2 ) это просто так,поиграться с кодом. Удачи в построении этой программы и 2 проекций :
 ( Вид1,Вид2).   Пока !   :)

 Источник: Devaka.ru
   
Источник: Devaka.ru

Комментариев нет:

Отправить комментарий