分享

用图形开发控件ProEssentials创建极坐标图

 昵称11921383 2013-04-10

极坐标图表是一种圆形极线图,上面的数据点使用角度和到中心点的距离来表示。 X轴位于圆圈的边界上,Y 轴连接圆心与 X 轴,图表上的每一个数据点对应一对X,Y值。下面我用工控图表控件ProEssentials介绍如何创建一个简单的极坐标图表。

极坐标图表:

极坐标图,Polar Chart,工控图表控件ProEssentials

ProEssentials创建极坐标图表源代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
void CPEView::CreateSimplePolar()
{
   //! Right button click to show popup menu. //
   //! Double Click to show customization dialog. //
   //! Left-Click and drag to draw zoom box. Use popup memu or 'z' to undo zoom. //
 
   // Simple example show the basics of a polar object. //
   // Polar Graph's contain both YData and XData. //
 
   RECT rect;
   GetClientRect( &rect );
 
   // Construct Object //
   m_hPE = PEcreate(PECONTROL_PGRAPH, WS_VISIBLE, &rect, m_hWnd, 1001);
                 
   PEnset(m_hPE, PEP_nSUBSETS, 2);
   PEnset(m_hPE, PEP_nPOINTS, 360);
 
   int p;
   float f1, f2;
   for (p=0; p<360; p++)
   {
       f1 = (float) p;
       f2 = (float) 150 * sin((double) p * 0.054F);
       PEvsetcellEx(m_hPE, PEP_faXDATA, 0, p, &f1);
       PEvsetcellEx(m_hPE, PEP_faYDATA, 0, p, &f2);
   }
        
   for (p=0; p<360; p++)
   {
       f1 = (float) p;
       f2 = (float) 150 * sin(((double) p * 0.044F)) * 2;
       PEvsetcellEx(m_hPE, PEP_faXDATA, 1, p, &f1);
       PEvsetcellEx(m_hPE, PEP_faYDATA, 1, p, &f2);
   }
 
   PEnset(m_hPE, PEP_nPLOTTINGMETHOD, PEGPM_LINE);
   PEnset(m_hPE, PEP_nALLOWZOOMING, 1);
   PEszset(m_hPE, PEP_szMAINTITLE, TEXT("Polar Chart"));
   PEszset(m_hPE, PEP_szSUBTITLE, TEXT("")); // no subtitle
   float ftmp = .9F;
   PEvset(m_hPE, PEP_fFONTSIZELEGENDCNTL, &ftmp, 1 );
   PEnset(m_hPE, PEP_bPREPAREIMAGES, TRUE);
   PEnset(m_hPE, PEP_bCACHEBMP, TRUE);
   PEnset(m_hPE, PEP_bFOCALRECT, FALSE);
 
   // Set line types
   int nTypes[] = { PELT_MEDIUMSOLID, PELT_MEDIUMSOLID };
   PEvset(m_hPE, PEP_naSUBSETLINETYPES, nTypes, 2);
 
   // Set point types
   int nPTypes[] = { PEPT_DOTSOLID, PEPT_PLUS };
   PEvset(m_hPE, PEP_naSUBSETPOINTTYPES, nTypes, 2);
 
   // subset colors
   DWORD dwArray[2] = { PERGB(128, 198,0,0), PERGB(128, 0, 198, 0) };
   PEvset( m_hPE, PEP_dwaSUBSETCOLORS, dwArray, 2);
             
   // subset labels
   PEvsetcell( m_hPE, PEP_szaSUBSETLABELS, 0, TEXT("Signal #1" ));
   PEvsetcell( m_hPE, PEP_szaSUBSETLABELS, 1, TEXT("Signal #2" ));
 
   double dnull = -99999.0F;
   PEvset(m_hPE, PEP_fNULLDATAVALUEX, &dnull, 1);
   PEvset(m_hPE, PEP_fNULLDATAVALUE, &dnull, 1);
 
   // Set Various other features //
   PEnset(m_hPE, PEP_bFIXEDFONTS, TRUE);
   PEnset(m_hPE, PEP_bBITMAPGRADIENTMODE, TRUE);
   PEnset(m_hPE, PEP_nQUICKSTYLE, PEQS_MEDIUM_NO_BORDER);
   PEnset(m_hPE, PEP_bSIMPLEPOINTLEGEND, TRUE);
   PEnset(m_hPE, PEP_bSIMPLELINELEGEND, TRUE);
   PEnset(m_hPE, PEP_nLEGENDSTYLE, PELS_1_LINE);
   PEnset(m_hPE, PEP_nZOOMSTYLE, PEZS_RO2_NOT);
   PEnset(m_hPE, PEP_nPOINTSIZE, PEPS_SMALL);
 
   PEnset(m_hPE, PEP_nTEXTSHADOWS, PETS_BOLD_TEXT);
   PEnset(m_hPE, PEP_bMAINTITLEBOLD, TRUE);
   PEnset(m_hPE, PEP_bSUBTITLEBOLD, TRUE);
   PEnset(m_hPE, PEP_bLABELBOLD, TRUE);
   PEnset(m_hPE, PEP_bLINESHADOWS, TRUE);
   PEnset(m_hPE, PEP_nFONTSIZE, PEFS_MEDIUM);
   PEnset(m_hPE, PEP_nGRADIENTBARS, 8);
   PEnset(m_hPE, PEP_nDATASHADOWS, PEDS_SHADOWS);
   float f = 1.2F;
   PEvset(m_hPE, PEP_fFONTSIZEGNCNTL, &f, 1);
   PEnset(m_hPE, PEP_nIMAGEADJUSTBOTTOM, 100);
 
   // Improves metafile export //
   PEnset(m_hPE, PEP_nDPIX, 600);
   PEnset(m_hPE, PEP_nDPIY, 600);
 
   // Set Demo's RenderEngine to Gdi Plus //
   CMDIFrameWnd* pWnd = (CMDIFrameWnd*) AfxGetApp()->GetMainWnd();
   pWnd->SendMessage(WM_CHANGE_METAFILE, PEPLAYMETAFILEGDIPLUS );
    
}
 
//***************************

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约