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. int i = 0;
  390. CArray<CStringArray, CStringArray>m_List1arraytemp;
  391. CArray<float,float>money1arraytemp;
  392. CArray<float,float>money2arraytemp;
  393. CString str;
  394. if(m_radio3==0)
  395. {
  396. str.Format ("%s员工 %d年%d月 业绩图表-全体", g_title, m_year, m_month);
  397. m_List1arraytemp.SetSize(m_List1array.GetSize ());
  398. money1arraytemp.SetSize(m_List1array.GetSize ());
  399. money2arraytemp.SetSize(m_List1array.GetSize ());
  400. for( i=0; i<m_List1array.GetSize (); i++)
  401. {
  402. m_List1arraytemp.ElementAt (i).Copy (m_List1array.ElementAt (i));
  403. }
  404. money1arraytemp.Copy (money1array);
  405. money2arraytemp.Copy (money2array);
  406. }
  407. else if(m_radio3==1)
  408. {
  409. str.Format ("%s员工 %d年%d月 业绩图表-门市部", g_title, m_year, m_month);
  410. int size=0;
  411. for( i=0; i<m_List1array.GetSize (); i++)
  412. {
  413. if(m_List1array.ElementAt (i).ElementAt (5)=="门市部")
  414. {
  415. m_List1arraytemp.SetSize(size+1);
  416. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  417. size++;
  418. money1arraytemp.Add (money1array.ElementAt (i));
  419. money2arraytemp.Add (money2array.ElementAt (i));
  420. }
  421. }
  422. }
  423. else if(m_radio3==2)
  424. {str.Format ("%s员工 %d年%d月 业绩图表-摄影部", g_title, m_year, m_month);
  425. int size=0;
  426. for( i=0; i<m_List1array.GetSize (); i++)
  427. {
  428. if(m_List1array.ElementAt (i).ElementAt (5)=="摄影部")
  429. {
  430. m_List1arraytemp.SetSize(size+1);
  431. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  432. size++;
  433. money1arraytemp.Add (money1array.ElementAt (i));
  434. money2arraytemp.Add (money2array.ElementAt (i));
  435. }
  436. }
  437. }
  438. else if(m_radio3==3)
  439. {str.Format ("%s员工 %d年%d月 业绩图表-化妆部", g_title, m_year, m_month);
  440. int size=0;
  441. for( i=0; i<m_List1array.GetSize (); i++)
  442. {
  443. if(m_List1array.ElementAt (i).ElementAt (5)=="化妆部")
  444. {
  445. m_List1arraytemp.SetSize(size+1);
  446. m_List1arraytemp.ElementAt (size).Copy (m_List1array.ElementAt (i));
  447. size++;
  448. money1arraytemp.Add (money1array.ElementAt (i));
  449. money2arraytemp.Add (money2array.ElementAt (i));
  450. }
  451. }
  452. }
  453. CRect rc;
  454. GetDlgItem(IDC_STATIC1)->GetWindowRect (rc);
  455. ScreenToClient(rc);
  456. InvalidateRect(rc);
  457. m_static1.SetWindowText (str);
  458. int chartcount=m_List1arraytemp.GetSize ()/m_day;
  459. if(m_List1arraytemp.GetSize ()%m_day)chartcount++;
  460. if(chartcount==0)return;
  461. BOOL bAdd=0;
  462. /* int m_day=m_List1array.GetSize ()/chartcount;
  463. if(m_List1array.GetSize ()%chartcount)
  464. {
  465. m_day++;
  466. bAdd=1;
  467. }*/
  468. for( i=0; i<m_pChartArray.GetSize (); i++)
  469. {
  470. CMSChart *pChart=m_pChartArray.ElementAt (i);
  471. pChart->ShowWindow (SW_HIDE);
  472. }
  473. while(m_pChartArray.GetSize ()<chartcount)
  474. {
  475. CMSChart *pChart=new CMSChart;
  476. CRect rc(0,0,0,0);
  477. WCHAR pwchLicenseKey[] =
  478. {
  479. 0x0038, 0x0045, 0x0031, 0x0034, 0x0037, 0x0043,
  480. 0x0036, 0x0039, 0x002D, 0x0042, 0x0044, 0x0035,
  481. 0x0030, 0x002D, 0x0031, 0x0031, 0x0064, 0x0031,
  482. 0x002D, 0x0042, 0x0031, 0x0033, 0x0037, 0x002D,
  483. 0x0030, 0x0030, 0x0030, 0x0030, 0x0046, 0x0038,
  484. 0x0037, 0x0035, 0x0033, 0x0046, 0x0035, 0x0044
  485. };
  486. BSTR bstrLicense = ::SysAllocStringLen(pwchLicenseKey,
  487. sizeof(pwchLicenseKey)/sizeof(WCHAR));
  488. pChart->Create ("", WS_VISIBLE|WS_CHILD, rc, this, m_pChartArray.GetSize (), NULL, 0, bstrLicense );
  489. ::SysFreeString(bstrLicense);
  490. m_pChartArray.Add (pChart);
  491. InitChartStyle(pChart);
  492. SetChartStyle(pChart);
  493. }
  494. GetDlgItem(IDC_STATIC2)->GetWindowRect(rc);
  495. ScreenToClient(rc);
  496. int hei=rc.Height ()/chartcount;
  497. float fmaxmoney1=0;
  498. float fmaxmoney2=0; VARIANT var;
  499. for( i=0; i<chartcount; i++)
  500. {
  501. int nRowCount=min(m_day, m_List1arraytemp.GetSize ()-i*m_day);
  502. for(int row = 1; row <= nRowCount; ++row)
  503. {
  504. fmaxmoney1=max(fmaxmoney1, money1arraytemp.ElementAt (i*m_day+row-1));
  505. fmaxmoney2=max(fmaxmoney2, money2arraytemp.ElementAt (i*m_day+row-1));
  506. }
  507. }
  508. for( i=0; i<chartcount; i++)
  509. {
  510. CMSChart *pChart=m_pChartArray.ElementAt (i);
  511. rc.bottom =rc.top +hei;
  512. pChart->MoveWindow (rc);
  513. pChart->ShowWindow (SW_SHOW);
  514. rc.top +=hei;
  515. int nRowCount=min(m_day, m_List1arraytemp.GetSize ()-i*m_day);
  516. if(bAdd)
  517. {
  518. if(i==chartcount-1)nRowCount++;
  519. }
  520. pChart->SetRowCount(nRowCount);
  521. if(m_radio2==0)//叠加
  522. {
  523. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMaximum(fmaxmoney1+fmaxmoney2);
  524. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMinimum(0);
  525. for(int row = 1; row <= nRowCount; ++row)
  526. {
  527. pChart->SetRow(row);
  528. if(bAdd && i==chartcount-1 && row==nRowCount)
  529. {
  530. pChart->SetRowLabel("");
  531. pChart->GetDataGrid().SetData(row, 1, 0, 0);
  532. continue;
  533. }
  534. pChart->SetRowLabel(m_List1arraytemp.ElementAt (i*m_day+row-1).ElementAt (0));
  535. pChart->GetDataGrid().SetData(row, 1, money1arraytemp.ElementAt (i*m_day+row-1)+money2arraytemp.ElementAt (i*m_day+row-1), 0);
  536. }
  537. }
  538. else
  539. {
  540. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMaximum(max(fmaxmoney1,fmaxmoney2));
  541. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetMinimum(0);
  542. for(int row = 1; row <= nRowCount; ++row)
  543. {
  544. pChart->SetRow(row);
  545. if(bAdd && i==chartcount-1 && row==nRowCount)
  546. {
  547. pChart->SetRowLabel("");
  548. pChart->GetDataGrid().SetData(row, 1, 0, 0);
  549. pChart->GetDataGrid().SetData(row, 2, 0, 0);
  550. continue;
  551. }
  552. pChart->SetRowLabel(m_List1arraytemp.ElementAt (i*m_day+row-1).ElementAt (0));
  553. pChart->GetDataGrid().SetData(row, 1, money1arraytemp.ElementAt (i*m_day+row-1), 0);
  554. pChart->GetDataGrid().SetData(row, 2, money2arraytemp.ElementAt (i*m_day+row-1), 0);
  555. }
  556. }
  557. pChart->Refresh();
  558. }
  559. }
  560. void StaffAchievementShowAll::OnRadio3()
  561. {
  562. // TODO: Add your control notification handler code here
  563. UpdateData();
  564. if(m_radio1==0)
  565. {
  566. for(int i=0; i<m_pChartArray.GetSize (); i++)
  567. {
  568. CMSChart *pChart=m_pChartArray.ElementAt (i);
  569. pChart->SetChartType(3);
  570. }
  571. }
  572. else if(m_radio1==1)
  573. {
  574. for(int i=0; i<m_pChartArray.GetSize (); i++)
  575. {
  576. CMSChart *pChart=m_pChartArray.ElementAt (i);
  577. pChart->SetChartType(1);
  578. }
  579. }
  580. else if(m_radio1==2)
  581. {
  582. for(int i=0; i<m_pChartArray.GetSize (); i++)
  583. {
  584. CMSChart *pChart=m_pChartArray.ElementAt (i);
  585. pChart->SetChartType(14);
  586. }
  587. }
  588. }
  589. void StaffAchievementShowAll::OnRadio4()
  590. {
  591. // TODO: Add your control notification handler code here
  592. OnRadio3();
  593. }
  594. void StaffAchievementShowAll::OnRadio5()
  595. {
  596. // TODO: Add your control notification handler code here
  597. OnRadio3();
  598. }
  599. void StaffAchievementShowAll::OnRadio6() //叠加
  600. {
  601. // TODO: Add your control notification handler code here
  602. UpdateData();
  603. for(int i=0; i<m_pChartArray.GetSize (); i++)
  604. {
  605. CMSChart *pChart=m_pChartArray.ElementAt (i);
  606. SetChartStyle(pChart);
  607. }
  608. KindChange();
  609. }
  610. void StaffAchievementShowAll::OnRadio7() //对比
  611. {
  612. // TODO: Add your control notification handler code here
  613. OnRadio6();
  614. }
  615. void StaffAchievementShowAll::SetChartStyle(CMSChart *pChart)
  616. {
  617. if(m_radio2==0)
  618. {
  619. pChart->SetColumnCount(1);
  620. pChart->SetColumn(1);
  621. pChart->SetColumnLabel((LPCTSTR)"全部");
  622. #ifdef MNLS_VERSION
  623. #ifdef LIM_TIME
  624. pChart->SetColumnLabel((LPCTSTR)"接单");
  625. #endif
  626. #endif
  627. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(255, 0, 0);
  628. // 线宽(对点线图有效)
  629. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetPen().SetWidth(30);
  630. // 数据点类型显示数据值的模式(对柱柱状图和点线图有效)
  631. // 0: 不显示 1: 显示在柱状图外
  632. // 2: 显示在柱状图内上方 3: 显示在柱状图内中间 4: 显示在柱状图内下方
  633. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  634. }
  635. else
  636. {
  637. pChart->SetColumnCount(2);
  638. pChart->SetColumn(1);
  639. pChart->SetColumnLabel((LPCTSTR)"前期");
  640. pChart->SetColumn(2);
  641. pChart->SetColumnLabel((LPCTSTR)"后期");
  642. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(255, 0, 0);
  643. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetDataPoints ().GetItem(-1).GetBrush ().GetFillColor ().Set(0, 255, 0);
  644. // 线宽(对点线图有效)
  645. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetPen().SetWidth(30);
  646. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetPen().SetWidth(30);
  647. // 数据点类型显示数据值的模式(对柱柱状图和点线图有效)
  648. // 0: 不显示 1: 显示在柱状图外
  649. // 2: 显示在柱状图内上方 3: 显示在柱状图内中间 4: 显示在柱状图内下方
  650. pChart->GetPlot().GetSeriesCollection().GetItem(1).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  651. pChart->GetPlot().GetSeriesCollection().GetItem(2).GetDataPoints().GetItem(-1).GetDataPointLabel().SetLocationType(1);
  652. }
  653. }
  654. void StaffAchievementShowAll::InitChartStyle(CMSChart *pChart)
  655. {
  656. VARIANT var;
  657. pChart->GetBackdrop().GetFill().SetStyle(1);
  658. pChart->GetBackdrop().GetFill().GetBrush().GetFillColor().Set(255, 255, 255);
  659. pChart->SetShowLegend(TRUE);
  660. pChart->SetChartType(3);
  661. // 栈模式
  662. pChart->SetStacking(FALSE);
  663. pChart->GetPlot().GetAxis(1,var).GetValueScale().SetAuto(0); // 不自动标注Y轴刻度
  664. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetAuto(0); // 不自动标注X轴刻度
  665. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetDivisionsPerLabel(1);// 每刻度一个标注
  666. pChart->GetPlot().GetAxis(0,var).GetCategoryScale().SetDivisionsPerTick(1); // 每刻度一个刻度线
  667. }
  668. void StaffAchievementShowAll::OnDestroy()
  669. {
  670. g_nAutoShowStaffAchievement=-1;
  671. for(int i=0; i<m_pChartArray.GetSize (); i++)
  672. {
  673. CMSChart *pChart=m_pChartArray.ElementAt (i);
  674. pChart->DestroyWindow ();
  675. delete pChart;
  676. }
  677. KillTimer(1);
  678. m_pChartArray.RemoveAll ();
  679. HWND wnd = ::FindWindow("Shell_TrayWnd", 0);
  680. ::ShowWindow(wnd, SW_SHOW);
  681. ::ShowCursor (1);
  682. CDialog::OnDestroy();
  683. }
  684. void StaffAchievementShowAll::OnBUTshowall()
  685. {
  686. // TODO: Add your control notification handler code here
  687. }
  688. BOOL StaffAchievementShowAll::OnInitDialog()
  689. {
  690. CDialog::OnInitDialog();
  691. //AfxMessageBox("789789");
  692. // TODO: Add extra initialization here
  693. SetWindowPos(&wndTopMost, 0, 0, 0, 0, SWP_NOSIZE | SWP_NOMOVE);
  694. BOOL bScrActive;
  695. SystemParametersInfo(SPI_GETSCREENSAVEACTIVE, 0, &bScrActive, 0);
  696. if (bScrActive)
  697. {
  698. SystemParametersInfo(SPI_SETSCREENSAVEACTIVE, FALSE, NULL, 0);
  699. }
  700. CRect rc2;
  701. GetWindowRect(rc2);
  702. ::MoveWindow(m_hWnd,0,0,g_screenwid,g_screenhei,TRUE);
  703. EnumChildWindows(m_hWnd,(WNDENUMPROC)EnumChildProc,0);
  704. GetDlgItem(IDC_STATIC1)->GetWindowRect(rc2);
  705. ScreenToClient(rc2);
  706. int wid=rc2.Width ();
  707. rc2.left =(g_screenwid-wid)/2;
  708. rc2.right =rc2.left +wid;
  709. rc2.bottom -=rc2.top;
  710. rc2.bottom +=10;
  711. rc2.top =10;
  712. GetDlgItem(IDC_STATIC1)->MoveWindow(rc2);
  713. GetWindowRect(rc2);
  714. ScreenToClient(rc2);
  715. rc2.top +=40*g_fscaley;
  716. GetDlgItem(IDC_STATIC2)->MoveWindow(rc2);
  717. rc2.top =0;
  718. rc2.bottom =41*g_fscaley;
  719. GetDlgItem(IDC_STATIC3)->MoveWindow(rc2);
  720. m_static1.SetFont (&g_titlefont);
  721. CString str;
  722. #ifdef LIM_TIME
  723. str="蒙娜丽莎员工活动期间业绩图表(从2010-01-14开始,仅接单)";
  724. #else
  725. str.Format ("%s员工 %d年%d月 业绩图表", g_title, m_year, m_month);
  726. #endif
  727. #ifndef MNLS_VERSION
  728. str.Format ("%s员工 %d年%d月 业绩图表", g_title, m_year, m_month);
  729. #endif
  730. m_static1.SetWindowText (str);
  731. m_spinyear.SetRange (1900, 3000);
  732. m_spinmonth.SetRange (1, 12);
  733. m_spinday.SetRange (1, 31);
  734. CString version = _T ("Version 1.0");
  735. m_day=AfxGetApp()->GetProfileInt (version, "rowcount", 12);
  736. UpdateData(false);
  737. SetTimer(1, 1000*60*5, NULL);
  738. SetTimer(5, 1000*8, NULL);
  739. if(AfxGetApp()->GetProfileInt (version, "autoshutdown", 12))
  740. {
  741. SetTimer(2, 1000*60*5, NULL);
  742. m_time=AfxGetApp()->GetProfileInt (version, "shutdowntime", 20);
  743. }
  744. SetTimer(3, 100, NULL);
  745. // HWND wnd = ::FindWindow("Shell_TrayWnd", 0);
  746. // ::ShowWindow(wnd, SW_HIDE);
  747. //::ShowCursor(0);
  748. return TRUE; // return TRUE unless you set the focus to a control
  749. // EXCEPTION: OCX Property Pages should return FALSE
  750. }
  751. BOOL StaffAchievementShowAll::IsCtrlDown()
  752. {
  753. short state=GetKeyState(VK_LCONTROL);
  754. BYTE sta=(BYTE)(state>>8);
  755. state=GetKeyState(VK_RCONTROL);
  756. BYTE sta2=(BYTE)(state>>8);
  757. if(sta||sta2)
  758. return 1;
  759. else
  760. return 0;
  761. }//IsShiftDown
  762. BOOL StaffAchievementShowAll::IsShiftDown()
  763. {
  764. short state=GetKeyState(VK_LSHIFT);
  765. BYTE sta=(BYTE)(state>>8);
  766. state=GetKeyState(VK_RSHIFT);
  767. BYTE sta2=(BYTE)(state>>8);
  768. state=GetKeyState(VK_F2);
  769. BYTE sta3=(BYTE)(state>>8);
  770. if(sta||sta2||sta3)
  771. return 1;
  772. else
  773. return 0;
  774. }
  775. BOOL StaffAchievementShowAll::PreTranslateMessage(MSG* pMsg)
  776. {
  777. // TODO: Add your specialized code here and/or call the base class
  778. if(pMsg->message==WM_KEYDOWN)
  779. {
  780. switch (pMsg->wParam)
  781. {
  782. case VK_RETURN:
  783. case VK_ESCAPE:
  784. if(!g_bStaffAchievementShow)
  785. CDialog::OnCancel ();
  786. else if(g_nAutoShowStaffAchievement==1)
  787. CDialog::OnCancel ();
  788. return 1;
  789. case VK_F4:
  790. if(IsCtrlDown() && IsShiftDown())
  791. CDialog::OnCancel ();
  792. else if(g_nAutoShowStaffAchievement==1)
  793. CDialog::OnCancel ();
  794. return 1;
  795. }
  796. return 1;
  797. }
  798. if(pMsg->message==WM_MOUSEMOVE)
  799. {
  800. if(g_nAutoShowStaffAchievement==1)
  801. CDialog::OnCancel ();
  802. }
  803. return CDialog::PreTranslateMessage(pMsg);
  804. }
  805. void StaffAchievementShowAll::OnTimer(UINT nIDEvent)
  806. {
  807. // TODO: Add your message handler code here and/or call default
  808. if(nIDEvent==1)
  809. DateChange();
  810. else if(nIDEvent==2)
  811. {
  812. if(m_time<=CTime::GetCurrentTime ().GetHour())
  813. {
  814. KillTimer(2);
  815. MyExitWindows();
  816. }
  817. }
  818. else if(nIDEvent==3)
  819. {
  820. KillTimer(3);
  821. m_bInit=1;
  822. DateChange();
  823. }
  824. else if(nIDEvent==5)
  825. {
  826. if(m_bInit)
  827. {
  828. m_radio3++;
  829. if(m_radio3==4)m_radio3=0;
  830. KindChange();
  831. }
  832. }
  833. }
  834. HBRUSH StaffAchievementShowAll::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor)
  835. {
  836. HBRUSH hbr = CDialog::OnCtlColor(pDC, pWnd, nCtlColor);
  837. // TODO: Change any attributes of the DC here
  838. if (nCtlColor==CTLCOLOR_STATIC && pWnd->GetDlgCtrlID ()==IDC_STATIC1)
  839. {
  840. pDC-> SetBkMode(TRANSPARENT); //设置字体背景为透明
  841. return (HBRUSH)::GetStockObject(NULL_BRUSH); // 设置背景色
  842. }
  843. // TODO: Return a different brush if the default is not desired
  844. return hbr;
  845. }
  846. //Axis(1,var).GetValueScale().SetAu
  847. void StaffAchievementShowAll::MyExitWindows()
  848. {
  849. UINT t=EWX_SHUTDOWN|EWX_FORCE;
  850. OSVERSIONINFO osv; //定义一个操作系统信息的结构体
  851. osv.dwOSVersionInfoSize=sizeof OSVERSIONINFO;
  852. GetVersionEx(&osv); //查询当前操作系统
  853. if(osv.dwPlatformId==VER_PLATFORM_WIN32_NT) //判断是否是2000/NT
  854. {
  855. //下面为向操作系统获取权限操作
  856. HANDLE hProcess,hToken;
  857. TOKEN_PRIVILEGES Privileges;
  858. LUID luid;
  859. hProcess=GetCurrentProcess();
  860. //下面为打开当前进程对话
  861. OpenProcessToken(hProcess,TOKEN_ADJUST_PRIVILEGES,&hToken);
  862. Privileges.PrivilegeCount=1;
  863. LookupPrivilegeValue(NULL,SE_SHUTDOWN_NAME,&luid);
  864. Privileges.Privileges[0].Luid=luid;
  865. Privileges.Privileges[0].Attributes=SE_PRIVILEGE_ENABLED;
  866. AdjustTokenPrivileges(hToken,FALSE,&Privileges,NULL,NULL,NULL);
  867. ExitWindowsEx(t,0);
  868. }
  869. else
  870. {
  871. ExitWindowsEx(t,0);//调用ExitWindowsEx关闭机器。
  872. PostQuitMessage(0);
  873. }
  874. }
  875. void StaffAchievementShowAll::OnClose()
  876. {
  877. // TODO: Add your message handler code here and/or call default
  878. // CDialog::OnClose();
  879. }