mfc程序設(shè)計(jì)課程設(shè)計(jì)---考勤系統(tǒng)_第1頁(yè)
已閱讀1頁(yè),還剩45頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p><b>  第1章 系統(tǒng)設(shè)計(jì)</b></p><p>  1.1 系統(tǒng)功能分析</p><p>  考勤管理系統(tǒng)的主要功能如下:</p><p>  1.上班時(shí)間的設(shè)定。上下班時(shí)間相對(duì)固定,可以保存在客戶端的設(shè)置文件中。</p><p>  2.員工出入單位的情況記錄.出入情況主要由考勤機(jī)來(lái)記錄,但是

2、需要設(shè)置人工添加的功能,以備特殊情況的處理。</p><p>  3.請(qǐng)假、加班和出差情況的記錄。</p><p>  4.每個(gè)月底進(jìn)行整月的出勤情況統(tǒng)計(jì)。</p><p>  1.2 系統(tǒng)功能模塊設(shè)計(jì)</p><p>  根據(jù)系統(tǒng)功能的要求,可以將系統(tǒng)分解成幾個(gè)功能模塊來(lái)分別設(shè)計(jì),功能模塊圖如圖1-1所示。</p><p

3、>  圖1-1人事管理功能模塊圖</p><p><b>  1.3 數(shù)據(jù)流程圖</b></p><p>  出勤的原始記錄主要來(lái)源于考勤機(jī),并且以固定格式保存在數(shù)據(jù)庫(kù)中。考勤管理系統(tǒng)的任務(wù)就是處理這些數(shù)據(jù)。</p><p><b>  第2章 數(shù)據(jù)庫(kù)設(shè)計(jì)</b></p><p>  2.1

4、數(shù)據(jù)庫(kù)需求分析 </p><p>  根據(jù)數(shù)據(jù)流程,可以列出以下管理系統(tǒng)所需的數(shù)據(jù)項(xiàng)和數(shù)據(jù)結(jié)構(gòu)。</p><p>  (1) 出勤記錄:記錄號(hào)、員工、出入情況和出入時(shí)間,如圖2-1。</p><p>  (2) 月度考勤統(tǒng)計(jì):記錄號(hào)、員工、年月、累計(jì)正常工作時(shí)間、累計(jì)請(qǐng)假時(shí)間、累計(jì)加班時(shí)間、累計(jì)出差時(shí)間、遲到次數(shù)、早退次數(shù)和礦工次數(shù),如圖2-2。</p>

5、<p>  (3) 請(qǐng)假記錄:記錄號(hào)、員工、假期起始時(shí)間/結(jié)束時(shí)間和請(qǐng)假緣由,如圖2-3。</p><p>  (4) 加班記錄:記錄號(hào)、員工、加班時(shí)間長(zhǎng)度和日期,如圖2-4。</p><p>  (5) 出差記錄:記錄號(hào)、員工、出差起始時(shí)間/結(jié)束時(shí)間和具體描述,如圖2-5。</p><p>  所需的外部數(shù)據(jù)支持:</p><p&

6、gt;  (1) 人員信息:?jiǎn)T工號(hào)、密碼、權(quán)限、姓名、部門(mén)、和當(dāng)前狀態(tài)等。</p><p>  (2) 部門(mén)設(shè)置:部門(mén)編號(hào)、名稱等。</p><p>  圖2-1 出勤記錄表</p><p>  圖2-2 月度考勤統(tǒng)計(jì)表</p><p>  圖2-3 請(qǐng)假記錄表</p><p>  圖2-4 加班記錄表&l

7、t;/p><p>  圖2-5 出差記錄表</p><p>  第3章 各個(gè)功能模塊的創(chuàng)建</p><p>  3.1 生成程序框架</p><p>  本系統(tǒng)的應(yīng)用程序使用MFC ODBC的方法開(kāi)發(fā),采用Dialog based 的應(yīng)用框架,如圖3-1為。由一個(gè)對(duì)話框和若干個(gè)功能對(duì)話框組成。</p><p>  為了使

8、用ODBC類,需要在stdafx.h中加入#include”afxdb.h”頭文件。本程序需要連接一個(gè)數(shù)據(jù)庫(kù),所以定義了一個(gè)CDatabase型的全局變量db,用于打開(kāi)和關(guān)閉數(shù)據(jù)庫(kù)。數(shù)據(jù)庫(kù)的打開(kāi)在登錄認(rèn)證數(shù)據(jù)庫(kù)中。</p><p>  為了訪問(wèn)數(shù)據(jù)庫(kù)中的表格,本程序從CRecordset中派生了8個(gè)類,分別用于封裝所需訪問(wèn)的表格,如表3-1。通過(guò)訪問(wèn)成員變量可以訪問(wèn)當(dāng)前記錄中字段的值。</p>&l

9、t;p>  表3-1 CRecordset派生類對(duì)應(yīng)的表格</p><p>  3.2 登錄認(rèn)證對(duì)話框</p><p>  登錄窗口如圖3-2所示,包括3個(gè)輸入框和2個(gè)按鈕。主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-4。</p><p>  圖3-2 登錄窗口</p><p>  表3-4 登錄認(rèn)證對(duì)話框控件列表

10、</p><p>  對(duì)IDOK的點(diǎn)擊加登錄代碼。</p><p>  CLoginDlg類需要用到加密類,本程序使用的是CCrypt類。在cpp文件的開(kāi)頭加入#include”Crypt.h”一行。</p><p>  另外,為了使用全局?jǐn)?shù)據(jù)庫(kù)變量db,需要在cpp文件開(kāi)頭加入以下語(yǔ)句:</p><p>  Extern CDatabase

11、 db;</p><p>  用戶認(rèn)證過(guò)程在“登錄”按鈕的處理函數(shù)中:代碼見(jiàn)附錄【1】</p><p>  為了運(yùn)行登錄認(rèn)證對(duì)話框,還需在App類的InitInstance()函數(shù)中在顯示主對(duì)話框前加入以下代碼:</p><p>  CLoginDlg LoginDlg;</p><p>  If(LoginDlg.DoModal()!=ID

12、OK)return FALSE;</p><p>  3.3主對(duì)話框窗口的設(shè)計(jì)</p><p>  用戶登錄后即顯示主對(duì)話框,如圖3-5所示。包括5個(gè)按鈕??丶斜砣绫?-6。</p><p><b>  圖3-5 主對(duì)話框</b></p><p>  表3-6 主對(duì)話框控件列表</p><p

13、>  在CAttendanceDlg 中定義以下成員變量:</p><p><b>  Public:</b></p><p>  CBrush m_brush;</p><p>  CStatDlg* m_pStatDlg;</p><p>  CAttDlg* m_pAttDlg;</p><

14、;p>  CFont m_font;</p><p>  對(duì)話框初始化時(shí)需要改變標(biāo)題字體大小,因此在OnInitDialog()中加入以下代碼:</p><p>  // 改變標(biāo)題字體大小</p><p>  LOGFONT LogFont;</p><p>  GetFont()->GetLogFont(&LogFont

15、);</p><p>  LogFont.lfHeight+=LogFont.lfHeight/2;</p><p>  LogFont.lfWidth+=LogFont.lfWidth/2;</p><p>  m_font.CreateFontIndirect(&LogFont);</p><p>  GetDlgItem(IDC

16、_STATIC_HEAD)->SetFont(&m_font);</p><p>  為了美觀起見(jiàn),還插入了背景圖片,通過(guò)Ctrl+R引入圖片后,在OnPaint()中的條件語(yǔ)句的else()中添加下列代碼:見(jiàn)附錄【2】</p><p>  對(duì)話框中5個(gè)按鈕的功能主要是顯示相應(yīng)的功能對(duì)話框。給按鈕的BN_CLICKED事件的處理和退出代碼見(jiàn)附錄【3】。</p>

17、<p>  3.4上班時(shí)間設(shè)置對(duì)話框的創(chuàng)建</p><p>  此對(duì)話框用于設(shè)置上下班時(shí)間,布局如圖3-7.所示。主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-8所示。</p><p>  圖3-7 時(shí)間設(shè)置對(duì)話框</p><p>  表3-8 時(shí)間設(shè)置對(duì)話框控件列表</p><p>  一般上下班時(shí)間是相對(duì)固定的,而且需要在統(tǒng)計(jì)

18、是頻繁使用,所以不需要保存在數(shù)據(jù)庫(kù)中,因此采用標(biāo)準(zhǔn)的INI設(shè)置文件來(lái)保存這些數(shù)據(jù)。</p><p>  首先,在構(gòu)造函數(shù)中初始化4個(gè)時(shí)間的取值:</p><p>  CWorkplanDlg::CWorkplanDlg(CWnd* pParent /*=NULL*/)</p><p>  : CDialog(CWorkplanDlg::IDD, pParent)&l

19、t;/p><p><b>  {</b></p><p>  m_Time1 = 0;</p><p>  m_Time2 = 0;</p><p>  m_Time3 = 0;</p><p>  m_Time4 = 0;</p><p><b>  }</b

20、></p><p>  “修改”按鈕的BN_CLICKED事件處理用于保存當(dāng)前的設(shè)置:代碼見(jiàn)附錄【4】</p><p>  “恢復(fù)默認(rèn)設(shè)置”按鈕的BN_CLICKED事件處理程序用于恢復(fù)初始設(shè)置。這個(gè)函數(shù)同時(shí)被OnInitDialog()函數(shù)應(yīng)用,以實(shí)現(xiàn)初始化操作,代碼見(jiàn)附錄【5】</p><p>  3.5 考勤修改對(duì)話框的創(chuàng)建</p><

21、;p>  考勤修改對(duì)話框主要用來(lái)人工輸入出勤情況。在考勤機(jī)出現(xiàn)問(wèn)題是,它可以及時(shí)彌補(bǔ)數(shù)據(jù)。同時(shí)加班、請(qǐng)假、出差的記錄都是需要通過(guò)這個(gè)對(duì)話框來(lái)輸入。對(duì)話框布局如圖3-9所示。為了區(qū)分不同的輸入,在對(duì)話框中嵌入了CPropertySheet和4個(gè)CPropertyPage,這4個(gè)CPropertyPage分別放置出勤、加班、請(qǐng)假和出差記錄的修改界面,而共用一個(gè)查詢條件設(shè)置。圖3-9下方空白處用于放置CPropertySheet和4個(gè)C

22、PropertyPage。對(duì)話框中的主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-10所示。</p><p>  圖3-9 考勤修改對(duì)話框</p><p>  表3-10 考勤修改對(duì)話框控件列表</p><p>  為了使用CPropertySheet和CPropertyPage,需要在類定義中加入以下變量:</p><p>  CPage

23、1 m_Page1;</p><p>  CPage2 m_Page2;</p><p>  CPage3 m_Page3;</p><p>  CPage4 m_Page4;</p><p>  CPropertySheet m_Sheet;</p><p>  然后在OnInitDialog中添加以下代碼:見(jiàn)附錄【

24、6】</p><p>  當(dāng)輸入員工號(hào)時(shí),需要檢索員工姓名,以確定設(shè)置的條件有效。加入IDC_EDT_SEEKPERSONID的EN_CHANGE消息,函數(shù)如下:見(jiàn)附錄【7】</p><p>  3.6 修改出勤記錄屬性頁(yè)的創(chuàng)建</p><p>  加入一個(gè)對(duì)話框資源,將其封裝設(shè)為從CPropertyPage繼承的CPage1類。對(duì)話框布局如圖3-11所示。對(duì)話框中

25、主要控件、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-12所示。</p><p>  圖3-11 修改出勤記錄屬性頁(yè)</p><p>  表3-12 修改出勤記錄屬性頁(yè)控件列表</p><p>  界面初始化操作如下:見(jiàn)附錄【8】</p><p>  為了方便更新列表框內(nèi)容,編寫(xiě)UpdateList()函數(shù),調(diào)用此函數(shù)可使列表框顯示給定的數(shù)據(jù)表格。見(jiàn)附

26、錄【9】</p><p>  當(dāng)輸入部門(mén)編號(hào)時(shí),自動(dòng)檢索部門(mén)名稱。見(jiàn)附錄【10】</p><p>  輸入員工號(hào)是,檢索相應(yīng)信息。見(jiàn)附錄【11】</p><p>  添加部門(mén)和全體員工出勤記錄的過(guò)程最終可分解為添加單個(gè)員工記錄的過(guò)程。設(shè)置以下子程序是為了避免程序的重復(fù)。見(jiàn)附錄【12】</p><p>  添加記錄的3個(gè)按鈕處理程序分別調(diào)用以上

27、的函數(shù)。見(jiàn)附錄【13】</p><p>  “刪除所選紀(jì)錄”按鈕用于刪除列表中當(dāng)前所選紀(jì)錄。見(jiàn)附錄【14】</p><p>  “按條件檢索”按鈕用于激活檢索條件。見(jiàn)附錄【15】</p><p>  3.7 加班記錄屬性頁(yè)的創(chuàng)建</p><p>  加班記錄屬性頁(yè)的創(chuàng)建與考勤修改屬性頁(yè)類似,封裝類設(shè)為從CPropertyPage繼承的Cpag

28、e2類。為了將它們放入同一個(gè)Property Sheet,需將二者大小設(shè)為一致。界面設(shè)計(jì)如圖3-13,主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-14所示。</p><p>  圖3-13 加班記錄屬性頁(yè)</p><p>  表3-14 加班記錄屬性頁(yè)控件列表</p><p>  初始化代碼如下:見(jiàn)附錄【16】</p><p>  Upd

29、ateList()完成列表框數(shù)據(jù)顯示工作,代碼如下:見(jiàn)附錄【17】</p><p>  當(dāng)輸入員工號(hào)時(shí),需要檢索員工姓名,以確認(rèn)輸入是否正確。見(jiàn)附錄【18】</p><p>  “添加”按鈕用于完成紀(jì)錄的添加操作。見(jiàn)附錄【19】</p><p>  3.8 請(qǐng)假記錄屬性頁(yè)的創(chuàng)建</p><p>  請(qǐng)假記錄屬性頁(yè)封裝類為從CPropertyP

30、age繼承的Cpage3類。界面設(shè)計(jì)如圖3-15,主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-16所示。</p><p>  圖3-15 請(qǐng)假記錄屬性頁(yè)</p><p>  表3-16 請(qǐng)假記錄屬性頁(yè)控件列表</p><p>  界面的初始化、列表框的更新、員工姓名的檢索、刪除所選記錄和條件檢索的功能與前面加班記錄相應(yīng)的功能類似,代碼稍作修改即可。添加記錄的代碼

31、如下:見(jiàn)附錄【20】</p><p>  3.9 出差記錄屬性頁(yè)的創(chuàng)建</p><p>  請(qǐng)假記錄屬性頁(yè)封裝類為從CPropertyPage繼承的Cpage4類。界面設(shè)計(jì)如圖3-17,主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-18所示。</p><p>  圖3-17 出差記錄屬性頁(yè)</p><p>  表3-18 出差記錄屬性頁(yè)控

32、件列表</p><p>  出差記錄與請(qǐng)假記錄的功能基本一致。</p><p>  3.10 考勤統(tǒng)計(jì)對(duì)話框的創(chuàng)建</p><p>  考勤統(tǒng)計(jì)對(duì)話框界面設(shè)計(jì)如圖3-19所示,主要控件類型、ID和對(duì)應(yīng)的成員變量及說(shuō)明如表3-20所示。</p><p>  圖3-19 考勤統(tǒng)計(jì)對(duì)話框</p><p>  表3-20

33、考勤統(tǒng)計(jì)控件列表</p><p>  列表框的初始化和數(shù)據(jù)更新和前面類似。初始化時(shí)設(shè)置缺省時(shí)間,修改構(gòu)造函數(shù)如下:見(jiàn)附錄【21】</p><p>  當(dāng)輸入員工號(hào)時(shí),檢索員工姓名,用于確認(rèn)輸入。見(jiàn)附錄【22】</p><p>  “檢索”按鈕的處理代碼如下:見(jiàn)附錄【23】</p><p>  統(tǒng)計(jì)過(guò)程主要是記錄判斷過(guò)程,代碼如下:見(jiàn)附錄【24

34、】</p><p><b>  第4章 系統(tǒng)的實(shí)現(xiàn)</b></p><p>  各對(duì)話框設(shè)計(jì)完成后,運(yùn)行程序,查看結(jié)果。系統(tǒng)啟動(dòng)后,首先出現(xiàn)的是登錄對(duì)話框,如圖4-1。</p><p>  圖4-1 登錄對(duì)話框</p><p>  在輸入用戶名和密碼并登錄后,系統(tǒng)會(huì)從數(shù)據(jù)庫(kù)中提取相應(yīng)記錄,來(lái)判斷用戶和密碼權(quán)限是否匹配,如

35、果不匹配,會(huì)彈出對(duì)話框提示,如圖4-2。</p><p>  圖4-2 認(rèn)證失敗提示信息</p><p>  登錄成功后,會(huì)出現(xiàn)如圖4-3所示的主對(duì)話框。</p><p><b>  圖4-3 主對(duì)話框</b></p><p>  單擊對(duì)話框中的各個(gè)按鈕即可顯示相應(yīng)的對(duì)話框。其中“重新登錄”用于回到登錄對(duì)話框,并且會(huì)隱藏

36、主對(duì)話框;“退出”按鈕直接退出應(yīng)用程序;“設(shè)置”按鈕用來(lái)彈出上下班時(shí)間設(shè)置對(duì)話框;“出勤記錄”按鈕用來(lái)彈出考勤修改對(duì)話框;“統(tǒng)計(jì)”用來(lái)彈出統(tǒng)計(jì)對(duì)話框。</p><p>  圖4-4顯示的是單擊“設(shè)置”按鈕彈出的時(shí)間設(shè)置對(duì)話框。</p><p>  圖4-4 時(shí)間設(shè)置對(duì)話框</p><p>  考勤修改窗口如圖4-5所示。這個(gè)對(duì)話框包括4個(gè)記錄修改功能,分別對(duì)應(yīng)出勤記

37、錄、加班記錄、請(qǐng)假記錄和出差記錄。檢索條件包括時(shí)間范圍和員工,可以根據(jù)需要任意選擇。如圖4-6。</p><p>  圖4-5 考勤修改窗口</p><p>  圖4-6 記錄檢索條件</p><p>  其中出勤記錄的添加時(shí)為了在考勤機(jī)出現(xiàn)故障是,可以人工添加,保證記錄的完整性。設(shè)置的全體員工、部門(mén)員工和單個(gè)員工出勤情況的輸入功能實(shí)現(xiàn)了批量輸入,下面的進(jìn)度條可以

38、顯示進(jìn)度,如圖4-7所示。</p><p>  圖4-7 添加修改出勤記錄對(duì)話框</p><p>  加班記錄對(duì)話框用于添加員工加班的日期和小時(shí)數(shù),如圖4-8。</p><p>  圖4-8 加班記錄對(duì)話框</p><p>  請(qǐng)假記錄和出差記錄布局和功能基本相似,主要用于記錄請(qǐng)假和出差的時(shí)間段和緣由,備注等。如圖4-9和4-10,分別為請(qǐng)

39、假記錄和出差記錄的對(duì)話框。</p><p>  圖4-9 請(qǐng)假記錄對(duì)話框</p><p>  圖4-10 出差記錄對(duì)話框</p><p>  考勤統(tǒng)計(jì)對(duì)話框有月度統(tǒng)計(jì)、檢索條件和記錄列表3部分。月度統(tǒng)計(jì)需要設(shè)定統(tǒng)計(jì)的時(shí)間范圍。檢索條件部分則用于快速地位記錄,便于查詢和修改,如圖4-11所示。</p><p>  圖4-11 考勤統(tǒng)計(jì)對(duì)話框&l

40、t;/p><p><b>  第5章 結(jié)束語(yǔ)</b></p><p>  通過(guò)本次課程設(shè)計(jì)的實(shí)踐,不僅熟悉了對(duì)Visual C++6.0程序設(shè)計(jì)工具的操作,加深了對(duì)Access2003的認(rèn)識(shí),還學(xué)到了有關(guān)考勤管理系統(tǒng)開(kāi)發(fā)方面的知識(shí)。體會(huì)了軟件開(kāi)發(fā)的基本過(guò)程,同時(shí)也學(xué)會(huì)了如何修改,調(diào)試程序,如何將各個(gè)模塊的功能進(jìn)行合理的整合和調(diào)整,如何充分利用各方資源,優(yōu)化和完善程序。提

41、高了綜合應(yīng)用計(jì)算機(jī)語(yǔ)言的各種編程知識(shí)和技巧進(jìn)行程序設(shè)計(jì)的能力。</p><p>  在老師和同學(xué)的指導(dǎo)和幫助下,通過(guò)一個(gè)多月的設(shè)計(jì)和開(kāi)發(fā),考勤管理系統(tǒng)基本完成,能夠?qū)崿F(xiàn)對(duì)員工出勤情況的記錄和統(tǒng)計(jì),以及按時(shí)間或員工號(hào)的各類查詢。</p><p>  但由于時(shí)間倉(cāng)促和自己水平所限,本系統(tǒng)不可避免的還存在著一些缺陷,比如在權(quán)限的管理以及美觀方面做的還不好,還要其他方面還請(qǐng)老師和同學(xué)提寶貴意見(jiàn),不

42、勝感激。</p><p><b>  參考文獻(xiàn)</b></p><p>  [1] 李閩溟,吳繼剛,周學(xué)明.Visual C++6.0數(shù)據(jù)庫(kù)系統(tǒng)開(kāi)發(fā)實(shí)例導(dǎo)航[M].北京:人民郵電出版社.2002:151-180.</p><p>  [2] 侯奇峰,李曉華,李莎.Visual C++數(shù)據(jù)庫(kù)通用模塊開(kāi)發(fā)與系統(tǒng)移植[M].北京:清華大學(xué)出版社.

43、2007:207-405.</p><p>  [3] 王珊,薩師煊.數(shù)據(jù)庫(kù)系統(tǒng)概論(第四版)[M]。北京:高等教育出版社.2008:263-330.</p><p>  [4] 馬石安,魏文平.Visual C++程序設(shè)計(jì)與應(yīng)用教程[M].北京:清華大學(xué)出版社.2007.</p><p>  附錄(主要程序代碼)</p><p>  【

44、1】void CLoginDlg::OnOK() </p><p><b>  {</b></p><p>  BOOL bLogin=FALSE;</p><p>  CString strPasswd,strCount;</p><p>  UpdateData(); // 更新數(shù)據(jù)變量</p><

45、;p>  if(!db.Open(m_strDSN)) return; // 連接數(shù)據(jù)庫(kù)</p><p>  strPasswd=CCrypt::Encrypt(m_strPasswd, 123); // 加密密碼</p><p>  CRecordset rs(&db); // 構(gòu)造記錄集</p><p>  rs.Open(CRecordset::

46、forwardOnly,</p><p>  "select COUNT(ID) as COUNT from PERSON where ID='" + m_strUser</p><p>  +"' and PASSWD='" + strPasswd + "' and AUTHORITY='4'

47、;"); // 執(zhí)行查詢</p><p>  rs.GetFieldValue("COUNT",strCount);</p><p>  rs.Close(); // 關(guān)閉數(shù)據(jù)集</p><p>  if(strCount=="1") // 判斷認(rèn)證是否通過(guò)</p><p><b>

48、  {</b></p><p>  EndDialog(IDOK); // 結(jié)束對(duì)話框,返回IDOK</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>

49、;  MessageBox("請(qǐng)輸入正確的用戶名和密碼,注意大小寫(xiě)!","認(rèn)證失敗");</p><p>  db.Close(); // 關(guān)閉數(shù)據(jù)庫(kù)</p><p><b>  }</b></p><p><b>  }</b></p><p>  【2】

50、 CPaintDC dc(this); </p><p>  CRect rect; </p><p>  GetClientRect(&rect); </p><p>  CDC dcMem; </p><p>  dcMem.CreateCompatibleDC(&dc); </p&g

51、t;<p>  CBitmap bmpBackground; </p><p>  bmpBackground.LoadBitmap(IDB_BITMAP); </p><p>  //IDB_BITMAP是圖對(duì)應(yīng)的ID </p><p>  BITMAP bitmap; </p><p>  bmpBa

52、ckground.GetBitmap(&bitmap); </p><p>  CBitmap *pbmpOld=dcMem.SelectObject(&bmpBackground); </p><p>  dc.StretchBlt(0,0,rect.Width(),rect.Height(),&dcMem,0,0, </p><

53、;p>  bitmap.bmWidth,bitmap.bmHeight,SRCCOPY); </p><p>  【3】void CAttendanceDlg::OnBtnExit() </p><p><b>  {</b></p><p>  EndDialog(IDCANCEL); // 退出主對(duì)話框,關(guān)閉程序</p>

54、;<p><b>  }</b></p><p>  void CAttendanceDlg::OnBtnRelogin() </p><p><b>  {</b></p><p><b>  // 隱藏主對(duì)話框</b></p><p>  ShowWindow

55、(SW_HIDE);</p><p>  // 顯示登錄對(duì)話框</p><p>  CLoginDlg dlg;</p><p>  if(dlg.DoModal()==IDOK)</p><p><b>  {</b></p><p>  ShowWindow(SW_SHOW); // 顯示對(duì)話

56、框</p><p><b>  }</b></p><p>  else EndDialog(IDCANCEL); // 退出程序</p><p><b>  }</b></p><p>  void CAttendanceDlg::OnBtnConfig() </p><p&g

57、t;<b>  {</b></p><p>  // 顯示工作時(shí)間設(shè)置對(duì)話框</p><p>  CWorkplanDlg dlg;</p><p>  dlg.DoModal();</p><p><b>  }</b></p><p>  void CAttendance

58、Dlg::OnBtnRecord() </p><p><b>  {</b></p><p>  // 非模態(tài)顯示出勤記錄對(duì)話框</p><p>  if(!m_pAttDlg) // 指針為空,創(chuàng)建對(duì)話框</p><p><b>  {</b></p><p>  m_p

59、AttDlg=new CAttDlg();</p><p>  m_pAttDlg->Create(IDD_DLG_ATTENDANCE, this);</p><p>  m_pAttDlg->ShowWindow(SW_SHOW);</p><p><b>  }</b></p><p>  else /

60、/ 對(duì)話框已創(chuàng)建</p><p>  m_pAttDlg->ShowWindow(SW_SHOW); // 顯示窗口</p><p><b>  }</b></p><p>  void CAttendanceDlg::OnBtnStatistics() </p><p><b>  {</b>

61、;</p><p>  // 非模態(tài)顯示考勤統(tǒng)計(jì)對(duì)話框</p><p>  if(!m_pStatDlg) // 指針為空,創(chuàng)建對(duì)話框</p><p><b>  {</b></p><p>  m_pStatDlg=new CStatDlg();</p><p>  m_pStatDlg->

62、;Create(IDD_DLG_STAT, this);</p><p>  m_pStatDlg->ShowWindow(SW_SHOW);</p><p><b>  }</b></p><p>  else // 對(duì)話框已創(chuàng)建</p><p>  m_pStatDlg->ShowWindow(SW_SH

63、OW); // 顯示窗口</p><p><b>  }</b></p><p>  【4】void CWorkplanDlg::OnWorkplanModify() </p><p><b>  {</b></p><p>  CString strFileName=".\\workpl

64、an.ini"; // INI文件名</p><p>  UpdateData(); // 更新數(shù)據(jù)</p><p>  WritePrivateProfileString("WorkPlan", "Time1",</p><p>  m_Time1.Format("%H:%M:%S"), str

65、FileName);</p><p>  WritePrivateProfileString("WorkPlan", "Time2",</p><p>  m_Time2.Format("%H:%M:%S"), strFileName);</p><p>  WritePrivateProfileStrin

66、g("WorkPlan", "Time3",</p><p>  m_Time3.Format("%H:%M:%S"), strFileName);</p><p>  WritePrivateProfileString("WorkPlan", "Time4",</p><

67、;p>  m_Time4.Format("%H:%M:%S"), strFileName);</p><p><b>  }</b></p><p>  【5】void CWorkplanDlg::OnWorkplanReset() </p><p><b>  {</b></p>

68、<p>  CString cstr[4];</p><p>  char str[4][9];</p><p><b>  int i;</b></p><p>  int nHour,nMinute,nSecond; // 時(shí),分,秒</p><p>  CString strFileName="

69、.\\workplan.ini"; // INI文件名</p><p>  // 讀取INI文件</p><p>  GetPrivateProfileString("WorkPlan", "Time1", "08:00:00", str[0], 9, strFileName);</p><p>

70、  GetPrivateProfileString("WorkPlan", "Time2", "12:00:00", str[1], 9, strFileName);</p><p>  GetPrivateProfileString("WorkPlan", "Time3", "14:00:00"

71、;, str[2], 9, strFileName);</p><p>  GetPrivateProfileString("WorkPlan", "Time4", "18:00:00", str[3], 9, strFileName);</p><p>  for(i=0; i<4; i++) cstr[i]=str[i]

72、;</p><p>  // 定義四個(gè)時(shí)間變量并初始化為INI文件中的值</p><p>  sscanf(cstr[0].Left(2), "%d", &nHour);// 得到時(shí)</p><p>  sscanf(cstr[0].Mid(3,2), "%d", &nMinute);// 得到分<

73、/p><p>  sscanf(cstr[0].Mid(6,2), "%d", &nSecond);// 得到秒</p><p>  CTime t1(2002,1,1,nHour,nMinute,nSecond);// 初始化t1</p><p>  sscanf(cstr[1].Left(2), "%d", &am

74、p;nHour);// 得到時(shí)</p><p>  sscanf(cstr[1].Mid(3,2), "%d", &nMinute);// 得到分</p><p>  sscanf(cstr[1].Mid(6,2), "%d", &nSecond);// 得到秒</p><p>  CTime t2(2

75、002,1,1,nHour,nMinute,nSecond);// 初始化t2</p><p>  sscanf(cstr[2].Left(2), "%d", &nHour);// 得到時(shí)</p><p>  sscanf(cstr[2].Mid(3,2), "%d", &nMinute);// 得到分</p>

76、<p>  sscanf(cstr[2].Mid(6,2), "%d", &nSecond);// 得到秒</p><p>  CTime t3(2002,1,1,nHour,nMinute,nSecond);// 初始化t3</p><p>  sscanf(cstr[3].Left(2), "%d", &nHour)

77、;// 得到時(shí)</p><p>  sscanf(cstr[3].Mid(3,2), "%d", &nMinute);// 得到分</p><p>  sscanf(cstr[3].Mid(6,2), "%d", &nSecond);// 得到秒</p><p>  CTime t4(2002,1,1,

78、nHour,nMinute,nSecond);// 初始化t4</p><p><b>  // 設(shè)置成員變量</b></p><p>  m_Time1=t1;</p><p>  m_Time2=t2;</p><p>  m_Time3=t3;</p><p>  m_Time4=t4;&

79、lt;/p><p>  UpdateData(FALSE); // 更新界面數(shù)據(jù)</p><p><b>  }</b></p><p>  【6】 m_Sheet.AddPage(&m_Page1); // 加第1頁(yè)</p><p>  m_Sheet.AddPage(&m_Page2); // 加第2

80、頁(yè)</p><p>  m_Sheet.AddPage(&m_Page3); // 加第3頁(yè)</p><p>  m_Sheet.AddPage(&m_Page4); // 加第4頁(yè)</p><p>  m_Sheet.Create(this, WS_CHILD | WS_VISIBLE, 0); // 創(chuàng)建窗口</p><p&g

81、t;  m_Sheet.ModifyStyleEx (0, WS_EX_CONTROLPARENT); // 修改風(fēng)格</p><p>  m_Sheet.ModifyStyle( 0, WS_TABSTOP ); // 修改風(fēng)格</p><p><b>  // 設(shè)置窗口位置</b></p><p>  m_Sheet.SetWindowPo

82、s( NULL, 0, 100, 0, 0, </p><p>  SWP_NOZORDER | SWP_NOSIZE | SWP_NOACTIVATE );</p><p>  【7】void CAttDlg::OnChangeEdtSeekpersonid() </p><p><b>  {</b></p><p>

83、;  UpdateData(); // 更新數(shù)據(jù)</p><p>  CPersonRS rs(&db); // 構(gòu)造記錄集</p><p>  rs.m_strFilter = "ID='" + m_strPersonID + "'"; // 設(shè)置過(guò)濾條件</p><p>  rs.Open(); /

84、/ 打開(kāi)記錄集</p><p>  if(rs.GetRecordCount()==1) // 判斷員工記錄是否存在</p><p><b>  {</b></p><p>  m_strName=rs.m_NAME; // 得到員工姓名</p><p><b>  }</b></p>

85、<p>  else m_strName.Empty(); // 清除員工姓名的顯示</p><p>  rs.Close(); // 關(guān)閉記錄集</p><p>  UpdateData(FALSE); // 更新界面數(shù)據(jù)</p><p><b>  }</b></p><p>  【8】BOOL CPag

86、e1::OnInitDialog() </p><p><b>  {</b></p><p>  CPropertyPage::OnInitDialog();</p><p>  // 出入情況缺省為出</p><p>  ((CButton*)GetDlgItem(IDC_RADIO_OUT))->SetChe

87、ck(TRUE);</p><p>  // 為L(zhǎng)ist添加網(wǎng)格</p><p>  m_cList.SetExtendedStyle(LVS_EX_GRIDLINES);</p><p>  // 設(shè)置List的列</p><p>  int nWidth=110;</p><p>  m_cList.InsertC

88、olumn(0, "記錄編號(hào)", LVCFMT_LEFT, nWidth);</p><p>  m_cList.InsertColumn(1, "員工號(hào)", LVCFMT_LEFT, nWidth);</p><p>  m_cList.InsertColumn(2, "出入情況", LVCFMT_LEFT, nWidth);&

89、lt;/p><p>  m_cList.InsertColumn(3, "時(shí)間", LVCFMT_LEFT, nWidth);</p><p>  CAttendanceRS rs(&db); // 構(gòu)造出勤記錄表</p><p>  UpdateList(rs); // 更新List</p><p>  return

90、 TRUE; </p><p><b>  }</b></p><p>  【9】void CPage1::UpdateList(CAttendanceRS& rs) // 更新列表框內(nèi)容</p><p><b>  {</b></p><p><b>  int i=0;<

91、;/b></p><p>  CString strID,strTime;</p><p>  rs.Open(); // 打開(kāi)出勤記錄表</p><p>  m_cList.DeleteAllItems(); // 清除列表框內(nèi)容</p><p>  while(!rs.IsEOF()) // 對(duì)數(shù)據(jù)表中所有記錄進(jìn)行處理</p&

92、gt;<p><b>  {</b></p><p>  m_cList.InsertItem(i, ""); // 添加新Item</p><p>  strID.Format("%d", rs.m_ID); // 轉(zhuǎn)換為字符串</p><p>  m_cList.SetItemText(

93、i, 0, strID);</p><p>  m_cList.SetItemText(i, 1, rs.m_PERSON);</p><p>  m_cList.SetItemText(i, 2, rs.m_IN_OUT);</p><p>  m_cList.SetItemText(i, 3, rs.m_IO_TIME.Format("%Y-%m-%d

94、 %H:%M"));</p><p>  rs.MoveNext(); // 跳到下一條記錄</p><p><b>  i++;</b></p><p><b>  }</b></p><p>  rs.Close(); // 關(guān)閉出勤記錄表</p><p>&l

95、t;b>  }</b></p><p>  【10】void CPage1::OnChangeEdtDepartid() </p><p><b>  {</b></p><p>  UpdateData(); // 更新數(shù)據(jù)</p><p>  CDepartRS rs(&db); // 構(gòu)造

96、記錄集</p><p>  rs.m_strFilter = "ID='" + m_strDepartID + "'"; // 設(shè)置過(guò)濾條件</p><p>  rs.Open(); // 打開(kāi)記錄集</p><p>  if(rs.GetRecordCount()==1) // 判斷部門(mén)代碼輸入是否正確<

97、;/p><p><b>  {</b></p><p>  m_strDepartName=rs.m_NAME; // 提取部門(mén)名稱</p><p><b>  }</b></p><p>  else m_strDepartName.Empty(); // 清除部門(mén)名稱</p><

98、p>  rs.Close(); // 關(guān)閉記錄集</p><p>  UpdateData(FALSE); // 更新界面數(shù)據(jù)</p><p><b>  }</b></p><p>  【11】void CPage1::OnChangeEdtPersonid() </p><p><b>  {<

99、/b></p><p>  UpdateData(); // 更新數(shù)據(jù)</p><p>  CPersonRS rs(&db); // 構(gòu)造PERSON記錄表</p><p>  rs.m_strFilter = "ID='" + m_strPersonID + "'"; // 設(shè)置過(guò)濾條件<

100、;/p><p>  rs.Open(); // 打開(kāi)記錄表</p><p>  if(rs.GetRecordCount()==1) // 判斷員工號(hào)是否正確</p><p><b>  {</b></p><p>  m_strPersonName=rs.m_NAME; // 提取員工姓名</p><p

101、>  m_strDepartID=rs.m_DEPARTMENT; // 提取員工所在部門(mén)編號(hào)</p><p><b>  }</b></p><p>  else m_strPersonName.Empty(); // 清除員工姓名顯示</p><p>  rs.Close(); // 關(guān)閉記錄表</p><p>

102、;  UpdateData(FALSE); // 更新界面數(shù)據(jù)</p><p>  OnChangeEdtDepartid(); // 顯示部門(mén)名稱</p><p><b>  }</b></p><p>  【12】void CPage1::IO_Add(CString strPersonID)</p><p><

103、;b>  {</b></p><p>  int counter; // 用于計(jì)數(shù)</p><p>  CString strIO; // 保存出入情況</p><p>  CCounterRS rs_counter(&db); // 構(gòu)造計(jì)數(shù)器記錄表</p><p><b>  // 記錄編號(hào)</b

104、></p><p>  rs_counter.m_strFilter = "ID='A'"; // 設(shè)置過(guò)濾器,提取計(jì)數(shù)值</p><p>  rs_counter.Open(); // 打開(kāi)計(jì)數(shù)器記錄表</p><p>  counter=rs_counter.m_COUNTER_VALUE; // 提取計(jì)數(shù)值</p

105、><p>  counter++; // 計(jì)數(shù)值加1</p><p>  rs_counter.Edit(); // 編輯計(jì)數(shù)器</p><p>  rs_counter.m_COUNTER_VALUE=counter; // 保存當(dāng)前計(jì)數(shù)</p><p>  rs_counter.Update(); // 提交修改</p><

106、;p>  rs_counter.Close(); // 關(guān)閉計(jì)數(shù)器記錄表</p><p><b>  // 添加記錄</b></p><p>  // 判斷確定出入情況</p><p>  if(((CButton*)GetDlgItem(IDC_RADIO_OUT))->GetCheck())</p><p&g

107、t;  strIO="O";</p><p>  else strIO="I";</p><p>  // 轉(zhuǎn)換出入時(shí)間類型</p><p>  int nYear,nMonth,nDay,nHour,nMinute; // 年,月,日,時(shí),分</p><p>  sscanf(m_strIOTime.

108、Left(4), "%d", &nYear); // 得到年</p><p>  sscanf(m_strIOTime.Mid(5,2), "%d", &nMonth); // 得到月</p><p>  sscanf(m_strIOTime.Mid(8,2), "%d", &nDay); // 得到日&l

109、t;/p><p>  sscanf(m_strIOTime.Mid(11,2), "%d", &nHour); // 得到時(shí)</p><p>  sscanf(m_strIOTime.Mid(14,2), "%d", &nMinute); // 得到分</p><p><b>  // 得到出入時(shí)間<

110、;/b></p><p>  CTime IO_time(nYear,nMonth,nDay,nHour,nMinute,0);</p><p>  CAttendanceRS rs_attendance(&db); // 構(gòu)造考勤記錄表</p><p>  rs_attendance.Open(); // 打開(kāi)考勤記錄表</p><

111、;p>  rs_attendance.AddNew(); // 追加考勤記錄</p><p>  rs_attendance.m_ID=counter;</p><p>  rs_attendance.m_PERSON=strPersonID;</p><p>  rs_attendance.m_IN_OUT=strIO;</p><p&g

112、t;  rs_attendance.m_IO_TIME=IO_time;</p><p>  rs_attendance.Update();</p><p>  rs_attendance.Close(); // 關(guān)閉考勤記錄表</p><p>  UpdateList(rs_attendance); // 更新列表框</p><p><

113、;b>  }</b></p><p>  【13】void CPage1::OnChangeEdtPersonid() </p><p><b>  {</b></p><p>  UpdateData(); // 更新數(shù)據(jù)</p><p>  CPersonRS rs(&db); // 構(gòu)造P

114、ERSON記錄表</p><p>  rs.m_strFilter = "ID='" + m_strPersonID + "'"; // 設(shè)置過(guò)濾條件</p><p>  rs.Open(); // 打開(kāi)記錄表</p><p>  if(rs.GetRecordCount()==1) // 判斷員工號(hào)是否正確&

115、lt;/p><p><b>  {</b></p><p>  m_strPersonName=rs.m_NAME; // 提取員工姓名</p><p>  m_strDepartID=rs.m_DEPARTMENT; // 提取員工所在部門(mén)編號(hào)</p><p><b>  }</b></p>

116、;<p>  else m_strPersonName.Empty(); // 清除員工姓名顯示</p><p>  rs.Close(); // 關(guān)閉記錄表</p><p>  UpdateData(FALSE); // 更新界面數(shù)據(jù)</p><p>  OnChangeEdtDepartid(); // 顯示部門(mén)名稱</p><

117、p><b>  }</b></p><p>  // 添加出勤記錄函數(shù)</p><p>  void CPage1::IO_Add(CString strPersonID)</p><p><b>  {</b></p><p>  int counter; // 用于計(jì)數(shù)</p>

118、<p>  CString strIO; // 保存出入情況</p><p>  CCounterRS rs_counter(&db); // 構(gòu)造計(jì)數(shù)器記錄表</p><p><b>  // 記錄編號(hào)</b></p><p>  rs_counter.m_strFilter = "ID='A'

119、"; // 設(shè)置過(guò)濾器,提取計(jì)數(shù)值</p><p>  rs_counter.Open(); // 打開(kāi)計(jì)數(shù)器記錄表</p><p>  counter=rs_counter.m_COUNTER_VALUE; // 提取計(jì)數(shù)值</p><p>  counter++; // 計(jì)數(shù)值加1</p><p>  rs_counter.Ed

120、it(); // 編輯計(jì)數(shù)器</p><p>  rs_counter.m_COUNTER_VALUE=counter; // 保存當(dāng)前計(jì)數(shù)</p><p>  rs_counter.Update(); // 提交修改</p><p>  rs_counter.Close(); // 關(guān)閉計(jì)數(shù)器記錄表</p><p><b>  /

121、/ 添加記錄</b></p><p>  // 判斷確定出入情況</p><p>  if(((CButton*)GetDlgItem(IDC_RADIO_OUT))->GetCheck())</p><p>  strIO="O";</p><p>  else strIO="I";

122、</p><p>  // 轉(zhuǎn)換出入時(shí)間類型</p><p>  int nYear,nMonth,nDay,nHour,nMinute; // 年,月,日,時(shí),分</p><p>  sscanf(m_strIOTime.Left(4), "%d", &nYear); // 得到年</p><p>  sscan

123、f(m_strIOTime.Mid(5,2), "%d", &nMonth); // 得到月</p><p>  sscanf(m_strIOTime.Mid(8,2), "%d", &nDay); // 得到日</p><p>  sscanf(m_strIOTime.Mid(11,2), "%d", &

124、nHour); // 得到時(shí)</p><p>  sscanf(m_strIOTime.Mid(14,2), "%d", &nMinute); // 得到分</p><p><b>  // 得到出入時(shí)間</b></p><p>  CTime IO_time(nYear,nMonth,nDay,nHour,nMin

125、ute,0);</p><p>  CAttendanceRS rs_attendance(&db); // 構(gòu)造考勤記錄表</p><p>  rs_attendance.Open(); // 打開(kāi)考勤記錄表</p><p>  rs_attendance.AddNew(); // 追加考勤記錄</p><p>  rs_atten

126、dance.m_ID=counter;</p><p>  rs_attendance.m_PERSON=strPersonID;</p><p>  rs_attendance.m_IN_OUT=strIO;</p><p>  rs_attendance.m_IO_TIME=IO_time;</p><p>  rs_attendance

127、.Update();</p><p>  rs_attendance.Close(); // 關(guān)閉考勤記錄表</p><p>  UpdateList(rs_attendance); // 更新列表框</p><p><b>  }</b></p><p>  void CPage1::OnBtnAddperson()

128、// 追加單個(gè)員工考勤記錄</p><p><b>  {</b></p><p>  if(!m_strPersonName.IsEmpty()) // 判斷員工是否存在</p><p><b>  {</b></p><p>  IO_Add(m_strPersonID); // 追加單個(gè)員工記

129、錄</p><p><b>  }</b></p><p><b>  }</b></p><p>  void CPage1::OnBtnAdddepart() // 追加部門(mén)員工考勤記錄</p><p><b>  {</b></p><p>  i

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論