?? teacherdlg.cpp
字號(hào):
// TeacherDlg.cpp : implementation file
//
#include "stdafx.h"
#include "studentscore.h"
#include "TeacherDlg.h"
#include "TeacherSet.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CTeacherDlg dialog
CTeacherDlg::CTeacherDlg(CWnd* pParent /*=NULL*/)
: CDialog(CTeacherDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CTeacherDlg)
//}}AFX_DATA_INIT
}
void CTeacherDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CTeacherDlg)
DDX_Control(pDX, IDC_TEACHER_NO, m_strNo);
DDX_Control(pDX, IDC_TEACHER_NAME, m_strName);
DDX_Control(pDX, IDC_TEACHER_LEVEL, m_strLevel);
DDX_Control(pDX, IDC_TEACHER_AGE, m_strAge);
DDX_Control(pDX, IDC_LIST_TEACHER, m_list);
DDX_Control(pDX, ID_TEACHER_EDIT, m_bEdit);
DDX_Control(pDX, ID_TEACHER_DEL, m_bDel);
DDX_Control(pDX, ID_TEACHER_CONFIRM, m_bConfirm);
DDX_Control(pDX, ID_TEACHER_ADD, m_bAdd);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CTeacherDlg, CDialog)
//{{AFX_MSG_MAP(CTeacherDlg)
ON_NOTIFY(NM_CLICK, IDC_LIST_TEACHER, OnClickListTeacher)
ON_BN_CLICKED(ID_TEACHER_ADD, OnTeacherAdd)
ON_BN_CLICKED(ID_TEACHER_EDIT, OnTeacherEdit)
ON_BN_CLICKED(ID_TEACHER_DEL, OnTeacherDel)
ON_BN_CLICKED(ID_TEACHER_CONFIRM, OnTeacherConfirm)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CTeacherDlg message handlers
void CTeacherDlg::RefreshList()
{
//刪除CList的所有內(nèi)容
m_list.DeleteAllItems();
//打開(kāi)記錄集
m_teacherSet.Open();
//設(shè)置查詢條件
m_teacherSet.m_strFilter="active_status='Y'";
//執(zhí)行查詢
m_teacherSet.Requery();
//將記錄集顯示到 CList中
for(int i=0;i<m_teacherSet.GetRecordCount();i++){
CString temp;
m_teacherSet.GetFieldValue("teacher_id",temp);
m_list.InsertItem(i,temp);
m_list.SetItemText(i,1,m_teacherSet.m_teacher_no);
m_list.SetItemText(i,2,m_teacherSet.m_teacher_name);
m_list.SetItemText(i,3,m_teacherSet.m_teacher_sex);
m_teacherSet.GetFieldValue("teacher_age",temp);
m_list.SetItemText(i,4,temp);
m_list.SetItemText(i,5,m_teacherSet.m_teacher_level);
m_teacherSet.MoveNext();
}
//關(guān)閉數(shù)據(jù)庫(kù)
m_teacherSet.Close();
}
void CTeacherDlg::ResetButton()
{
//設(shè)置不可用
m_strNo.EnableWindow(false);
m_strName.EnableWindow(false);
m_strLevel.EnableWindow(false);
m_strAge.EnableWindow(false);
femaleRadio->EnableWindow(false);
maleRadio->EnableWindow(false);
//設(shè)置確定按鈕不可用
m_bConfirm.EnableWindow(false);
//設(shè)置添加、刪除、編輯按鈕可用狀態(tài)
m_bAdd.EnableWindow(true);
m_bDel.EnableWindow(true);
m_bEdit.EnableWindow(true);
}
BOOL CTeacherDlg::OnInitDialog()
{
CDialog::OnInitDialog();
//初始化里CList 控件的和header
m_list.InsertColumn(0,"記錄號(hào)");
m_list.InsertColumn(1,"編號(hào)");
m_list.InsertColumn(2,"姓名");
m_list.InsertColumn(3,"性別");
m_list.InsertColumn(4,"年齡");
m_list.InsertColumn(5,"職稱");
//設(shè)置header的寬度
RECT rectList;
m_list.GetWindowRect(&rectList);
int wid=rectList.right-rectList.left-4;
for(int i=0;i<6;i++)
m_list.SetColumnWidth(i,wid/6);
m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT);
//調(diào)用refreshList()初始化CList中的數(shù)據(jù)
RefreshList();
//為職稱的下拉列表添加item
m_strLevel.AddString("教授");
m_strLevel.AddString("副教授");
m_strLevel.AddString("講師");
m_strLevel.AddString("助教");
//設(shè)置第一個(gè)item為選中狀態(tài)
m_strLevel.SelectString(0,"教授");
//為年齡的下拉列表添加item
for(int j=1;j<100;j++)
{
CString s;
s.Format("%d",j);
m_strAge.AddString(s);
}
//設(shè)置第一個(gè)item為選中狀態(tài)
m_strLevel.SelectString(0,"1");
//初始化單選按鈕
femaleRadio=(CButton*)this->GetDlgItem(IDC_RADIO_TEACHER_FEMALE);
maleRadio=(CButton*)this->GetDlgItem(IDC_RADIO_TEACHER_MALE);
//調(diào)用ResetButton()方法,使按鈕處于初始狀態(tài)
ResetButton();
return TRUE;
}
void CTeacherDlg::OnClickListTeacher(NMHDR* pNMHDR, LRESULT* pResult)
{
// TODO: Add your control notification handler code here
//當(dāng)選中CList中某一行時(shí),將CList中的數(shù)據(jù)也顯示到編輯框中
//獲得所選行的行號(hào)
int row=m_list.GetSelectionMark();
CString s;
////將第2列的值賦給臨時(shí)字符串s中
s=m_list.GetItemText(row,1);
//相應(yīng)的編輯框顯示該值
m_strNo.SetWindowText(s);
s=m_list.GetItemText(row,2);
m_strName.SetWindowText(s);
s=m_list.GetItemText(row,3);
//設(shè)置單選按鈕選中狀態(tài)
if(s=="女")
{
femaleRadio->SetCheck(true);
maleRadio->SetCheck(false);
}
else
{
femaleRadio->SetCheck(false);
maleRadio->SetCheck(true);
}
//設(shè)置年齡的下拉列表值
s=m_list.GetItemText(row,4);
int i=m_strAge.FindString(0,s);
m_strAge.SelectString(i,s);
s=m_list.GetItemText(row,5);
i=m_strLevel.FindString(0,s);
m_strLevel.SelectString(i,s);
*pResult = 0;
}
void CTeacherDlg::OnTeacherAdd()
{
//設(shè)置輸入框?yàn)榭删庉嫚顟B(tài)并清空輸入框中的值
m_strNo.EnableWindow(true);
m_strNo.SetWindowText("");
m_strName.EnableWindow(true);
m_strName.SetWindowText("");
m_strAge.EnableWindow(true);
m_strAge.SelectString(0,"20");
m_strLevel.EnableWindow(true);
m_strLevel.SelectString(0,"教授");
femaleRadio->EnableWindow(true);
maleRadio->EnableWindow(true);
//打開(kāi)記錄集
m_teacherSet.Open();
//添加新記錄
m_teacherSet.AddNew();
//設(shè)置點(diǎn)擊確定按鈕后,其他按鈕的狀態(tài)
m_bConfirm.EnableWindow(true);
m_bAdd.EnableWindow(false);
m_bEdit.EnableWindow(false);
m_bDel.EnableWindow(false);
}
void CTeacherDlg::OnTeacherEdit()
{
// TODO: Add your control notification handler code here
//得到CList當(dāng)前所選的行號(hào)
int row=m_list.GetSelectionMark();
CString s,strSQL;
//將當(dāng)前行的第一列的值賦給s
s=m_list.GetItemText(row,0);
if(s=="")//如果s為空,則表示沒(méi)有選中行
{
MessageBox("請(qǐng)選擇一行!");
}
else //如果有選中一行
{
//定義查詢條件,相當(dāng)于where
strSQL.Format("teacher_id=%s",s);
//打開(kāi)記錄集
m_teacherSet.Open();
//設(shè)置查詢條件
m_teacherSet.m_strFilter=strSQL;
//執(zhí)行查詢
m_teacherSet.Requery();
//游標(biāo)指定到該行所在的記錄上,執(zhí)行修改
m_teacherSet.Edit();
//設(shè)置點(diǎn)擊修改按鈕后其他按鈕的狀態(tài)
m_bConfirm.EnableWindow(true);
m_bAdd.EnableWindow(false);
m_bEdit.EnableWindow(false);
m_bDel.EnableWindow(false);
m_strName.EnableWindow(true);
femaleRadio->EnableWindow(true);
maleRadio->EnableWindow(true);
m_strNo.EnableWindow(true);
m_strLevel.EnableWindow(true);
m_strAge.EnableWindow(true);
}
}
void CTeacherDlg::OnTeacherDel()
{
// TODO: Add your control notification handler code here
//得到CList當(dāng)前所選的行號(hào)
int row=m_list.GetSelectionMark();
CString s,strSQL;
//將當(dāng)前行的第一列的值賦給s
s=m_list.GetItemText(row,0);
if(s=="")//如果s為空,則表示沒(méi)有選中行
{
MessageBox("請(qǐng)選擇一行!");
}
else
{
//彈出窗口詢問(wèn)是否刪除數(shù)據(jù)
if(MessageBox("確定要?jiǎng)h除記錄嗎?","刪除詢問(wèn)",MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
{
//查詢所選行所在的記錄
strSQL.Format("teacher_id=%s",s);
m_teacherSet.Open();
m_teacherSet.m_strFilter=strSQL;
m_teacherSet.Requery();
m_teacherSet.Edit();
//設(shè)置active_status="N";
m_teacherSet.m_active_status="N";
//更新數(shù)據(jù)庫(kù)
m_teacherSet.Update();
//關(guān)閉數(shù)據(jù)庫(kù)
m_teacherSet.Close();
//更新CList數(shù)據(jù)
RefreshList();
}
}
}
void CTeacherDlg::OnTeacherConfirm()
{
// TODO: Add your control notification handler code here
CString no,name,level,strSex;
//得到輸入編輯框的值
m_strNo.GetWindowText(no);
m_strName.GetWindowText(name);
//將CString類型轉(zhuǎn)化為int型
int age;
CString s;
m_strAge.GetWindowText(s);
age=atoi(s);
//取得單選按紐的狀態(tài)
int sex=this->GetCheckedRadioButton(IDC_RADIO_TEACHER_FEMALE,IDC_RADIO_TEACHER_MALE);
if(sex==IDC_RADIO_TEACHER_FEMALE)
strSex="女";
else
strSex="男";
m_strLevel.GetWindowText(level);
//
if(name=="")//如果教師姓名為空
{
MessageBox("請(qǐng)輸入教師姓名");
}
else
{
//設(shè)置記錄添加或編輯后的值
m_teacherSet.m_teacher_no=no;
m_teacherSet.m_teacher_name=name;
m_teacherSet.m_teacher_sex=strSex;
m_teacherSet.m_teacher_age=age;
m_teacherSet.m_teacher_level=level;
m_teacherSet.m_active_status="Y";
//更新記錄集
m_teacherSet.Update();
//關(guān)閉記錄集
m_teacherSet.Close();
//更新列表數(shù)據(jù)
RefreshList();
//按鈕恢復(fù)初始狀態(tài)
ResetButton();
}
}
void CTeacherDlg::OnCancel()
{
// TODO: Add extra cleanup here
if(m_teacherSet.IsOpen())//如果記錄集打開(kāi),則關(guān)閉記錄集
m_teacherSet.Close();
ResetButton();
CDialog::OnCancel();
}
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -