Всем привет! Сегодня мы сделаем легкую программу в С++ , при запуске которой,у нас высветятся квадратики и они будут разрисованы по спектру(или радуге). Приступим...
Для начала нам нужно зайти в сам 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
Для начала нам нужно зайти в сам 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
Комментариев нет:
Отправить комментарий