StaffAchievementShowAll.cpp 28 KB

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