📄 studentdlg.cpp
字号:
// StudentDlg.cpp : implementation file
//
#include "stdafx.h"
#include "StudentScore.h"
#include "StudentDlg.h"
#include "StudentSet.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CStudentDlg dialog
CStudentDlg::CStudentDlg(CWnd* pParent /*=NULL*/)
: CDialog(CStudentDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CStudentDlg)
//}}AFX_DATA_INIT
}
void CStudentDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CStudentDlg)
DDX_Control(pDX, IDC_STUDENT_NO, m_strNo);
DDX_Control(pDX, IDC_STUDENT_PHONE, m_strPhone);
DDX_Control(pDX, IDC_STUDENT_NAME, m_strName);
DDX_Control(pDX, IDC_STUDENT_AGE, m_strAge);
DDX_Control(pDX, IDC_STUDENT_ADDRESS, m_strAddress);
DDX_Control(pDX, IDC_LIST_STUDENT, m_list);
DDX_Control(pDX, ID_STUDENT_EDIT, m_bEdit);
DDX_Control(pDX, ID_STUDENT_DEL, m_bDel);
DDX_Control(pDX, ID_STUDENT_CONFIRM, m_bConfirm);
DDX_Control(pDX, ID_STUDENT_ADD, m_bAdd);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CStudentDlg, CDialog)
//{{AFX_MSG_MAP(CStudentDlg)
ON_BN_CLICKED(ID_STUDENT_ADD, OnStudentAdd)
ON_NOTIFY(NM_CLICK, IDC_LIST_STUDENT, OnClickListStudent)
ON_BN_CLICKED(ID_STUDENT_EDIT, OnStudentEdit)
ON_BN_CLICKED(ID_STUDENT_DEL, OnStudentDel)
ON_BN_CLICKED(ID_STUDENT_CONFIRM, OnStudentConfirm)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CStudentDlg message handlers
void CStudentDlg::OnStudentAdd()
{
//设置输入框为可编辑状态并清空输入框中的值
m_strNo.EnableWindow(true);
m_strNo.SetWindowText("");
m_strName.EnableWindow(true);
m_strName.SetWindowText("");
m_strAge.EnableWindow(true);
m_strAge.SelectString(0,"20");
m_strPhone.EnableWindow(true);
m_strAddress.EnableWindow(true);
femaleRadio->EnableWindow(true);
maleRadio->EnableWindow(true);
//打开记录集
m_studentSet.Open();
//添加新记录
m_studentSet.AddNew();
//设置点击确定按钮后,其他按钮的状态
m_bConfirm.EnableWindow(true);
m_bAdd.EnableWindow(false);
m_bEdit.EnableWindow(false);
m_bDel.EnableWindow(false);
}
BOOL CStudentDlg::OnInitDialog()
{
CDialog::OnInitDialog();
//初始化里CList 控件的和header
m_list.InsertColumn(0,"记录号");
m_list.InsertColumn(1,"编号");
m_list.InsertColumn(2,"姓名");
m_list.InsertColumn(3,"性别");
m_list.InsertColumn(4,"年龄");
m_list.InsertColumn(5,"电话");
m_list.InsertColumn(6,"地址");
//设置header的宽度
RECT rectList;
m_list.GetWindowRect(&rectList);
int wid=rectList.right-rectList.left-4;
for(int i=0;i<7;i++)
m_list.SetColumnWidth(i,wid/7);
m_list.SetExtendedStyle(LVS_EX_FULLROWSELECT);
//调用refreshList()初始化CList中的数据
RefreshList();
//为年龄的下拉列表添加item
for(int j=1;j<100;j++)
{
CString s;
s.Format("%d",j);
m_strAge.AddString(s);
}
femaleRadio=(CButton*)this->GetDlgItem(IDC_RADIO_SEX_FEMALE);
maleRadio=(CButton*)this->GetDlgItem(IDC_RADIO_SEX_MALE);
femaleRadio->EnableWindow(false);
maleRadio->EnableWindow(false);
//调用ResetButton()方法,使按钮处于初始状态
ResetButton();
return TRUE;
}
void CStudentDlg::RefreshList()
{
//删除CList的所有内容
m_list.DeleteAllItems();
//打开记录集
m_studentSet.Open();
//设置查询条件
m_studentSet.m_strFilter="active_status='Y'";
//执行查询
m_studentSet.Requery();
//将记录集显示到 CList中
for(int i=0;i<m_studentSet.GetRecordCount();i++){
CString temp;
m_studentSet.GetFieldValue("student_id",temp);
m_list.InsertItem(i,temp);
m_list.SetItemText(i,1,m_studentSet.m_student_no);
m_list.SetItemText(i,2,m_studentSet.m_student_name);
m_list.SetItemText(i,3,m_studentSet.m_student_sex);
m_studentSet.GetFieldValue("student_age",temp);
m_list.SetItemText(i,4,temp);
m_list.SetItemText(i,5,m_studentSet.m_student_phone);
m_list.SetItemText(i,6,m_studentSet.m_student_address);
m_studentSet.MoveNext();
}
//关闭数据库
m_studentSet.Close();
}
void CStudentDlg::ResetButton()
{
//设置不可用
m_strNo.EnableWindow(false);
m_strName.EnableWindow(false);
m_strAge.EnableWindow(false);
m_strPhone.EnableWindow(false);
m_strAddress.EnableWindow(false);
femaleRadio->EnableWindow(false);
maleRadio->EnableWindow(false);
//设置确定按钮不可用
m_bConfirm.EnableWindow(false);
//设置添加、删除、编辑按钮可用状态
m_bAdd.EnableWindow(true);
m_bDel.EnableWindow(true);
m_bEdit.EnableWindow(true);
}
void CStudentDlg::OnClickListStudent(NMHDR* pNMHDR, LRESULT* pResult)
{
//当选中CList中某一行时,将CList中的数据也显示到编辑框中
//获得所选行的行号
int row=m_list.GetSelectionMark();
CString s;
//将第2列的值赋给临时字符串s中
s=m_list.GetItemText(row,1);
//相应的编辑框显示该值
m_strNo.SetWindowText(s);
s=m_list.GetItemText(row,2);
m_strName.SetWindowText(s);
s=m_list.GetItemText(row,3);
//设置单选按钮选中状态
if(s=="女")
{
femaleRadio->SetCheck(true);
maleRadio->SetCheck(false);
}
else
{
femaleRadio->SetCheck(false);
maleRadio->SetCheck(true);
}
//设置年龄的下拉列表值
s=m_list.GetItemText(row,4);
int i=m_strAge.FindString(0,s);
m_strAge.SelectString(i,s);
s=m_list.GetItemText(row,5);
m_strPhone.SetWindowText(s);
s=m_list.GetItemText(row,6);
m_strAddress.SetWindowText(s);
*pResult = 0;
}
void CStudentDlg::OnStudentEdit()
{
//得到CList当前所选的行号
int row=m_list.GetSelectionMark();
CString s,strSQL;
//将当前行的第一列的值赋给s
s=m_list.GetItemText(row,0);
if(s=="")//如果s为空,则表示没有选中行
{
MessageBox("请选择一行!");
}
else//如果有选中一行
{
//定义查询条件,相当于where
strSQL.Format("student_id=%s",s);
//打开记录集
m_studentSet.Open();
//设置查询条件
m_studentSet.m_strFilter=strSQL;
//执行查询
m_studentSet.Requery();
//游标指定到该行所在的记录上,执行修改
m_studentSet.Edit();
//设置点击修改按钮后其他按钮的状态
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_strAge.EnableWindow(true);
m_strPhone.EnableWindow(true);
m_strAddress.EnableWindow(true);
}
}
void CStudentDlg::OnStudentDel()
{
//得到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("student_id=%s",s);
m_studentSet.Open();
m_studentSet.m_strFilter=strSQL;
m_studentSet.Requery();
m_studentSet.Edit();
//设置active_status="N";
m_studentSet.m_active_status="N";
//更新数据库
m_studentSet.Update();
//关闭数据库
m_studentSet.Close();
//更新CList数据
RefreshList();
}
}
}
void CStudentDlg::OnStudentConfirm()
{
CString no,name,phone,address,strSex;
//得到输入编辑框的值
m_strNo.GetWindowText(no);
m_strName.GetWindowText(name);
m_strPhone.GetWindowText(phone);
m_strAddress.GetWindowText(address);
//将CString类型转化为int型
int age;
CString s;
m_strAge.GetWindowText(s);
age=atoi(s);
//取得单选按纽的状态
int sex=this->GetCheckedRadioButton(IDC_RADIO_SEX_MALE,IDC_RADIO_SEX_FEMALE);
if(sex==IDC_RADIO_SEX_FEMALE)
strSex="女";
else
strSex="男";
if(name=="")//如果学生姓名为空
{
MessageBox("请输入教师姓名");
}
else
{
//设置记录添加或编辑后的值
m_studentSet.m_student_no=no;
m_studentSet.m_student_name=name;
m_studentSet.m_student_sex=strSex;
m_studentSet.m_student_age=age;
m_studentSet.m_student_phone=phone;
m_studentSet.m_student_address=address;
m_studentSet.m_active_status="Y";
//更新记录集
m_studentSet.Update();
//关闭记录集
m_studentSet.Close();
//更新列表数据
RefreshList();
//按钮恢复初始状态
ResetButton();
}
}
void CStudentDlg::OnCancel()
{
// TODO: Add extra cleanup here
CDialog::OnCancel();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -