Всем привет,сегодня мы будем делать сложную программу в С++
Для начала нам нужен MicrosoftVisualStudio. Вы можете его скачать,нажав на эту кнопку.
После того, как вы его скачали, вы должны в него зайти.
Создаем MFC Application и называем его как хотим.Далее открываем Обозреватель решений .
Выбираем 2 файла: ProgramDlg.h i ProgramDlg.cpp >
Я буду давать вам сразу полный код файлов,чтоб никто не мучился.
Приступим: ... >
Открываем файл Program.h и стираем весь код в нём.
но вставляем этот :
--------------------------------------------------------------------------------------------------------------------------
// ProgramDlg.h : файл заголовка
//
#pragma once
#include "afxwin.h"
#define mtime 298
#define pi 3.14159265358979323846
// диалоговое окно CProgramDlg
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:
HFONT hold, hNew, hbk;
HPEN hPenOxy, hOldPen;
HBRUSH m, oldm, brush;
HPEN pen;
COLORREF cf, ck, c[25];
CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[12];
CString ms, t, z;
int x1, y1, x2, y2;
int Matrix[50][50];
int RH, RW, k, i, j, p, cx, cy, dx, dy;
bool fg;
public:
CButton RD1;
CButton RD2;
afx_msg void OnBnClickedRadio1();
afx_msg void OnBnClickedRadio2();
void Risovanie(int p);
};
--------------------------------------------------------------------------------------------------------------------------
Открываем файл ProgramDlg.cpp
Стираем весь код
И вставляем этот:
--------------------------------------------------------------------------------------------------------------------------
// ProgramDlg.cpp : файл реализации
//
#include "stdafx.h"
#include "Program.h"
#include "ProgramDlg.h"
#include "afxdialogex.h"
#include "Dialog1.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);
CDialog1 dlg;
dlg.DoModal();
}
void CProgramDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
fg = true;
c[0] = 0x000000FF;
c[1] = 0x0000A5FF;
c[2] = 0x0000DDFF;
c[3] = 0x00008000;
c[4] = 0x00FFFF00;
c[5] = 0x00FF0000;
c[6] = 0x00D30094;
SetWindowTextW(L"Program");
DDX_Control(pDX, IDC_RADIO1, RD1);
DDX_Control(pDX, IDC_RADIO2, RD2);
}
BEGIN_MESSAGE_MAP(CProgramDlg, CDialog)
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_RADIO1, &CProgramDlg::OnBnClickedRadio1)
ON_BN_CLICKED(IDC_RADIO2, &CProgramDlg::OnBnClickedRadio2)
END_MESSAGE_MAP()
// обработчики сообщений CProgramDlg
BOOL CProgramDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// Задает значок для этого диалогового окна. Среда делает это автоматически,
// если главное окно приложения не является диалоговым
SetIcon(m_hIcon, TRUE); // Крупный значок
SetIcon(m_hIcon, FALSE); // Мелкий значок
// TODO: добавьте дополнительную инициализацию
RD1.SetCheck(0);
RD2.SetCheck(1);
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
{
Risovanie(2);
CDialog::OnPaint();
}
}
// Система вызывает эту функцию для получения отображения курсора при перемещении
// свернутого окна.
HCURSOR CProgramDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CProgramDlg::OnBnClickedRadio1()
{
// TODO: Add your control notification handler code here
RD1.SetCheck(1);
RD2.SetCheck(0);
Risovanie(3);
}
void CProgramDlg::OnBnClickedRadio2()
{
// TODO: Add your control notification handler code here
RD1.SetCheck(0);
RD2.SetCheck(1);
Risovanie(2);
}
void CProgramDlg::Risovanie(int p)
{
CClientDC dc(this);
GetClientRect(&rc);
w.left = rc.left + 200;
w.right = rc.right - 150;
w.top = rc.top + 110;
w.bottom = rc.bottom - 50;
dc.FillSolidRect(&rc, RGB(255, 255, 255));
x1 = w.left + 70;
y1 = w.top + 20;
x2 = w.right - 70;
y2 = w.bottom - 10;
cf = 0x0000DDFF;
ck = 0x00800000;
hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);
if (p == 0) dc.Rectangle(x1, y1, x2, y2);
else dc.Ellipse(x1, y1, x2, y2);
if ((p == 2) || (p == 3))
{
rc.left += 180;
rc.right -= 180;
rc.top += 20;
rc.bottom -= 20;
dx = abs(rc.right - rc.left) / 7;
dy = abs(rc.bottom - rc.top) / 7;
for (k = 0; k < 7; k++)
{
hPenOxy = CreatePen(PS_SOLID, 2, c[k]);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(c[k]);
oldm = (HBRUSH)dc.SelectObject(m);
//dc.Rectangle(rc.left+k*dx, rc.top, rc.left + (k+1)*dx, rc.bottom);
//dc.Rectangle(rc.left, rc.top + k*dy, rc.right, rc.top + (k+1)*dy);
if(p==2) dc.Rectangle(rc.left+k*dx/2, rc.top + k*dy/2, rc.right-k*dx/2, rc.bottom-k*dy/2);
else dc.Ellipse(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
}
}
if (p == 4)
{
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, 7, RGB(255, 255, 255));
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);
}
}
DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);
}
--------------------------------------------------------------------------------------------------------------------------
Теперь открываем Окно ресурсов и находим папочку Dialog и открываем IDD_PROGRAM_DIALOG .
Стираем все с нашего поля и делаем его в сеточку:
Теперь заходим в Панель Инструментов.
На нашу планшетку переносим :
2 RadioButton'a с названиями : Ellipse , Kvadrat.
и после этого соединяем их с помощью Group Box. И отодвигаем их вниз.
Теперь в папке Dialog,копируем наш IDD_PROGRAM_DIALOG и вставляем в эту же папку.
По новому файлу - ПКМ - Настройки - IDD_PROGRAM_DIALOG(1) > Dialog1 ( для нашего удобства).
Теперь в нашей основной планшетке ( IDD_PROGRAM_DIALOG ) по Ellipse , Kvadrat - ПКМ - Добавить переменную -:
для Ellipse:
Название : RD2
Control > Value
для Kvadrat :
Название : RD1
Control так и остается.
Теперь,когда кнопки запрограммированы,мы запрограммируем GroupBox.
Для этого :
ПКМ по элементу - Добавить обработчик событий - ничего не изменяя,нажимаем Готово.
Теперь заходим в наш Обозреватель решений и видим,что у нас появились 2 новые файла.
Это : Dialog1.h / Dialog1.cpp
Нам нужно заполнить эти файлы тоже.
Открываем Dialog1.h
Стираем все, и вставляем этот код :
--------------------------------------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------------------------------------
Теперь открываем Dialog1.cpp
Стираем код и пишем :
--------------------------------------------------------------------------------------------------------------------------
// Dialog1.cpp : implementation file
//
#include "stdafx.h"
#include "Program.h"
#include "Dialog1.h"
#include "afxdialogex.h"
#include "ProgramDlg.h"
// CDialog1 dialog
IMPLEMENT_DYNAMIC(CDialog1, CDialog)
CDialog1::CDialog1(CWnd* pParent /*=NULL*/)
: CDialog(DIALOG1, pParent)
{
}
CDialog1::~CDialog1()
{
}
void CDialog1::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
c[0] = 0x000000FF;
c[1] = 0x0000A5FF;
c[2] = 0x0000DDFF;
c[3] = 0x00008000;
c[4] = 0x00FFFF00;
c[5] = 0x00FF0000;
c[6] = 0x00D30094;
//Risovanie(4);
}
BEGIN_MESSAGE_MAP(CDialog1, CDialog)
ON_WM_RBUTTONDOWN()
ON_WM_PAINT()
END_MESSAGE_MAP()
// CDialog1 message handlers
void CDialog1::Risovanie(int p)
{
CClientDC dc(this);
GetClientRect(&rc);
w.left = rc.left + 200;
w.right = rc.right - 150;
w.top = rc.top + 110;
w.bottom = rc.bottom - 50;
dc.FillSolidRect(&rc, RGB(255, 255, 255));
x1 = w.left + 70;
y1 = w.top + 20;
x2 = w.right - 70;
y2 = w.bottom - 10;
cf = 0x0000DDFF;
ck = 0x00800000;
hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);
if (p == 0) dc.Rectangle(x1, y1, x2, y2);
else dc.Ellipse(x1, y1, x2, y2);
if ((p == 2) || (p == 3))
{
rc.left += 180;
rc.right -= 180;
rc.top += 20;
rc.bottom -= 20;
dx = abs(rc.right - rc.left) / 7;
dy = abs(rc.bottom - rc.top) / 7;
for (k = 0; k < 7; k++)
{
hPenOxy = CreatePen(PS_SOLID, 2, c[k]);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(c[k]);
oldm = (HBRUSH)dc.SelectObject(m);
//dc.Rectangle(rc.left+k*dx, rc.top, rc.left + (k+1)*dx, rc.bottom);
//dc.Rectangle(rc.left, rc.top + k*dy, rc.right, rc.top + (k+1)*dy);
if (p == 2) dc.Rectangle(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
else dc.Ellipse(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
}
}
if (p == 4)
{
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, 7, RGB(255, 255, 255));
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);
}
}
DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);
}
void CDialog1::OnRButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
CProgramDlg dlg;
EndDialog(0);
dlg.DoModal();
CDialog::OnRButtonDown(nFlags, point);
}
void CDialog1::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
{
Risovanie(4);
CDialog::OnPaint();
}
}
--------------------------------------------------------------------------------------------------------------------------
Готово! Код нашей программы построен.Теперь при нажатии на Локальный отладчик Windows, у нас будет высвечиваться интро(заголовок программы) и после того как мы его закроем ,у нас будет программа , которая рисует либо круг,либо квадрат, которые в свою очередь будут разрисованы в цветах радуги.
Всё это выглядит примерно вот так :
а после закрытия интро :
Готово! У нас есть во такая, совсем нелегкая программа.
Вы можете написать мне в любой момент, вот ссылка на мой вконтакте
Удачи всем и пока :)
P.S. Я использую русскую версию MicrosoftVisualStudio,если у вас английская версия,то некоторые файлы , компоненты или элементы могут быть переименованы.
Для начала нам нужен MicrosoftVisualStudio. Вы можете его скачать,нажав на эту кнопку.
После того, как вы его скачали, вы должны в него зайти.
Создаем MFC Application и называем его как хотим.Далее открываем Обозреватель решений .
Выбираем 2 файла: ProgramDlg.h i ProgramDlg.cpp >
Я буду давать вам сразу полный код файлов,чтоб никто не мучился.
Приступим: ... >
Открываем файл Program.h и стираем весь код в нём.
но вставляем этот :
--------------------------------------------------------------------------------------------------------------------------
// ProgramDlg.h : файл заголовка
//
#pragma once
#include "afxwin.h"
#define mtime 298
#define pi 3.14159265358979323846
// диалоговое окно CProgramDlg
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:
HFONT hold, hNew, hbk;
HPEN hPenOxy, hOldPen;
HBRUSH m, oldm, brush;
HPEN pen;
COLORREF cf, ck, c[25];
CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[12];
CString ms, t, z;
int x1, y1, x2, y2;
int Matrix[50][50];
int RH, RW, k, i, j, p, cx, cy, dx, dy;
bool fg;
public:
CButton RD1;
CButton RD2;
afx_msg void OnBnClickedRadio1();
afx_msg void OnBnClickedRadio2();
void Risovanie(int p);
};
--------------------------------------------------------------------------------------------------------------------------
Открываем файл ProgramDlg.cpp
Стираем весь код
И вставляем этот:
--------------------------------------------------------------------------------------------------------------------------
// ProgramDlg.cpp : файл реализации
//
#include "stdafx.h"
#include "Program.h"
#include "ProgramDlg.h"
#include "afxdialogex.h"
#include "Dialog1.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);
CDialog1 dlg;
dlg.DoModal();
}
void CProgramDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
fg = true;
c[0] = 0x000000FF;
c[1] = 0x0000A5FF;
c[2] = 0x0000DDFF;
c[3] = 0x00008000;
c[4] = 0x00FFFF00;
c[5] = 0x00FF0000;
c[6] = 0x00D30094;
SetWindowTextW(L"Program");
DDX_Control(pDX, IDC_RADIO1, RD1);
DDX_Control(pDX, IDC_RADIO2, RD2);
}
BEGIN_MESSAGE_MAP(CProgramDlg, CDialog)
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_BN_CLICKED(IDC_RADIO1, &CProgramDlg::OnBnClickedRadio1)
ON_BN_CLICKED(IDC_RADIO2, &CProgramDlg::OnBnClickedRadio2)
END_MESSAGE_MAP()
// обработчики сообщений CProgramDlg
BOOL CProgramDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// Задает значок для этого диалогового окна. Среда делает это автоматически,
// если главное окно приложения не является диалоговым
SetIcon(m_hIcon, TRUE); // Крупный значок
SetIcon(m_hIcon, FALSE); // Мелкий значок
// TODO: добавьте дополнительную инициализацию
RD1.SetCheck(0);
RD2.SetCheck(1);
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
{
Risovanie(2);
CDialog::OnPaint();
}
}
// Система вызывает эту функцию для получения отображения курсора при перемещении
// свернутого окна.
HCURSOR CProgramDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}
void CProgramDlg::OnBnClickedRadio1()
{
// TODO: Add your control notification handler code here
RD1.SetCheck(1);
RD2.SetCheck(0);
Risovanie(3);
}
void CProgramDlg::OnBnClickedRadio2()
{
// TODO: Add your control notification handler code here
RD1.SetCheck(0);
RD2.SetCheck(1);
Risovanie(2);
}
void CProgramDlg::Risovanie(int p)
{
CClientDC dc(this);
GetClientRect(&rc);
w.left = rc.left + 200;
w.right = rc.right - 150;
w.top = rc.top + 110;
w.bottom = rc.bottom - 50;
dc.FillSolidRect(&rc, RGB(255, 255, 255));
x1 = w.left + 70;
y1 = w.top + 20;
x2 = w.right - 70;
y2 = w.bottom - 10;
cf = 0x0000DDFF;
ck = 0x00800000;
hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);
if (p == 0) dc.Rectangle(x1, y1, x2, y2);
else dc.Ellipse(x1, y1, x2, y2);
if ((p == 2) || (p == 3))
{
rc.left += 180;
rc.right -= 180;
rc.top += 20;
rc.bottom -= 20;
dx = abs(rc.right - rc.left) / 7;
dy = abs(rc.bottom - rc.top) / 7;
for (k = 0; k < 7; k++)
{
hPenOxy = CreatePen(PS_SOLID, 2, c[k]);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(c[k]);
oldm = (HBRUSH)dc.SelectObject(m);
//dc.Rectangle(rc.left+k*dx, rc.top, rc.left + (k+1)*dx, rc.bottom);
//dc.Rectangle(rc.left, rc.top + k*dy, rc.right, rc.top + (k+1)*dy);
if(p==2) dc.Rectangle(rc.left+k*dx/2, rc.top + k*dy/2, rc.right-k*dx/2, rc.bottom-k*dy/2);
else dc.Ellipse(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
}
}
if (p == 4)
{
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, 7, RGB(255, 255, 255));
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);
}
}
DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);
}
--------------------------------------------------------------------------------------------------------------------------
Теперь открываем Окно ресурсов и находим папочку Dialog и открываем IDD_PROGRAM_DIALOG .
Стираем все с нашего поля и делаем его в сеточку:
Теперь заходим в Панель Инструментов.
На нашу планшетку переносим :
2 RadioButton'a с названиями : Ellipse , Kvadrat.
и после этого соединяем их с помощью Group Box. И отодвигаем их вниз.
Теперь в папке Dialog,копируем наш IDD_PROGRAM_DIALOG и вставляем в эту же папку.
По новому файлу - ПКМ - Настройки - IDD_PROGRAM_DIALOG(1) > Dialog1 ( для нашего удобства).
Теперь в нашей основной планшетке ( IDD_PROGRAM_DIALOG ) по Ellipse , Kvadrat - ПКМ - Добавить переменную -:
для Ellipse:
Название : RD2
Control > Value
для Kvadrat :
Название : RD1
Control так и остается.
Теперь,когда кнопки запрограммированы,мы запрограммируем GroupBox.
Для этого :
ПКМ по элементу - Добавить обработчик событий - ничего не изменяя,нажимаем Готово.
Теперь заходим в наш Обозреватель решений и видим,что у нас появились 2 новые файла.
Это : Dialog1.h / Dialog1.cpp
Нам нужно заполнить эти файлы тоже.
Открываем Dialog1.h
Стираем все, и вставляем этот код :
--------------------------------------------------------------------------------------------------------------------------
#pragma once
// CDialog1 dialog
class CDialog1 : public CDialog
{
DECLARE_DYNAMIC(CDialog1)
public:
CDialog1(CWnd* pParent = NULL); // standard constructor
virtual ~CDialog1();
// Dialog Data
#ifdef AFX_DESIGN_TIME
enum { IDD = DIALOG1 };
#endif
protected:
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
protected:
HICON m_hIcon;
DECLARE_MESSAGE_MAP()
private:
HFONT hold, hNew, hbk;
HPEN hPenOxy, hOldPen;
HBRUSH m, oldm, brush;
HPEN pen;
COLORREF cf, ck, c[25];
CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[12];
CString ms, t, z;
int x1, y1, x2, y2;
int Matrix[50][50];
int RH, RW, k, i, j, p, cx, cy, dx, dy;
bool fg;
public:
void Risovanie(int p);
afx_msg void OnRButtonDown(UINT nFlags, CPoint point);
afx_msg void OnPaint();
};
Теперь открываем Dialog1.cpp
Стираем код и пишем :
--------------------------------------------------------------------------------------------------------------------------
// Dialog1.cpp : implementation file
//
#include "stdafx.h"
#include "Program.h"
#include "Dialog1.h"
#include "afxdialogex.h"
#include "ProgramDlg.h"
// CDialog1 dialog
IMPLEMENT_DYNAMIC(CDialog1, CDialog)
CDialog1::CDialog1(CWnd* pParent /*=NULL*/)
: CDialog(DIALOG1, pParent)
{
}
CDialog1::~CDialog1()
{
}
void CDialog1::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
c[0] = 0x000000FF;
c[1] = 0x0000A5FF;
c[2] = 0x0000DDFF;
c[3] = 0x00008000;
c[4] = 0x00FFFF00;
c[5] = 0x00FF0000;
c[6] = 0x00D30094;
//Risovanie(4);
}
BEGIN_MESSAGE_MAP(CDialog1, CDialog)
ON_WM_RBUTTONDOWN()
ON_WM_PAINT()
END_MESSAGE_MAP()
// CDialog1 message handlers
void CDialog1::Risovanie(int p)
{
CClientDC dc(this);
GetClientRect(&rc);
w.left = rc.left + 200;
w.right = rc.right - 150;
w.top = rc.top + 110;
w.bottom = rc.bottom - 50;
dc.FillSolidRect(&rc, RGB(255, 255, 255));
x1 = w.left + 70;
y1 = w.top + 20;
x2 = w.right - 70;
y2 = w.bottom - 10;
cf = 0x0000DDFF;
ck = 0x00800000;
hPenOxy = CreatePen(PS_SOLID, 6, ck);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(cf);
oldm = (HBRUSH)dc.SelectObject(m);
if (p == 0) dc.Rectangle(x1, y1, x2, y2);
else dc.Ellipse(x1, y1, x2, y2);
if ((p == 2) || (p == 3))
{
rc.left += 180;
rc.right -= 180;
rc.top += 20;
rc.bottom -= 20;
dx = abs(rc.right - rc.left) / 7;
dy = abs(rc.bottom - rc.top) / 7;
for (k = 0; k < 7; k++)
{
hPenOxy = CreatePen(PS_SOLID, 2, c[k]);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);
m = CreateSolidBrush(c[k]);
oldm = (HBRUSH)dc.SelectObject(m);
//dc.Rectangle(rc.left+k*dx, rc.top, rc.left + (k+1)*dx, rc.bottom);
//dc.Rectangle(rc.left, rc.top + k*dy, rc.right, rc.top + (k+1)*dy);
if (p == 2) dc.Rectangle(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
else dc.Ellipse(rc.left + k*dx / 2, rc.top + k*dy / 2, rc.right - k*dx / 2, rc.bottom - k*dy / 2);
}
}
if (p == 4)
{
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, 7, RGB(255, 255, 255));
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);
}
}
DeleteObject(m);
SelectObject(dc, oldm);
SelectObject(dc, hOldPen);
DeleteObject(hPenOxy);
}
void CDialog1::OnRButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default
CProgramDlg dlg;
EndDialog(0);
dlg.DoModal();
CDialog::OnRButtonDown(nFlags, point);
}
void CDialog1::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
{
Risovanie(4);
CDialog::OnPaint();
}
}
--------------------------------------------------------------------------------------------------------------------------
Готово! Код нашей программы построен.Теперь при нажатии на Локальный отладчик Windows, у нас будет высвечиваться интро(заголовок программы) и после того как мы его закроем ,у нас будет программа , которая рисует либо круг,либо квадрат, которые в свою очередь будут разрисованы в цветах радуги.
Всё это выглядит примерно вот так :
а после закрытия интро :
Готово! У нас есть во такая, совсем нелегкая программа.
Вы можете написать мне в любой момент, вот ссылка на мой вконтакте
Удачи всем и пока :)
P.S. Я использую русскую версию MicrosoftVisualStudio,если у вас английская версия,то некоторые файлы , компоненты или элементы могут быть переименованы.
Best Article Merry Xmax Excellent post. I appreciate this site. Stick with it! Because the admin of this web page is working, no doubt very quickly it will be well-known, due to its quality contents.This website was how do you say it? Relevant!! Finally, I’ve found something that helped me.
ОтветитьУдалитьBest Article Buy Pain relief medications online Excellent post. I appreciate this site. Stick with it! This website was how do you say it? Relevant!! Finally, I’ve found something that helped me.
Best Article Merry Xmax Excellent post. I appreciate this site. Stick with it! Because the admin of this web page is working, no doubt very quickly it will be well-known, due to its quality contents.This website was how do you say it? Relevant!! Finally, I’ve found something that helped me.
ОтветитьУдалитьBest Article Buy Pain relief medications online Excellent post. I appreciate this site. Stick with it! This website was how do you say it? Relevant!! Finally, I’ve found something that helped me.