вторник, 2 мая 2017 г.

Програма "Кругова діаграма сім секторів "

Програма "Кругова діаграма сім секторів "

 Сьогодні ми спробуємо побудувати кругову діаграму на сім секторів у Visual Studio.



                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           
По - перше потрібно скачати файл з яким ми будемо працювати. Його можна скачати на (
https://www.miwzua.com/)  назва якого RndColorProgramDiagramm7. 

Після скачування зайдіть у проект. І зайдіть у ProgramDlg.h


















Видаляємо все і пишемо такий код:


// ProgramDlg.h : файл заголовка

 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);

protected:
HICON m_hIcon;

virtual BOOL OnInitDialog();
afx_msg void OnPaint();
afx_msg HCURSOR OnQueryDragIcon();
DECLARE_MESSAGE_MAP()


private:


COLORREF cf, ck, c[25];
HFONT hold, hNew, hbk;
HPEN hPenOxy, hOldPen, pen;
HBRUSH m, oldm, brush;
CPen d, oldd;
CBitmap pic;
CRect rc, w, kw[30];

CString ms, t, z;

int Matrix[50][50];
int x1, y1, x2, y2, x3, y3, x4, y4;
int RH, RW, k, i, j, p, x, y, cx, cy, cz, dx, dy;

bool fg;

public:

void zastavka();
void kdiagramm();
void krdiagramm();
void diagramm();
void sevensector();


afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
afx_msg void OnRButtonDown(UINT nFlags, CPoint point);
}

Після чого відкриваємо ProgramDlg.cpp. 



Видаляємо там увесь код і пишемо:

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

#include "stdafx.h"
#include "Program.h"
#include "ProgramDlg.h"
#include "afxdialogex.h"
#include <time.h>

using namespace std;


#ifdef _DEBUG
#define new DEBUG_NEW
#endif


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

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

fg = true;

SetWindowTextW(L"Побудова діаграм.");
}

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


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

BOOL CProgramDlg::OnInitDialog()
{
CDialog::OnInitDialog();
SetIcon(m_hIcon, TRUE);  
SetIcon(m_hIcon, FALSE); 

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

return TRUE; 
}

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
{
  //zastavka();
  //kdiagramm();
  //diagramm();
  //krdiagramm();
  sevensector();

  CDialog::OnPaint();
}
}

HCURSOR CProgramDlg::OnQueryDragIcon()
{
return static_cast<HCURSOR>(m_hIcon);
}


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::kdiagramm()
{
CClientDC dc(this);
GetClientRect(&rc);

dc.FillSolidRect(&rc, 0x00FFFFFF);

hPenOxy = CreatePen(PS_SOLID, 3, 0x00FFFFFF);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);

x1 = rc.left + 170;
y1 = rc.top + 10;
x2 = rc.right - 170;
y2 = rc.bottom - 10;


m = CreateSolidBrush(0x0000BBFF);
oldm = (HBRUSH)dc.SelectObject(m);

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

m = CreateSolidBrush(0x00E16941);
oldm = (HBRUSH)dc.SelectObject(m);

x3 = x2;
y3 = (y1 + y2) / 2 + 20;
x4 = (x1 + x2) / 2;
y4 = y1;

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);

m = CreateSolidBrush(0x002E67F3);
oldm = (HBRUSH)dc.SelectObject(m);

x3 = x2 - 50;
y3 = y2;
x4 = x2;
y4 = (y1 + y2) / 2 + 20;

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);


m = CreateSolidBrush(0x00C4A69A);
oldm = (HBRUSH)dc.SelectObject(m);

x3 = x1;
y3 = y2 - 50;
x4 = x2 - 50;
y4 = y2;

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);


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

void CProgramDlg::diagramm()
{
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++)
{
  cx = rand() % 255;
  cy = rand() % 255;
  cz = rand() % 255;
  c[k] = RGB(cx, cy, cz);
}

cf = ck = RGB(255, 255, 255);
dc.Rectangle(&rc);

// прорисовываем прямоугольники разного цвета
for (k = 0; k < 6; k++)
{
  // крайние только белого света
  if ((k > 0) && (k < 6))
  {
   cf = ck = c[k];
   ck = RGB(255, 255, 255);
  }

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

  x1 = rc.left + k*dx;
  y1 = rc.top + (rand() % 6 + 1)*dy - rand() % dy;
  x2 = rc.left + (k + 1)*dx;
  y2 = rc.bottom - dy + 50;

  if ((k > 0) && (k < 6)) dc.Rectangle(x1, y1, x2, y2);
}


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

}

void CProgramDlg::krdiagramm()
{
CClientDC dc(this);
GetClientRect(&rc);


dc.FillSolidRect(&rc, 0x00FFFFFF);
for (k = 0; k < 7; k++)
{
  cx = rand() % 255;
  cy = rand() % 255;
  cz = rand() % 255;
  c[k] = RGB(cx, cy, cz);
}

hPenOxy = CreatePen(PS_SOLID, 4, 0x00FFFFFF);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);

x = x1 = rc.left + 170;
y = y1 = rc.top + 10;
dx = x2 = rc.right - 170;
dy = y2 = rc.bottom - 10;

cx = 0.5*(x + dx);
cy = 0.5*(y + dy);

m = CreateSolidBrush(c[0]);
oldm = (HBRUSH)dc.SelectObject(m);

dc.Ellipse(x1, y1, x2, y2); // рисуем круг


m = CreateSolidBrush(c[1]);
oldm = (HBRUSH)dc.SelectObject(m);

// вторая координатная четверть
do
{
  x3 = x + rand() % abs(cx - x);
  x4 = x + rand() % abs(cx - x);
} while (x4 > x3);

do
{
  y3 = y + rand() % abs(cy - y);
  y4 = y + rand() % abs(cy - y);
} while (y4 < y3);

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);
m = CreateSolidBrush(c[2]);
oldm = (HBRUSH)dc.SelectObject(m);

// первая координатная четверть
do
{
  x3 = cx + rand() % abs(dx - cx);
  x4 = cx + rand() % abs(dx - cx);
} while (x4 > x3);

do
{
  y3 = y + rand() % abs(cy - y);
  y4 = y + rand() % abs(cy - y);
} while (y4 > y3);

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);
m = CreateSolidBrush(c[3]);
oldm = (HBRUSH)dc.SelectObject(m);

// третья координатная четверть
do
{
  x3 = x + rand() % (cx - x);
  x4 = x + rand() % (cx - x);
} while (x4 < x3);

do
{
  y3 = cy + rand() % (dy - cy);
  y4 = cy + rand() % (dy - cy);
} while (y3 > y4);

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);

m = CreateSolidBrush(c[4]);
oldm = (HBRUSH)dc.SelectObject(m);

// четвертая координатная четверть
do
{
  x3 = cx + rand() % (dx - cx);
  x4 = cx + rand() % (dx - cx);
} while (x4<x3);

do
{
  y3 = cy + rand() % (dy - cy);
  y4 = cy + rand() % (dy - cy);
} while (y3<y4);

dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);

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




void CProgramDlg::sevensector()
{
CClientDC dc(this);
GetClientRect(&rc);


dc.FillSolidRect(&rc, 0x00FFFFFF);


for (k = 0; k < 12; k++)
{
  cx = rand() % 255;
  cy = rand() % 255;
  cz = rand() % 255;
  c[k] = RGB(cx, cy, cz);
}

hPenOxy = CreatePen(PS_SOLID, 1, 0x00FFFFFF);
hOldPen = (HPEN)SelectObject(dc, hPenOxy);


x = x1 = rc.left + 170;
y = y1 = rc.top + 10;
dx = x2 = rc.right - 170;
dy = y2 = rc.bottom - 10;

cx = 0.5*(x + dx);
cy = 0.5*(y + dy);

m = CreateSolidBrush(c[0]);
oldm = (HBRUSH)dc.SelectObject(m);

dc.Ellipse(x1, y1, x2, y2); // рисуем круг



Matrix[0][0] = cx; Matrix[0][1] = y;



// вторая координатная четверть
do
{
  x3 = x + rand() % abs(cx - x);
  x4 = x + rand() % abs(cx - x);
} while (x4 > x3);

do
{
  y3 = y + rand() % abs(cy - y);
  y4 = y + rand() % abs(cy - y);
} while (y4 < y3);

Matrix[1][0] = x3; Matrix[1][1] = y3;








// третья координатная четверть 1 tochka
do
{
  x3 = x + rand() % (cx - x);
  x4 = x + rand() % (cx - x);
} while (x4 < x3);

do
{
  y3 = cy + rand() % ((dy + cy) / 2 - cy);
  y4 = cy + rand() % ((dy + cy) / 2 - cy);
} while (y3 > y4);

Matrix[2][0] = x3; Matrix[2][1] = y3;

// третья координатная четверть 2 tochka
do
{
  x3 = (x + cx)*0.5 + rand() % (cx - (x + cx) / 2);
  x4 = (x + cx)*0.5 + rand() % (cx - (x + cx) / 2);
} while (x4 < x3);

do
{
  y3 = (cy + dy)*0.5 + rand() % (dy - (cy + dy) / 2);
  y4 = (cy + dy)*0.5 + rand() % (dy - (cy + dy) / 2);
} while (y3 > y4);

Matrix[3][0] = x3; Matrix[3][1] = y3;


// четвертая координатная четверть
do
{
  x3 = cx + rand() % (dx - cx);
  x4 = cx + rand() % (dx - cx);
} while (x4<x3);

do
{
  y3 = cy + rand() % (dy - cy);
  y4 = cy + rand() % (dy - cy);
} while (y3<y4);

Matrix[4][0] = x3; Matrix[4][1] = y3;

// первая координатная четверть 1 точка
do
{
  x3 = (cx + dx)*0.5 + rand() % abs(dx - (cx + dx) / 2);
  x4 = (cx + dx)*0.5 + rand() % abs(dx - (cx + dx) / 2);
} while (x4 > x3);

do
{
  y3 = (y + cy)*0.5 + rand() % abs(cy - (y + cy) / 2);
  y4 = (y + cy)*0.5 + rand() % abs(cy - (y + cy) / 2);
} while (y4 > y3);

Matrix[5][0] = x3; Matrix[5][1] = y3;



// первая координатная четверть 2 точка
do
{
  x3 = cx + rand() % abs((cx + dx) / 2 - cx);
  x4 = cx + rand() % abs((cx + dx) / 2 - cx);
} while (x4 > x3);

do
{
  y3 = y + rand() % abs((y + cy) / 2 - y);
  y4 = y + rand() % abs((y + cy) / 2 - y);
} while (y4 > y3);

Matrix[6][0] = x3; Matrix[6][1] = y3;



for (k = 0; k < 6; k++)
{
  // определить цвет рисования обьекта
  m = CreateSolidBrush(c[k]);
  oldm = (HBRUSH)dc.SelectObject(m);

  x3 = Matrix[k][0]; y3 = Matrix[k][1];
  x4 = Matrix[k + 1][0]; y4 = Matrix[k + 1][1];

  dc.Pie(x1, y1, x2, y2, x3, y3, x4, y4);

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

}

void CProgramDlg::OnLButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default

//kdiagramm();
//diagramm();
//krdiagramm();
sevensector();

CDialog::OnLButtonDown(nFlags, point);
}

void CProgramDlg::OnRButtonDown(UINT nFlags, CPoint point)
{
// TODO: Add your message handler code here and/or call default

zastavka();

CDialog::OnRButtonDown(nFlags, point);
}

Запускаємо проект і готово. Ось що у вас вийде при багато разовому натисканню: 





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

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