?? userdlg.cpp
字號:
// UserDlg.cpp : implementation file
//
#include "stdafx.h"
#include "StudentScore.h"
#include "UserDlg.h"
#include "UserSet.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CUserDlg dialog
CUserDlg::CUserDlg(CWnd* pParent /*=NULL*/)
: CDialog(CUserDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CUserDlg)
//}}AFX_DATA_INIT
}
void CUserDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CUserDlg)
DDX_Control(pDX, ID_USER_OK, m_bConfirm);
DDX_Control(pDX, IDC_USER_PASSWORD, m_strPassword);
DDX_Control(pDX, IDC_USER_NAME, m_strUser);
DDX_Control(pDX, IDC_USER_LEVEL, m_cLevel);
DDX_Control(pDX, ID_USER_EDIT, m_bEdit);
DDX_Control(pDX, ID_USER_DEL, m_bDel);
DDX_Control(pDX, ID_USER_ADD, m_bAdd);
DDX_Control(pDX, IDC_LIST_USER, m_list);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CUserDlg, CDialog)
//{{AFX_MSG_MAP(CUserDlg)
ON_BN_CLICKED(ID_USER_ADD, OnUserAdd)
ON_BN_CLICKED(ID_USER_EDIT, OnUserEdit)
ON_BN_CLICKED(ID_USER_DEL, OnUserDel)
ON_NOTIFY(NM_CLICK, IDC_LIST_USER, OnClickListUser)
ON_BN_CLICKED(ID_USER_OK, OnUserOk)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CUserDlg message handlers
BOOL CUserDlg::OnInitDialog()
{
CDialog::OnInitDialog();
//初始化里CList 控件的和header
m_list.InsertColumn(0,"用戶編號");
m_list.InsertColumn(1,"用戶名");
m_list.InsertColumn(2,"密碼");
m_list.InsertColumn(3,"用戶權限");
//設置header的寬度
RECT rectList;
m_list.GetWindowRect(&rectList);
int wid=rectList.right-rectList.left-4;
for(int i=0;i<4;i++)
m_list.SetColumnWidth(i,wid/4);
m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT);
//調用refreshList()初始化CList中的數據
RefreshList();
//為權限的下拉列表添加item
m_cLevel.AddString("管理員");
m_cLevel.AddString("教師");
m_cLevel.AddString("學生");
//設置第一個item為選中狀態
m_cLevel.SelectString(0,"管理員");
//調用ResetButton()方法,使按鈕處于初始狀態
ResetButton();
return TRUE;
}
void CUserDlg::OnUserAdd() //添加按鈕方法
{
//設置輸入框為可編輯狀態并清空輸入框中的值
m_strUser.EnableWindow(true);
m_strUser.SetWindowText("");
m_strPassword.EnableWindow(true);
m_strPassword.SetWindowText("");
m_cLevel.EnableWindow(true);
m_cLevel.SelectString(0,"管理員");
//打開記錄集
m_userSet.Open();
//添加新記錄
m_userSet.AddNew();
//設置點擊確定按鈕后,其他按鈕的狀態
m_bConfirm.EnableWindow(true);
m_bAdd.EnableWindow(false);
m_bEdit.EnableWindow(false);
m_bDel.EnableWindow(false);
}
void CUserDlg::RefreshList()//更新CList中的數據
{
//刪除CList的所有內容
m_list.DeleteAllItems();
//打開記錄集
m_userSet.Open();
//設置查詢條件
m_userSet.m_strFilter="active_status='Y'";
//執行查詢
m_userSet.Requery();
//將記錄集顯示到 CList中
for(int i=0;i<m_userSet.GetRecordCount();i++){
CString temp;
m_userSet.GetFieldValue("user_id",temp);
m_list.InsertItem(i,temp);
m_userSet.GetFieldValue("user_name",temp);
m_list.SetItemText(i,1,temp);
m_userSet.GetFieldValue("user_password",temp);
m_list.SetItemText(i,2,temp);
m_userSet.GetFieldValue("user_level",temp);
m_list.SetItemText(i,3,temp);
m_userSet.MoveNext();
}
//關閉數據庫
m_userSet.Close();
}
void CUserDlg::OnUserEdit() //修改按鈕方法
{
//得到CList當前所選的行號
int row=m_list.GetSelectionMark();
CString s,strSQL;
//將當前行的第一列的值賦給s
s=m_list.GetItemText(row,0);
if(s=="")//如果s為空,則表示沒有選中行
{
MessageBox("請選擇一行!");
}
else//如果有選中一行
{
//定義查詢條件,相當于where
strSQL.Format("user_id=%s",s);
//打開記錄集
m_userSet.Open();
//設置查詢條件
m_userSet.m_strFilter=strSQL;
//執行查詢
m_userSet.Requery();
//游標指定到該行所在的記錄上,執行修改
m_userSet.Edit();
//設置點擊修改按鈕后其他按鈕的狀態
m_bConfirm.EnableWindow(true);
m_bAdd.EnableWindow(false);
m_bEdit.EnableWindow(false);
m_bDel.EnableWindow(false);
m_strUser.EnableWindow(true);
m_strPassword.EnableWindow(true);
m_cLevel.EnableWindow(true);
}
}
void CUserDlg::OnUserDel() //刪除按鈕方法
{
//得到CList當前所選的行號
int row=m_list.GetSelectionMark();
CString s,strSQL;
//將當前行的第一列的值賦給s
s=m_list.GetItemText(row,0);
if(s=="")//如果s為空,則表示沒有選中行
{
MessageBox("請選擇一行!");
}
else
{
//彈出窗口詢問是否刪除數據
if(MessageBox("確定要刪除記錄嗎?","刪除詢問",MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
{
//查詢所選行所在的記錄
strSQL.Format("user_id=%s",s);
m_userSet.Open();
m_userSet.m_strFilter=strSQL;
m_userSet.Requery();
m_userSet.Edit();
//設置active_status="N";
m_userSet.m_active_status="N";
//更新數據庫
m_userSet.Update();
//關閉數據庫
m_userSet.Close();
//更新CList數據
RefreshList();
}
}
}
void CUserDlg::OnCancel()//取消按鈕方法
{
if(m_userSet.IsOpen())//如果記錄集打開,則關閉記錄集
m_userSet.Close();
ResetButton();
CDialog::OnCancel();
}
void CUserDlg::OnClickListUser(NMHDR* pNMHDR, LRESULT* pResult) //選中Clist中某一行是的事件方法
{
//當選中CList中某一行時,將CList中的數據也顯示到編輯框中
//獲得所選行的行號
int row=m_list.GetSelectionMark();
CString s;
//將第2列的值賦給臨時字符串s中
s=m_list.GetItemText(row,1);
//相應的編輯框顯示該值
m_strUser.SetWindowText(s);
s=m_list.GetItemText(row,2);
m_strPassword.SetWindowText(s);
//將第4列的值賦給臨時字符串s中
s=m_list.GetItemText(row,3);
if(s=="0")//如果s為0,則設置下拉列表值為管理員
{
m_cLevel.SelectString(0,"管理員");
}
else if(s=="1")//如果s為1,則設置下拉列表值為 教師
{
m_cLevel.SelectString(1,"教師");
}
else if(s=="2")//如果s為2,則設置下拉列表值為學生
{
m_cLevel.SelectString(2,"學生");
}
*pResult = 0;
}
void CUserDlg::OnUserOk() //確定按鈕方法
{
CString username,password,level;
//得到輸入編輯框的值
m_strUser.GetWindowText(username);
m_strPassword.GetWindowText(password);
if(username=="")//如果用戶名為空
{
MessageBox("請輸入用戶名");
}
else if(password=="")//如果密碼為空
{
MessageBox("請輸入密碼");
}
else
{
//獲取下拉列表中的值
int i=m_cLevel.GetCurSel();
if(i==0)
level="0";
if(i==1)
level="1";
if(i==2)
level="2";
//設置記錄添加或編輯后的值
m_userSet.m_user_name=username;
m_userSet.m_user_password=password;
m_userSet.m_user_level=level;
m_userSet.m_active_status="Y";
//更新記錄集
m_userSet.Update();
//關閉記錄集
m_userSet.Close();
RefreshList();
ResetButton();
}
}
void CUserDlg::ResetButton()//設置按鈕的初始狀態
{
//設置用戶名,密碼,權限編輯框不可用
m_strUser.EnableWindow(false);
m_strPassword.EnableWindow(false);
m_cLevel.EnableWindow(false);
//設置確定按鈕不可用
m_bConfirm.EnableWindow(false);
//設置添加、刪除、編輯按鈕可用狀態
m_bAdd.EnableWindow(true);
m_bDel.EnableWindow(true);
m_bEdit.EnableWindow(true);
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -