StaffAchievementShowAll.cpp 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977
  1. // StaffAchievementShowAll.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "ylgl.h"
  5. #include "StaffAchievementShowAll.h"
  6. #include "MyMdi.H"
  7. #include "VcPlot.h"
  8. #include "VcAxis.h"
  9. #include "VcValueScale.h"
  10. #include "VcSeriesCollection.h"
  11. #include "VcSeries.h"
  12. #include "VcPen.h"
  13. #include "VcCategoryScale.h"
  14. #include "VcColor.h"
  15. #include "VcDataGrid.h"
  16. #include "VcBackdrop.h"
  17. #include "VcFill.h"
  18. #include "VcBrush.h"
  19. #include "VcDataPoints.h"
  20. #include "VcDataPoint.h"
  21. #include "VcDataPointLabel.h"
  22. #include "VcAxisTitle.h"
  23. #ifdef _DEBUG
  24. #define new DEBUG_NEW
  25. #undef THIS_FILE
  26. static char THIS_FILE[] = __FILE__;
  27. #endif
  28. //#define LIM_TIME 1
  29. #define ONLYBOOKING 1 //摄影师化妆师不提前期, 一般影楼是没有前期的。
  30. /////////////////////////////////////////////////////////////////////////////
  31. // StaffAchievementShowAll IDC_STATIC1
  32. StaffAchievementShowAll::StaffAchievementShowAll(CWnd* pParent /*=NULL*/)
  33. : CDialog(StaffAchievementShowAll::IDD, pParent)
  34. {
  35. //{{AFX_DATA_INIT(StaffAchievementShowAll)
  36. m_year = atoi(g_date.Mid (0,4));
  37. m_month = atoi(g_date.Mid (5,2));
  38. m_day = 12;
  39. m_radio2 = 1;
  40. m_radio1 = 1;
  41. m_bInit=0;
  42. m_timestmap=0;
  43. m_radio3=0;
  44. //}}AFX_DATA_INIT
  45. //m_date = CTime::GetCurrentTime ().Format ("%Y-%m-%d");
  46. }
  47. void StaffAchievementShowAll::DoDataExchange(CDataExchange* pDX)
  48. {
  49. CDialog::DoDataExchange(pDX);
  50. //{{AFX_DATA_MAP(StaffAchievementShowAll)
  51. DDX_Control(pDX, IDC_SPIN3, m_spinday);
  52. DDX_Control(pDX, IDC_SPIN2, m_spinmonth);
  53. DDX_Control(pDX, IDC_SPIN1, m_spinyear);
  54. DDX_Control(pDX, IDC_STATIC1, m_static1);
  55. DDX_Text(pDX, IDC_EDITyear, m_year);
  56. DDX_Text(pDX, IDC_EDITmonth, m_month);
  57. DDV_MinMaxUInt(pDX, m_month, 1, 12);
  58. DDX_Text(pDX, IDC_EDITday, m_day);
  59. DDV_MinMaxUInt(pDX, m_day, 1, 31);
  60. DDX_Radio(pDX, IDC_RADIO6, m_radio2);
  61. DDX_Radio(pDX, IDC_RADIO3, m_radio1);
  62. //}}AFX_DATA_MAP
  63. }
  64. BEGIN_MESSAGE_MAP(StaffAchievementShowAll, CDialog)
  65. //{{AFX_MSG_MAP(StaffAchievementShowAll)
  66. ON_BN_CLICKED(IDC_BUTclose, OnBUTclose)
  67. ON_EN_CHANGE(IDC_EDITyear, OnChangeEDITyear)
  68. ON_EN_CHANGE(IDC_EDITmonth, OnChangeEDITmonth)
  69. ON_EN_CHANGE(IDC_EDITday, OnChangeEDITday)
  70. ON_BN_CLICKED(IDC_RADIO3, OnRadio3)
  71. ON_BN_CLICKED(IDC_RADIO4, OnRadio4)
  72. ON_BN_CLICKED(IDC_RADIO5, OnRadio5)
  73. ON_BN_CLICKED(IDC_RADIO6, OnRadio6)
  74. ON_BN_CLICKED(IDC_RADIO7, OnRadio7)
  75. ON_WM_DESTROY()
  76. ON_BN_CLICKED(IDC_BUTprint, OnBUTshowall)
  77. ON_WM_TIMER()
  78. ON_WM_CTLCOLOR()
  79. ON_WM_CLOSE()
  80. //}}AFX_MSG_MAP
  81. END_MESSAGE_MAP()
  82. /////////////////////////////////////////////////////////////////////////////
  83. // StaffAchievementShowAll diagnostics
  84. #ifdef _DEBUG
  85. void StaffAchievementShowAll::AssertValid() const
  86. {
  87. CDialog::AssertValid();
  88. }
  89. void StaffAchievementShowAll::Dump(CDumpContext& dc) const
  90. {
  91. CDialog::Dump(dc);
  92. }
  93. #endif //_DEBUG
  94. /////////////////////////////////////////////////////////////////////////////
  95. // StaffAchievementShowAll message handlers
  96. void StaffAchievementShowAll::FillGrid()
  97. {
  98. }
  99. void StaffAchievementShowAll::OnBUTclose()
  100. {
  101. // TODO: Add your control notification handler code here
  102. CDialog::OnCancel ();
  103. }
  104. void StaffAchievementShowAll::OnChangeEDITyear()
  105. {
  106. // TODO: If this is a RICHEDIT control, the control will not
  107. // send this notification unless you override the CDialog::OnInitDialog()
  108. // function and call CRichEditCtrl().SetEventMask()
  109. // with the ENM_CHANGE flag ORed into the mask.
  110. DateChange();
  111. // TODO: Add your control notification handler code here
  112. }
  113. void StaffAchievementShowAll::OnChangeEDITmonth()
  114. {
  115. // TODO: If this is a RICHEDIT control, the control will not
  116. // send this notification unless you override the CDialog::OnInitDialog()
  117. // function and call CRichEditCtrl().SetEventMask()
  118. // with the ENM_CHANGE flag ORed into the mask.
  119. DateChange();
  120. // TODO: Add your control notification handler code here
  121. }
  122. void StaffAchievementShowAll::OnChangeEDITday()
  123. {
  124. // TODO: If this is a RICHEDIT control, the control will not
  125. // send this notification unless you override the CDialog::OnInitDialog()
  126. // function and call CRichEditCtrl().SetEventMask()
  127. // with the ENM_CHANGE flag ORed into the mask.
  128. if(m_bInit==0)return;
  129. DateChange();
  130. UpdateData();
  131. CString version = _T ("Version 1.0");
  132. AfxGetApp()->WriteProfileInt (version, "rowcount", m_day);
  133. // TODO: Add your control notification handler code here
  134. }
  135. void StaffAchievementShowAll::DateChange()
  136. {
  137. if(m_bInit==0)return;
  138. // if(::GetTickCount ()-m_timestmap<500)return;
  139. // m_timestmap=::GetTickCount ();
  140. UpdateData();
  141. CString date1,date2;
  142. #ifdef LIM_TIME
  143. date1.Format ("%d-%02d-14", m_year, m_month);
  144. date2.Format ("%d-%02d-31", m_year, 2);
  145. #else
  146. date1.Format ("%d-%02d-01", m_year, m_month);
  147. date2.Format ("%d-%02d-31", m_year, m_month);
  148. #endif
  149. #ifndef MNLS_VERSION
  150. date1.Format ("%d-%02d-01", m_year, m_month);
  151. date2.Format ("%d-%02d-31", m_year, m_month);
  152. #endif
  153. CArray<CStringArray, CStringArray>bukuanarray;
  154. CArray<CStringArray, CStringArray>bukuanarray2;
  155. CArray<CStringArray, CStringArray>singleincomearray;
  156. int i;
  157. int g_nYearposTemp=g_nYearpos;
  158. BOOL bLastYear=0;
  159. BOOL bThisYear=0;
  160. BOOL bOldYear=0;
  161. if(m_year==atoi(g_date.Left (4)) && g_hisyeararray.GetSize () )
  162. bThisYear=1;
  163. else if(m_year<=atoi(g_date.Left (4))-1 && g_hisyeararray.GetSize ())
  164. bLastYear=1;
  165. else if(atoi(g_date.Left (4))-m_year>1 && g_hisyeararray.GetSize ()>=(atoi(g_date.Left (4))-m_year))
  166. {
  167. bOldYear=1;
  168. }
  169. g_nYearpos=GetYearPos(m_year);
  170. CString filter="date>='"+date1+"' and date<='"+date2+"';date>='"+date1+"' and date<='"+date2+"';;dimission='在职';time2>='"+date1+"' and time2<='"+date2+"' and status='OK'***date<'"+date1+"'";
  171. g_sendhead.code[0]=59;
  172. g_sendhead.code[1]=198;
  173. g_sendhead.code[2]=60;
  174. g_sendhead.code[3]=34;
  175. g_sendhead.code[4]=61;
  176. g_sendhead.tabcount=5;
  177. g_sendhead.bsql=0;
  178. g_pMainWnd->ProcessChatMessageRequest2(filter);
  179. if(g_bSendOK==0)
  180. {
  181. g_nYearpos=g_nYearposTemp;
  182. return;
  183. }
  184. DataToArray(&bukuanarray,&singleincomearray,&waiterarray,&m_List1array,&bukuanarray2);
  185. if(bLastYear)//如果是去年, 则加今年的补款
  186. {
  187. g_nYearpos=-1;//今年
  188. filter="date>='"+date1+"' and date<='"+date2+"';date>='"+date1+"' and date<='"+date2+"';;dimission='在职';time2>='"+date1+"' and time2<='"+date2+"' and status='OK'***date<'"+date1+"'";
  189. g_sendhead.code[0]=59;
  190. g_sendhead.code[1]=198;
  191. g_sendhead.code[2]=60;
  192. g_sendhead.code[3]=34;
  193. g_sendhead.code[4]=61;
  194. g_sendhead.tabcount=5;
  195. g_sendhead.bsql=0;
  196. g_pMainWnd->ProcessChatMessageRequest2(filter);
  197. if(g_bSendOK==0)
  198. {
  199. g_nYearpos=g_nYearposTemp;
  200. return;
  201. }
  202. CArray<CStringArray, CStringArray>ThisYearbukuanarray;
  203. CArray<CStringArray, CStringArray>ThisYearsingleincomearray;
  204. CArray<CStringArray, CStringArray>ThisYearwaiterarray;
  205. CArray<CStringArray, CStringArray>ThisYearbukuanarray2;
  206. DataToArray(&ThisYearbukuanarray,&ThisYearsingleincomearray,&ThisYearwaiterarray,&m_List1array,&ThisYearbukuanarray2);
  207. int oldsize=bukuanarray.GetSize ();
  208. bukuanarray.SetSize(oldsize+ThisYearbukuanarray.GetSize ());
  209. for(i=oldsize; i<oldsize+ThisYearbukuanarray.GetSize (); i++)
  210. {
  211. bukuanarray.ElementAt (i).Copy(ThisYearbukuanarray.ElementAt (i-oldsize));
  212. }
  213. oldsize=singleincomearray.GetSize ();
  214. singleincomearray.SetSize(oldsize+ThisYearsingleincomearray.GetSize ());
  215. for(i=oldsize; i<oldsize+ThisYearsingleincomearray.GetSize (); i++)
  216. {
  217. singleincomearray.ElementAt (i).Copy(ThisYearsingleincomearray.ElementAt (i-oldsize));
  218. }
  219. oldsize=bukuanarray2.GetSize ();
  220. bukuanarray2.SetSize(oldsize+ThisYearbukuanarray2.GetSize ());
  221. for(i=oldsize; i<oldsize+ThisYearbukuanarray2.GetSize (); i++)
  222. {
  223. bukuanarray2.ElementAt (i).Copy(ThisYearbukuanarray2.ElementAt (i-oldsize));
  224. }
  225. oldsize=waiterarray.GetSize ();
  226. waiterarray.SetSize(oldsize+ThisYearwaiterarray.GetSize ());
  227. for(i=oldsize; i<oldsize+ThisYearwaiterarray.GetSize (); i++)
  228. {
  229. waiterarray.ElementAt (i).Copy(ThisYearwaiterarray.ElementAt (i-oldsize));
  230. }
  231. }
  232. else if(bThisYear)//如果是今年, 则加去年的补款
  233. {
  234. g_nYearpos=0;//去年
  235. CString filter="date>='"+date1+"' and date<='"+date2+"';date>='"+date1+"' and date<='"+date2+"';;time2>='"+date1+"' and time2<='"+date2+"' and status='OK'***date<'"+date1+"'";
  236. g_sendhead.code[0]=59;
  237. g_sendhead.code[1]=198;
  238. g_sendhead.code[2]=60;
  239. g_sendhead.code[3]=61;
  240. g_sendhead.tabcount=4;
  241. g_sendhead.bsql=0;
  242. g_pMainWnd->ProcessChatMessageRequest2(filter);
  243. if(g_bSendOK==0)
  244. {
  245. g_nYearpos=g_nYearposTemp;
  246. return;
  247. }
  248. CArray<CStringArray, CStringArray>ThisYearbukuanarray;
  249. CArray<CStringArray, CStringArray>ThisYearsingleincomearray;
  250. CArray<CStringArray, CStringArray>ThisYearwaiterarray;
  251. CArray<CStringArray, CStringArray>ThisYearbukuanarray2;
  252. DataToArray(&ThisYearbukuanarray,&ThisYearsingleincomearray,&ThisYearwaiterarray,&ThisYearbukuanarray2);
  253. int oldsize=bukuanarray.GetSize ();
  254. bukuanarray.SetSize(oldsize+ThisYearbukuanarray.GetSize ());
  255. for(i=oldsize; i<oldsize+ThisYearbukuanarray.GetSize (); i++)
  256. {
  257. bukuanarray.ElementAt (i).Copy(ThisYearbukuanarray.ElementAt (i-oldsize));
  258. }
  259. oldsize=singleincomearray.GetSize ();
  260. singleincomearray.SetSize(oldsize+ThisYearsingleincomearray.GetSize ());
  261. for(i=oldsize; i<oldsize+ThisYearsingleincomearray.GetSize (); i++)
  262. {
  263. singleincomearray.ElementAt (i).Copy(ThisYearsingleincomearray.ElementAt (i-oldsize));
  264. }
  265. oldsize=bukuanarray2.GetSize ();
  266. bukuanarray2.SetSize(oldsize+ThisYearbukuanarray2.GetSize ());
  267. for(i=oldsize; i<oldsize+ThisYearbukuanarray2.GetSize (); i++)
  268. {
  269. bukuanarray2.ElementAt (i).Copy(ThisYearbukuanarray2.ElementAt (i-oldsize));
  270. }
  271. oldsize=waiterarray.GetSize ();
  272. waiterarray.SetSize(oldsize+ThisYearwaiterarray.GetSize ());
  273. for(i=oldsize; i<oldsize+ThisYearwaiterarray.GetSize (); i++)
  274. {
  275. waiterarray.ElementAt (i).Copy(ThisYearwaiterarray.ElementAt (i-oldsize));
  276. }
  277. }
  278. g_nYearpos=g_nYearposTemp;
  279. ////////////////////////////
  280. int ii=0;
  281. money1array.RemoveAll ();
  282. money1array.SetSize(m_List1array.GetSize ());
  283. money2array.RemoveAll ();
  284. money2array.SetSize(m_List1array.GetSize ());
  285. for(int n=0; n<m_List1array.GetSize (); n++)
  286. {
  287. CString name=m_List1array.ElementAt (n).ElementAt (0);
  288. float money1=0;
  289. float money2=0;
  290. int arraypos=0;
  291. for( ii=0; ii<bukuanarray.GetSize (); ii++)
  292. {
  293. if(bukuanarray.ElementAt (ii).ElementAt (2)=="3" || bukuanarray.ElementAt (ii).ElementAt (2)=="4")
  294. {
  295. BOOL bWait1=0;
  296. BOOL bWait2=0;
  297. float fscale1=0;
  298. float fscale2=0;
  299. IsWaiter2(bukuanarray.ElementAt (ii).ElementAt (5), name, &waiterarray, bWait1, bWait2, fscale1, fscale2, 1, date1, date2);
  300. if(bWait1 && atoi(g_cominfoarray.ElementAt(0).ElementAt(56)) )//我是摄影师
  301. {
  302. money1+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale1;
  303. }
  304. if(bWait2 && atoi(g_cominfoarray.ElementAt(0).ElementAt(57)))//我是化妆师
  305. {
  306. money1+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale2;
  307. }
  308. IsWaiter3(bukuanarray.ElementAt (ii).ElementAt (5), name, &waiterarray, bWait1, bWait2, fscale1, fscale2);
  309. if(bWait1)
  310. {
  311. money1+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale1;
  312. }
  313. if(bWait2)
  314. {
  315. money1+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale2;
  316. }
  317. // if(bukuanarray.ElementAt (ii).ElementAt (6)!=name)continue;
  318. // money1+=atof(bukuanarray.ElementAt (ii).ElementAt (0));
  319. }
  320. // else if(bukuanarray.ElementAt (ii).ElementAt (2)=="2")//选片补款, 需加摄影师和化妆师
  321. else if(bukuanarray.ElementAt (ii).ElementAt (7)=="选片二销")//选片补款, 需加摄影师和化妆师
  322. {
  323. BOOL bWait1=0;
  324. BOOL bWait2=0;
  325. float fscale1=0;
  326. float fscale2=0;
  327. IsWaiter2(bukuanarray.ElementAt (ii).ElementAt (5), name, &waiterarray, bWait1, bWait2, fscale1, fscale2, 0, date1, date2);
  328. if(bWait1 && atoi(g_cominfoarray.ElementAt(0).ElementAt(41)) )//我是摄影师
  329. {
  330. money2+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale1;
  331. }
  332. if(bWait2 && atoi(g_cominfoarray.ElementAt(0).ElementAt(42)))//我是化妆师
  333. {
  334. money2+=atof(bukuanarray.ElementAt (ii).ElementAt (0))*fscale2;
  335. }
  336. if(bukuanarray.ElementAt (ii).ElementAt (6)!=name)continue;
  337. money2+=atof(bukuanarray.ElementAt (ii).ElementAt (0));
  338. }
  339. else
  340. {
  341. if(bukuanarray.ElementAt (ii).ElementAt (6)!=name)continue;
  342. money2+=atof(bukuanarray.ElementAt (ii).ElementAt (0));
  343. }
  344. }
  345. for( ii=0; ii<bukuanarray2.GetSize (); ii++)
  346. {
  347. if(bukuanarray2.ElementAt (ii).ElementAt (2)=="3" || bukuanarray2.ElementAt (ii).ElementAt (2)=="4")
  348. {
  349. BOOL bWait1=0;
  350. BOOL bWait2=0;
  351. float fscale1=0;
  352. float fscale2=0;
  353. IsWaiter2(bukuanarray2.ElementAt (ii).ElementAt (5), name, &waiterarray, bWait1, bWait2, fscale1, fscale2, 1, date1, date2);
  354. if(bWait1 && atoi(g_cominfoarray.ElementAt(0).ElementAt(56)) )//我是摄影师
  355. {
  356. money1+=atof(bukuanarray2.ElementAt (ii).ElementAt (0))*fscale1;
  357. }
  358. if(bWait2 && atoi(g_cominfoarray.ElementAt(0).ElementAt(57)))//我是化妆师
  359. {
  360. money1+=atof(bukuanarray2.ElementAt (ii).ElementAt (0))*fscale2;
  361. }
  362. }
  363. }
  364. for( ii=0; ii<singleincomearray.GetSize (); ii++)
  365. {
  366. if(singleincomearray.ElementAt (ii).ElementAt (2)!=name)continue;
  367. money2+=atof(singleincomearray.ElementAt (ii).ElementAt (4));
  368. }
  369. money1array.SetAt (n, money1);
  370. money2array.SetAt (n, money2);
  371. #ifdef MNLS_VERSION
  372. #ifdef LIM_TIME
  373. money2array.SetAt (n, 0);
  374. #endif
  375. #endif
  376. }
  377. #ifdef MNLS_VERSION
  378. #ifdef LIM_TIME
  379. m_radio2=0;//全部
  380. #endif
  381. #endif
  382. KindChange();
  383. OnRadio3();
  384. }
  385. void StaffAchievementShowAll::KindChange()
  386. {
  387. m_day=1000;
  388. if(m_day<1)return;
  389. CArray<CStringArray, CStringArray>m_List1arraytemp;
  390. CArray<float,float>money1arraytemp;
  391. CArray<float,float>money2arraytemp;
  392. CString str;
  393. if(m_radio3==0)
  394. {
  395. str.Format ("%s员工 %d年%d月 业绩图表-全体", g_title, m_year, m_month);
  396. m_List1arraytemp.SetSize(m_List1array.GetSize ());
  397. money1arraytemp.SetSize(m_List1array.GetSize ());
  398. money2arraytemp.SetSize(m_List1array.GetSize ());
  399. for(int i=0; i<m_List1array.GetSize (); i++)
  400. {
  401. m_List1arraytemp.ElementAt (i).Copy (m_List1array.ElementAt (i));
  402. }
  403. money1arraytemp.Copy (money1array);
  404. money2arraytemp.Copy (money2array);
  405. }
  406. else if(m_radio3==1)
  407. {
  408. str.Format ("%s员工 %d年%d月 业绩图表-门市部", g_title, m_year, m_month);
  409. int size=0;
  410. for(int i=0; i<m_List1array.GetSize (); i++)
  411. {
  412. if(m_List1array.ElementAt (i).ElementAt (5)=="门市部")
  413. {
  414. m_List1arraytemp.SetSize(size+1);
  415. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  416. size++;
  417. money1arraytemp.Add (money1array.ElementAt (i));
  418. money2arraytemp.Add (money2array.ElementAt (i));
  419. }
  420. }
  421. }
  422. else if(m_radio3==2)
  423. {str.Format ("%s员工 %d年%d月 业绩图表-摄影部", g_title, m_year, m_month);
  424. int size=0;
  425. for(int i=0; i<m_List1array.GetSize (); i++)
  426. {
  427. if(m_List1array.ElementAt (i).ElementAt (5)=="摄影部")
  428. {
  429. m_List1arraytemp.SetSize(size+1);
  430. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  431. size++;
  432. money1arraytemp.Add (money1array.ElementAt (i));
  433. money2arraytemp.Add (money2array.ElementAt (i));
  434. }
  435. }
  436. }
  437. else if(m_radio3==3)
  438. {str.Format ("%s员工 %d年%d月 业绩图表-化妆部", g_title, m_year, m_month);
  439. int size=0;
  440. for(int i=0; i<m_List1array.GetSize (); i++)
  441. {
  442. if(m_List1array.ElementAt (i).ElementAt (5)=="化妆部")
  443. {
  444. m_List1arraytemp.SetSize(size+1);
  445. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  446. size++;
  447. money1arraytemp.Add (money1array.ElementAt (i));
  448. money2arraytemp.Add (money2array.ElementAt (i));
  449. }
  450. }
  451. }
  452. CRect rc;
  453. GetDlgItem(IDC_STATIC1)->GetWindowRect (rc);
  454. ScreenToClient(rc);
  455. InvalidateRect(rc);
  456. m_static1.SetWindowText (str);
  457. int chartcount=m_List1arraytemp.GetSize ()/m_day;
  458. if(m_List1arraytemp.GetSize ()%m_day)chartcount++;
  459. if(chartcount==0)return;
  460. BOOL bAdd=0;
  461. /* int m_day=m_List1array.GetSize ()/chartcount;
  462. if(m_List1array.GetSize ()%chartcount)
  463. {
  464. m_day++;
  465. bAdd=1;
  466. }*/
  467. for(int i=0; i<m_pChartArray.GetSize (); i++)
  468. {
  469. CMSChart *pChart=m_pChartArray.ElementAt (i);
  470. pChart->ShowWindow (SW_HIDE);
  471. }
  472. while(m_pChartArray.GetSize ()<chartcount)
  473. {
  474. CMSChart *pChart=new CMSChart;
  475. CRect rc(0,0,0,0);
  476. WCHAR pwchLicenseKey[] =
  477. {
  478. 0x0038, 0x0045, 0x0031, 0x0034, 0x0037, 0x0043,
  479. 0x0036, 0x0039, 0x002D, 0x0042, 0x0044, 0x0035,
  480. 0x0030, 0x002D, 0x0031, 0x0031, 0x0064, 0x0031,
  481. 0x002D, 0x0042, 0x0031, 0x0033, 0x0037, 0x002D,
  482. 0x0030, 0x0030, 0x0030, 0x0030, 0x0046, 0x0038,
  483. 0x0037, 0x0035, 0x0033, 0x0046, 0x0035, 0x0044
  484. };
  485. BSTR bstrLicense = ::SysAllocStringLen(pwchLicenseKey,
  486. sizeof(pwchLicenseKey)/sizeof(WCHAR));
  487. pChart->Create ("", WS_VISIBLE|WS_CHILD, rc, this, m_pChartArray.GetSize (), NULL, 0, bstrLicense );
  488. ::SysFreeString(bstrLicense);
  489. m_pChartArray.Add (pChart);
  490. InitChartStyle(pChart);
  491. SetChartStyle(pChart);
  492. }
  493. GetDlgItem(IDC_STATIC2)->GetWindowRect(rc);
  494. ScreenToClient(rc);
  495. int hei=rc.Height ()/chartcount;
  496. float fmaxmoney1=0;
  497. float fmaxmoney2=0; VARIANT var;
  498. for( i=0; i<chartcount; i++)
  499. {
  500. int nRowCount=min(m_day, m_List1arraytemp.GetSize ()-i*m_day);
  501. for(int row = 1; row <= nRowCount; ++row)
  502. {
  503. fmaxmoney1=max(fmaxmoney1, money1arraytemp.ElementAt (i*m_day+row-1));
  504. fmaxmoney2=max(fmaxmoney2, money2arraytemp.ElementAt (i*m_day+row-1));
  505. }
  506. }
  507. for( i=0; i<chartcount; i++)
  508. {
  509. CMSChart *pChart=m_pChartArray.ElementAt (i);
  510. rc.bottom =rc.top +hei;
  511. pChart->MoveWindow (rc);
  512. pChart->ShowWindow (SW_SHOW);
  513. rc.top +=hei;
  514. int nRowCount=min(m_day, m_List1arraytemp.GetSize ()-i*m_day);
  515. if(bAdd)
  516. {
  517. if(i==chartcount-1)nRowCount++;
  518. }
  519. pChart->SetRowCount(nRowCount);
  520. if(m_radio2==0)//叠加
  521. {
  522. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMaximum(fmaxmoney1+fmaxmoney2);
  523. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMinimum(0);
  524. for(int row = 1; row <= nRowCount; ++row)
  525. {
  526. pChart->SetRow(row);
  527. if(bAdd && i==chartcount-1 && row==nRowCount)
  528. {
  529. pChart->SetRowLabel("");
  530. pChart->GetDataGrid().SetData(row, 1, 0, 0);
  531. continue;
  532. }
  533. pChart->SetRowLabel(m_List1arraytemp.ElementAt (i*m_day+row-1).ElementAt (0));
  534. pChart->GetDataGrid().SetData(row, 1, money1arraytemp.ElementAt (i*m_day+row-1)+money2arraytemp.ElementAt (i*m_day+row-1), 0);
  535. }
  536. }
  537. else
  538. {
  539. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMaximum(max(fmaxmoney1,fmaxmoney2));
  540. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMinimum(0);
  541. for(int row = 1; row <= nRowCount; ++row)
  542. {
  543. pChart->SetRow(row);
  544. if(bAdd && i==chartcount-1 && row==nRowCount)
  545. {
  546. pChart->SetRowLabel("");
  547. pChart->GetDataGrid().SetData(row, 1, 0, 0);
  548. pChart->GetDataGrid().SetData(row, 2, 0, 0);
  549. continue;
  550. }
  551. pChart->SetRowLabel(m_List1arraytemp.ElementAt (i*m_day+row-1).ElementAt (0));
  552. pChart->GetDataGrid().SetData(row, 1, money1arraytemp.ElementAt (i*m_day+row-1), 0);
  553. pChart->GetDataGrid().SetData(row, 2, money2arraytemp.ElementAt (i*m_day+row-1), 0);
  554. }
  555. }
  556. pChart->Refresh();
  557. }
  558. }
  559. void StaffAchievementShowAll::OnRadio3()
  560. {
  561. // TODO: Add your control notification handler code here
  562. UpdateData();
  563. if(m_radio1==0)
  564. {
  565. for(int i=0; i<m_pChartArray.GetSize (); i++)
  566. {
  567. CMSChart *pChart=m_pChartArray.ElementAt (i);
  568. pChart->SetChartType(3);
  569. }
  570. }
  571. else if(m_radio1==1)
  572. {
  573. for(int i=0; i<m_pChartArray.GetSize (); i++)
  574. {
  575. CMSChart *pChart=m_pChartArray.ElementAt (i);
  576. pChart->SetChartType(1);
  577. }
  578. }
  579. else if(m_radio1==2)
  580. {
  581. for(int i=0; i<m_pChartArray.GetSize (); i++)
  582. {
  583. CMSChart *pChart=m_pChartArray.ElementAt (i);
  584. pChart->SetChartType(14);
  585. }
  586. }
  587. }
  588. void StaffAchievementShowAll::OnRadio4()
  589. {
  590. // TODO: Add your control notification handler code here
  591. OnRadio3();
  592. }
  593. void StaffAchievementShowAll::OnRadio5()
  594. {
  595. // TODO: Add your control notification handler code here
  596. OnRadio3();
  597. }
  598. void StaffAchievementShowAll::OnRadio6() //叠加
  599. {
  600. // TODO: Add your control notification handler code here
  601. UpdateData();
  602. for(int i=0; i<m_pChartArray.GetSize (); i++)
  603. {
  604. CMSChart *pChart=m_pChartArray.ElementAt (i);
  605. SetChartStyle(pChart);
  606. }
  607. KindChange();
  608. }
  609. void StaffAchievementShowAll::OnRadio7() //对比
  610. {
  611. // TODO: Add your control notification handler code here
  612. OnRadio6();
  613. }
  614. void StaffAchievementShowAll::SetChartStyle(CMSChart *pChart)
  615. {
  616. if(m_radio2==0)
  617. {
  618. pChart->SetColumnCount(1);
  619. pChart->SetColumn(1);
  620. pChart->SetColumnLabel((LPCTSTR)"全部");
  621. #ifdef MNLS_VERSION
  622. #ifdef LIM_TIME
  623. pChart->SetColumnLabel((LPCTSTR)"接单");
  624. #endif
  625. #endif
  626. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(255, 0, 0);
  627. // 线宽(对点线图有效)
  628. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetPen().SetWidth(30);
  629. // 数据点类型显示数据值的模式(对柱柱状图和点线图有效)
  630. // 0: 不显示 1: 显示在柱状图外
  631. // 2: 显示在柱状图内上方 3: 显示在柱状图内中间 4: 显示在柱状图内下方
  632. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  633. }
  634. else
  635. {
  636. pChart->SetColumnCount(2);
  637. pChart->SetColumn(1);
  638. pChart->SetColumnLabel((LPCTSTR)"前期");
  639. pChart->SetColumn(2);
  640. pChart->SetColumnLabel((LPCTSTR)"后期");
  641. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(255, 0, 0);
  642. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(0, 255, 0);
  643. // 线宽(对点线图有效)
  644. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetPen().SetWidth(30);
  645. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetPen().SetWidth(30);
  646. // 数据点类型显示数据值的模式(对柱柱状图和点线图有效)
  647. // 0: 不显示 1: 显示在柱状图外
  648. // 2: 显示在柱状图内上方 3: 显示在柱状图内中间 4: 显示在柱状图内下方
  649. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  650. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  651. }
  652. }
  653. void StaffAchievementShowAll::InitChartStyle(CMSChart *pChart)
  654. {
  655. VARIANT var;
  656. pChart->GetBackdrop().GetFill().SetStyle(1);
  657. pChart->GetBackdrop().GetFill().GetBrush().GetFillColor().Set(255, 255, 255);
  658. pChart->SetShowLegend(TRUE);
  659. pChart->SetChartType(3);
  660. // 栈模式
  661. pChart->SetStacking(FALSE);
  662. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetAuto(0); // 不自动标注Y轴刻度
  663. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetAuto(0); // 不自动标注X轴刻度
  664. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetDivisionsPerLabel(1);// 每刻度一个标注
  665. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetDivisionsPerTick(1); // 每刻度一个刻度线
  666. }
  667. void StaffAchievementShowAll::OnDestroy()
  668. {
  669. g_nAutoShowStaffAchievement=-1;
  670. for(int i=0; i<m_pChartArray.GetSize (); i++)
  671. {
  672. CMSChart *pChart=m_pChartArray.ElementAt (i);
  673. pChart->DestroyWindow ();
  674. delete pChart;
  675. }
  676. KillTimer(1);
  677. m_pChartArray.RemoveAll ();
  678. HWND wnd = ::FindWindow("Shell_TrayWnd", 0);
  679. ::ShowWindow(wnd, SW_SHOW);
  680. ::ShowCursor (1);
  681. CDialog::OnDestroy();
  682. }
  683. void StaffAchievementShowAll::OnBUTshowall()
  684. {
  685. // TODO: Add your control notification handler code here
  686. }
  687. BOOL StaffAchievementShowAll::OnInitDialog()
  688. {
  689. CDialog::OnInitDialog();
  690. //AfxMessageBox("789789");
  691. // TODO: Add extra initialization here
  692. SetWindowPos(&wndTopMost, 0, 0, 0, 0, SWP_NOSIZE | SWP_NOMOVE);
  693. BOOL bScrActive;
  694. SystemParametersInfo(SPI_GETSCREENSAVEACTIVE, 0, &bScrActive, 0);
  695. if (bScrActive)
  696. {
  697. SystemParametersInfo(SPI_SETSCREENSAVEACTIVE, FALSE, NULL, 0);
  698. }
  699. CRect rc2;
  700. GetWindowRect(rc2);
  701. ::MoveWindow(m_hWnd,0,0,g_screenwid,g_screenhei,TRUE);
  702. EnumChildWindows(m_hWnd,(WNDENUMPROC)EnumChildProc,0);
  703. GetDlgItem(IDC_STATIC1)->GetWindowRect(rc2);
  704. ScreenToClient(rc2);
  705. int wid=rc2.Width ();
  706. rc2.left =(g_screenwid-wid)/2;
  707. rc2.right =rc2.left +wid;
  708. rc2.bottom -=rc2.top;
  709. rc2.bottom +=10;
  710. rc2.top =10;
  711. GetDlgItem(IDC_STATIC1)->MoveWindow(rc2);
  712. GetWindowRect(rc2);
  713. ScreenToClient(rc2);
  714. rc2.top +=40*g_fscaley;
  715. GetDlgItem(IDC_STATIC2)->MoveWindow(rc2);
  716. rc2.top =0;
  717. rc2.bottom =41*g_fscaley;
  718. GetDlgItem(IDC_STATIC3)->MoveWindow(rc2);
  719. m_static1.SetFont (&g_titlefont);
  720. CString str;
  721. #ifdef LIM_TIME
  722. str="蒙娜丽莎员工活动期间业绩图表(从2010-01-14开始,仅接单)";
  723. #else
  724. str.Format ("%s员工 %d年%d月 业绩图表", g_title, m_year, m_month);
  725. #endif
  726. #ifndef MNLS_VERSION
  727. str.Format ("%s员工 %d年%d月 业绩图表", g_title, m_year, m_month);
  728. #endif
  729. m_static1.SetWindowText (str);
  730. m_spinyear.SetRange (1900, 3000);
  731. m_spinmonth.SetRange (1, 12);
  732. m_spinday.SetRange (1, 31);
  733. CString version = _T ("Version 1.0");
  734. m_day=AfxGetApp()->GetProfileInt (version, "rowcount", 12);
  735. UpdateData(false);
  736. SetTimer(1, 1000*60*5, NULL);
  737. SetTimer(5, 1000*8, NULL);
  738. if(AfxGetApp()->GetProfileInt (version, "autoshutdown", 12))
  739. {
  740. SetTimer(2, 1000*60*5, NULL);
  741. m_time=AfxGetApp()->GetProfileInt (version, "shutdowntime", 20);
  742. }
  743. SetTimer(3, 100, NULL);
  744. // HWND wnd = ::FindWindow("Shell_TrayWnd", 0);
  745. // ::ShowWindow(wnd, SW_HIDE);
  746. //::ShowCursor(0);
  747. return TRUE; // return TRUE unless you set the focus to a control
  748. // EXCEPTION: OCX Property Pages should return FALSE
  749. }
  750. BOOL StaffAchievementShowAll::IsCtrlDown()
  751. {
  752. short state=GetKeyState(VK_LCONTROL);
  753. BYTE sta=(BYTE)(state>>8);
  754. state=GetKeyState(VK_RCONTROL);
  755. BYTE sta2=(BYTE)(state>>8);
  756. if(sta||sta2)
  757. return 1;
  758. else
  759. return 0;
  760. }//IsShiftDown
  761. BOOL StaffAchievementShowAll::IsShiftDown()
  762. {
  763. short state=GetKeyState(VK_LSHIFT);
  764. BYTE sta=(BYTE)(state>>8);
  765. state=GetKeyState(VK_RSHIFT);
  766. BYTE sta2=(BYTE)(state>>8);
  767. state=GetKeyState(VK_F2);
  768. BYTE sta3=(BYTE)(state>>8);
  769. if(sta||sta2||sta3)
  770. return 1;
  771. else
  772. return 0;
  773. }
  774. BOOL StaffAchievementShowAll::PreTranslateMessage(MSG* pMsg)
  775. {
  776. // TODO: Add your specialized code here and/or call the base class
  777. if(pMsg->message==WM_KEYDOWN)
  778. {
  779. switch (pMsg->wParam)
  780. {
  781. case VK_RETURN:
  782. case VK_ESCAPE:
  783. if(!g_bStaffAchievementShow)
  784. CDialog::OnCancel ();
  785. else if(g_nAutoShowStaffAchievement==1)
  786. CDialog::OnCancel ();
  787. return 1;
  788. case VK_F4:
  789. if(IsCtrlDown() && IsShiftDown())
  790. CDialog::OnCancel ();
  791. else if(g_nAutoShowStaffAchievement==1)
  792. CDialog::OnCancel ();
  793. return 1;
  794. }
  795. return 1;
  796. }
  797. if(pMsg->message==WM_MOUSEMOVE)
  798. {
  799. if(g_nAutoShowStaffAchievement==1)
  800. CDialog::OnCancel ();
  801. }
  802. return CDialog::PreTranslateMessage(pMsg);
  803. }
  804. void StaffAchievementShowAll::OnTimer(UINT nIDEvent)
  805. {
  806. // TODO: Add your message handler code here and/or call default
  807. if(nIDEvent==1)
  808. DateChange();
  809. else if(nIDEvent==2)
  810. {
  811. if(m_time<=CTime::GetCurrentTime ().GetHour())
  812. {
  813. KillTimer(2);
  814. MyExitWindows();
  815. }
  816. }
  817. else if(nIDEvent==3)
  818. {
  819. KillTimer(3);
  820. m_bInit=1;
  821. DateChange();
  822. }
  823. else if(nIDEvent==5)
  824. {
  825. if(m_bInit)
  826. {
  827. m_radio3++;
  828. if(m_radio3==4)m_radio3=0;
  829. KindChange();
  830. }
  831. }
  832. }
  833. HBRUSH StaffAchievementShowAll::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
  834. {
  835. HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
  836. // TODO: Change any attributes of the DC here
  837. if (nCtlColor==CTLCOLOR_STATIC && pWnd->GetDlgCtrlID ()==IDC_STATIC1)
  838. {
  839. pDC-> SetBkMode(TRANSPARENT); //设置字体背景为透明
  840. return (HBRUSH)::GetStockObject(NULL_BRUSH); // 设置背景色
  841. }
  842. // TODO: Return a different brush if the default is not desired
  843. return hbr;
  844. }
  845. //Axis(1,var).GetValueScale().SetAu
  846. void StaffAchievementShowAll::MyExitWindows()
  847. {
  848. UINT t=EWX_SHUTDOWN|EWX_FORCE;
  849. OSVERSIONINFO osv; //定义一个操作系统信息的结构体
  850. osv.dwOSVersionInfoSize=sizeof OSVERSIONINFO;
  851. GetVersionEx(&osv); //查询当前操作系统
  852. if(osv.dwPlatformId==VER_PLATFORM_WIN32_NT) //判断是否是2000/NT
  853. {
  854. //下面为向操作系统获取权限操作
  855. HANDLE hProcess,hToken;
  856. TOKEN_PRIVILEGES Privileges;
  857. LUID luid;
  858. hProcess=GetCurrentProcess();
  859. //下面为打开当前进程对话
  860. OpenProcessToken(hProcess,TOKEN_ADJUST_PRIVILEGES,&hToken);
  861. Privileges.PrivilegeCount=1;
  862. LookupPrivilegeValue(NULL,SE_SHUTDOWN_NAME,&luid);
  863. Privileges.Privileges[0].Luid=luid;
  864. Privileges.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED;
  865. AdjustTokenPrivileges(hToken,FALSE,&Privileges,NULL,NULL,NULL);
  866. ExitWindowsEx(t,0);
  867. }
  868. else
  869. {
  870. ExitWindowsEx(t,0);//调用ExitWindowsEx关闭机器。
  871. PostQuitMessage(0);
  872. }
  873. }
  874. void StaffAchievementShowAll::OnClose()
  875. {
  876. // TODO: Add your message handler code here and/or call default
  877. // CDialog::OnClose();
  878. }