亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? empeditdlg.cpp

?? VC + SQL數據庫編程 人事、工資、部門管理 包含SQL備份文件及部分源碼注釋
?? CPP
字號:
// EmpEditDlg.cpp : implementation file
//

#include "stdafx.h"
#include "HrSys.h"
#include "EmpEditDlg.h"
#include "Employees.h"
#include "EmpSelDlg.h"
#include "ADOConn.h"

extern CUsers curUser;

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CEmpEditDlg dialog


CEmpEditDlg::CEmpEditDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CEmpEditDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CEmpEditDlg)
	m_Badge = _T("");
	m_Contract = _T("");
	m_EmpName = _T("");
	m_Culture = _T("");
	m_Family = _T("");
	m_File = _T("");
	m_Fillperson = _T("");
	m_Filltime = _T("");
	m_Hukou = _T("");
	m_Idcard = _T("");
	m_Marital = _T("");
	m_Memo = _T("");
	m_Mobile = _T("");
	m_Nation = _T("");
	m_Office = _T("");
	m_Political = _T("");
	m_Position = _T("");
	m_Title = _T("");
	m_Birth = 0;
	m_HireDate = 0;
	m_Upper = _T("");
	//}}AFX_DATA_INIT
}


void CEmpEditDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CEmpEditDlg)
	DDX_Control(pDX, IDC_STATE_COMBO, m_State);
	DDX_Control(pDX, IDC_SEX_COMBO, m_Sex);
	DDX_Text(pDX, IDC_BADGE_EDIT, m_Badge);
	DDX_Text(pDX, IDC_CONTRACT_EDIT, m_Contract);
	DDX_Text(pDX, IDC_EMPNAME_EDIT, m_EmpName);
	DDX_Text(pDX, IDC_CULTURE_EDIT, m_Culture);
	DDX_Text(pDX, IDC_FAMILY_EDIT, m_Family);
	DDX_Text(pDX, IDC_FILE_EDIT, m_File);
	DDX_Text(pDX, IDC_FILLPERSON_STATIC, m_Fillperson);
	DDX_Text(pDX, IDC_FILLTIME_STATIC, m_Filltime);
	DDX_Text(pDX, IDC_HUKOU_EDIT, m_Hukou);
	DDX_Text(pDX, IDC_ID_EDIT, m_Idcard);
	DDX_Text(pDX, IDC_MARITAL_EDIT, m_Marital);
	DDX_Text(pDX, IDC_MEMO_EDIT, m_Memo);
	DDX_Text(pDX, IDC_MOBILE_EDIT, m_Mobile);
	DDX_Text(pDX, IDC_NATION_EDIT, m_Nation);
	DDX_Text(pDX, IDC_OFFICE_EDIT, m_Office);
	DDX_Text(pDX, IDC_POLITICAL_EDIT, m_Political);
	DDX_Text(pDX, IDC_POSITION, m_Position);
	DDX_Text(pDX, IDC_TITLE_EDIT, m_Title);
	DDX_DateTimeCtrl(pDX, IDC_BIRTH, m_Birth);
	DDX_DateTimeCtrl(pDX, IDC_HIREDATE, m_HireDate);
	DDX_Text(pDX, IDC_UPPER_STATIC, m_Upper);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CEmpEditDlg, CDialog)
	//{{AFX_MSG_MAP(CEmpEditDlg)
	ON_BN_CLICKED(IDC_EMPSEL_BUTTON, OnEmpselButton)
	ON_BN_CLICKED(IDC_SETPHOTO_BUTTON, OnSetphotoButton)
	ON_WM_PAINT()
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEmpEditDlg message handlers

void CEmpEditDlg::OnOK() 
{
	// TODO: Add extra validation here
	UpdateData(TRUE);
	CEmployees emp;
	
	//將用戶輸入的數據賦值到對象dep中,為更新數據庫做準備
	emp.EmpName = m_EmpName;
	int index;
	index = m_Sex.GetCurSel();
	if (index == 0)
		emp.Sex = "男";
	else
		emp.Sex = "女";
	emp.Nationality = m_Nation;
	emp.Birth = m_Birth.Format("%Y-%m-%d");
	emp.Political_Party = m_Political;
	emp.Culture_Level = m_Culture;
	emp.Marital_Condition = m_Marital;
	emp.Family_Place = m_Family;
	emp.Id_Card = m_Idcard;
	emp.BadgeId = m_Badge;
	emp.Office_phone = m_Office;
	emp.Mobile = m_Mobile;
	emp.Files_Keep_Org = m_File;
	emp.Hukou = m_Hukou;
	emp.HireDate = m_HireDate.Format("%Y-%m-%d");
	emp.DepId = DepId;
	emp.Position = m_Position;
	emp.sTitle = m_Title;
	emp.State = m_State.GetCurSel() + 1;
	emp.UpperId = UpperId;
	emp.Memo = m_Memo;
	//自動保存填表人和填表時間
	m_Fillperson = curUser.UserName;
	CTime t = CTime::GetCurrentTime();
	m_Filltime = t.Format("%Y-%m-%d");

	emp.Fillin_Person = m_Fillperson;
	emp.Fillin_Time = m_Filltime;
	
	if (EmpId == 0)  //表示插入數據
		emp.sql_insert();
	else
	{
		//根據DepId的值更新記錄
		CString cEmpId;
		cEmpId.Format("%d", EmpId);
		emp.sql_update(cEmpId);
	}
	
	CDialog::OnOK();
}

void CEmpEditDlg::OnEmpselButton() 
{
	// TODO: Add your control notification handler code here
	UpdateData(TRUE);
	//打開選擇員工對話框
	CEmpSelDlg dlg;
	dlg.DoModal();	
	//根據用戶選擇設置員工信息
	m_Upper = dlg.EmpName;
	UpperId = dlg.EmpId;

	UpdateData(FALSE);
}

BOOL CEmpEditDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();
	
	// TODO: Add extra initialization here
	//設置性別
	if (cSex == "男")
		m_Sex.SetCurSel(0);
	else
		m_Sex.SetCurSel(1);
	//設置狀態
	m_State.SetCurSel(iState-1);	
	//如果是添加新員工,則將設置和刪除照片的按鈕置灰
	if (EmpId == 0)
		GetDlgItem(IDC_SETPHOTO_BUTTON)->EnableWindow(FALSE);
	else  //讀取照片圖像信息
	{
		//清除原圖像數據
		if(m_hBitmap)
		{
			DeleteObject(m_hBitmap);
			m_hBitmap = NULL;
		}
		//將當前員工記錄讀取到m_pRs對象中
		CString cEmpId;
		cEmpId.Format("%d", EmpId);
		//連接數據庫
		ADOConn m_AdoConn;
		m_AdoConn.OnInitADOConn();
		//設置SELECT語句
		_bstr_t vSQL;
		vSQL = "SELECT * FROM Employees WHERE EmpId=" + cEmpId;
		//執行SELETE語句
		_RecordsetPtr	m_pRs;
		m_pRs = m_AdoConn.GetRecordSet(vSQL);	

		//如果不存在此記錄,則將設置按鈕置灰并返回
		if(m_pRs->adoEOF || m_pRs->adoBOF)  
		{
			GetDlgItem(IDC_SETPHOTO_BUTTON)->EnableWindow(FALSE);
			return FALSE;
		}
		//讀取圖像字段的實際大小
		long lDataSize = m_pRs->GetFields()->GetItem("Photo")->ActualSize;
		char *m_pBuffer;  //定義緩沖變量
		if(lDataSize > 0)
		{
			//從圖像字段中讀取數據到varBLOB中
			_variant_t varBLOB;
			varBLOB = m_pRs->GetFields()->GetItem("Photo")->GetChunk(lDataSize);
			if(varBLOB.vt == (VT_ARRAY | VT_UI1))
			{
				if(m_pBuffer = new char[lDataSize+1])	//分配必要的存儲空間
				{	
					char *pBuf = NULL;
					SafeArrayAccessData(varBLOB.parray,(void **)&pBuf);
					memcpy(m_pBuffer,pBuf,lDataSize); ///復制數據到緩沖區m_pBuffer
					SafeArrayUnaccessData (varBLOB.parray);
					
					//將數據轉換為HBITMAP格式
					LPSTR hDIB;
					LPVOID lpDIBBits;
					BITMAPFILEHEADER bmfHeader;  //用于保存BMP文件頭信息,包括類型、大小、位移量等
					DWORD bmfHeaderLen;  //保存文件頭的長度

					bmfHeaderLen = sizeof(bmfHeader);  //讀取文件頭的長度
					//將m_pBuffer中文件頭復制到bmfHeader中
					strncpy((LPSTR)&bmfHeader, (LPSTR)m_pBuffer, bmfHeaderLen); 	
					if (bmfHeader.bfType != (*(WORD*)"BM"))   //如果文件類型不對,則返回
					{
						MessageBox("BMP文件格式不準確");
						return FALSE;
					}
					hDIB = m_pBuffer + bmfHeaderLen;  //將指針移至文件頭后面
					//讀取BMP文件的圖像數據,包括坐標及顏色格式等信息到BITMAPINFOHEADER對象
					BITMAPINFOHEADER &bmiHeader = *(LPBITMAPINFOHEADER)hDIB;
					//讀取BMP文件的圖像數據,包括坐標及顏色格式等信息到BITMAPINFO對象
					BITMAPINFO &bmInfo = *(LPBITMAPINFO)hDIB ;
					//根據bfOffBits屬性將指針移至文件頭后
					lpDIBBits = (m_pBuffer) + ((BITMAPFILEHEADER *)m_pBuffer)->bfOffBits;
					CClientDC dc(this);  //生成一個與當前窗口相關的CClientDC,用于管理輸出設置
					//生成DIBitmap數據
					m_hBitmap = CreateDIBitmap(dc.m_hDC,&bmiHeader,CBM_INIT,lpDIBBits,&bmInfo,DIB_RGB_COLORS);
				}
			}
		}
	}

	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}

void CEmpEditDlg::OnSetphotoButton() 
{
	// TODO: Add your control notification handler code here
	static char BASED_CODE szFilter[] = "BMP Files (*.bmp)|*.bmp|All Files (*.*)|*.*||";
	CFileDialog dlg(TRUE,"BMP",NULL,  OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,szFilter);
	if(dlg.DoModal() != IDOK)
		return;

	CString pathname = dlg.GetPathName();

	char *m_pBuffer;  //從BMP文件中讀取的數據存放在此變量中
	
	//@@@@@@@@@@   讀取BMP文件到m_pBuffer   @@@@@@@@@@
	CFile file;  //定義文件對象
	if( !file.Open(pathname, CFile::modeRead)) //以只讀方式打開文件
	{
		MessageBox("無法打開BMP文件");
		return;
	}
	DWORD m_filelen;  //用于保存文件長度
	m_filelen = file.GetLength();  //讀取文件長度
	m_pBuffer = new char[m_filelen + 1]; //根據文件長度分配數組空間
	if(!m_pBuffer)  //如果不空間不足則返回
	{
		MessageBox("無法分配足夠的內存空間");
		return;
	}
	if(file.ReadHuge(m_pBuffer, m_filelen) != m_filelen)  //讀取BMP文件到m_pBuffer中
	{
		MessageBox("讀取BMP文件時出現錯誤");
		return;
	}
	
	//@@@@@@@@@@   將BMP文件數據從m_pBuffer中轉換到m_hBitMap位圖句柄中
	LPSTR hDIB;
	LPVOID lpDIBBits;
	BITMAPFILEHEADER bmfHeader;  //用于保存BMP文件頭信息,包括類型、大小、位移量等
	DWORD bmfHeaderLen;  //保存文件頭的長度

	bmfHeaderLen = sizeof(bmfHeader);  //讀取文件頭的長度
	//將m_pBuffer中文件頭復制到bmfHeader中
	strncpy((LPSTR)&bmfHeader, (LPSTR)m_pBuffer, bmfHeaderLen); 	
	if (bmfHeader.bfType != (*(WORD*)"BM"))   //如果文件類型不對,則返回
	{
		MessageBox("BMP文件格式不準確");
		return;
	}
	hDIB = m_pBuffer + bmfHeaderLen;  //將指針移至文件頭后面
	//讀取BMP文件的圖像數據,包括坐標及顏色格式等信息到BITMAPINFOHEADER對象
	BITMAPINFOHEADER &bmiHeader = *(LPBITMAPINFOHEADER)hDIB;
	//讀取BMP文件的圖像數據,包括坐標及顏色格式等信息到BITMAPINFO對象
	BITMAPINFO &bmInfo = *(LPBITMAPINFO)hDIB ;
	//根據bfOffBits屬性將指針移至文件頭后
	lpDIBBits = (m_pBuffer) + ((BITMAPFILEHEADER *)m_pBuffer)->bfOffBits;
	CClientDC dc(this);  //生成一個與當前窗口相關的CClientDC,用于管理輸出設置
	//生成DIBitmap數據
	m_hBitmap = CreateDIBitmap(dc.m_hDC,&bmiHeader,CBM_INIT,lpDIBBits,&bmInfo,DIB_RGB_COLORS);
	
	//激活OnPaint()函數,顯示圖像
	Invalidate();
	//@@@@@@@@@@@  將圖像數據保存到數據庫中  @@@@@@@@@@@@@
	//將當前員工記錄讀取到m_pRs對象中
	CString cEmpId;
	cEmpId.Format("%d", EmpId);
	//連接數據庫
	ADOConn m_AdoConn;
	m_AdoConn.OnInitADOConn();
	//設置SELECT語句
	_bstr_t vSQL;
	vSQL = "SELECT * FROM Employees WHERE EmpId=" + cEmpId;
	//執行SELETE語句
	_RecordsetPtr	m_pRs;
	m_pRs = m_AdoConn.GetRecordSet(vSQL);	

	VARIANT			varBLOB;
	SAFEARRAY		*psa;  //定義數組
    SAFEARRAYBOUND	rgsabound[1];

	rgsabound[0].lLbound = 0;
	rgsabound[0].cElements = m_filelen;
	psa = SafeArrayCreate(VT_UI1, 1, rgsabound);  //創建數組
	for (long i = 0; i < (long)m_filelen; i++)  //將m_pBuffer中的圖像數據寫入數組psa
		SafeArrayPutElement (psa, &i, m_pBuffer++);
	varBLOB.vt = VT_ARRAY | VT_UI1;
	varBLOB.parray = psa;
	//調用AppendChunk()函數將圖像數據寫入Photo字段
	m_pRs->GetFields()->GetItem("Photo")->AppendChunk(varBLOB);
	//更新數據庫
	m_pRs->Update();
	//斷開與數據庫的連接
	m_AdoConn.ExitConnect();
}


void CEmpEditDlg::OnPaint() 
{
	CPaintDC dc(this); // device context for painting
	int x=512, y=24;
	int iWidth=72, iHeight=79;
	// TODO: Add your message handler code here
	if(!m_hBitmap)  //如果內存中沒有BMP數據,則返回
		return;
	HBITMAP tmpBitmap;  //用于保存輸出到屏幕的BMP數據
	CDC MemDC;  //CDC對象,用于輸出到屏幕
	MemDC.CreateCompatibleDC(&dc);
	tmpBitmap = (HBITMAP)MemDC.SelectObject(m_hBitmap);
	dc.BitBlt(x,y,iWidth,iHeight,&MemDC,0,0,SRCCOPY);
	MemDC.SelectObject(tmpBitmap);
	
	// Do not call CDialog::OnPaint() for painting messages
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲美女偷拍久久| 26uuu另类欧美| 亚洲一区二区三区四区不卡| 欧美综合天天夜夜久久| 亚洲一区二区三区小说| 欧美精品色一区二区三区| 日本三级韩国三级欧美三级| 精品国产精品网麻豆系列| 国模冰冰炮一区二区| 欧美国产一区视频在线观看| 色诱亚洲精品久久久久久| 亚洲影视在线观看| 欧美成人精品福利| av在线不卡观看免费观看| 亚洲国产欧美另类丝袜| 日韩女优av电影在线观看| 成人性视频免费网站| 夜色激情一区二区| 日韩欧美视频在线| 成人影视亚洲图片在线| 夜色激情一区二区| 久久久午夜精品| 在线免费观看一区| 国产综合色在线视频区| 中文字幕一区二区三区在线播放 | 风间由美一区二区av101| 日韩久久一区二区| 日韩欧美色电影| av在线综合网| 极品销魂美女一区二区三区| 亚洲日穴在线视频| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 国产馆精品极品| 亚洲曰韩产成在线| 国产亚洲女人久久久久毛片| 欧美自拍偷拍午夜视频| 国产在线精品一区二区| 亚洲国产三级在线| 亚洲成av人片在线观看无码| 精品不卡在线视频| 欧美片在线播放| 波多野结衣在线aⅴ中文字幕不卡| 婷婷国产在线综合| 亚洲蜜臀av乱码久久精品| 日韩欧美一二区| 欧美日韩国产天堂| 91亚洲男人天堂| 国产自产高清不卡| 天天射综合影视| 一区二区三区日韩精品| 国产日韩精品一区二区三区在线| 91精品婷婷国产综合久久竹菊| 99r国产精品| 国产99久久久国产精品潘金| 久久精品99国产精品| 亚洲一区二三区| 亚洲免费毛片网站| 国产精品久久久久久久蜜臀 | 国产精品美女一区二区在线观看| 日韩视频免费直播| 5858s免费视频成人| 欧美性猛交xxxx乱大交退制版| 成人爽a毛片一区二区免费| 久久精品国产亚洲a| 免费在线观看精品| 日本一区中文字幕| 日韩黄色片在线观看| 97se亚洲国产综合自在线观| 国产尤物一区二区| 国产一区激情在线| 国内精品写真在线观看| 美女尤物国产一区| 日产国产高清一区二区三区 | 亚洲免费观看在线视频| 欧美激情在线免费观看| 欧美韩国日本不卡| 中文字幕国产一区| 日韩一区在线看| 亚洲免费伊人电影| 亚洲国产精品久久艾草纯爱| 亚洲国产一区二区视频| 亚洲国产精品一区二区久久恐怖片| 亚洲综合在线免费观看| 亚洲午夜久久久久久久久电影院| 亚洲狠狠爱一区二区三区| 亚洲6080在线| 美腿丝袜一区二区三区| 国产一区不卡精品| 成人性视频网站| 在线精品视频免费观看| 欧美日韩久久不卡| 精品国产一区二区国模嫣然| 国产婷婷色一区二区三区在线| 中日韩免费视频中文字幕| 依依成人综合视频| 色综合天天综合狠狠| 色呦呦网站一区| 欧美日韩一区在线| 精品久久久久香蕉网| 欧美激情一区二区三区全黄| 亚洲日本va午夜在线影院| 亚洲与欧洲av电影| 国产资源精品在线观看| 不卡视频免费播放| 欧美人牲a欧美精品| 2020日本不卡一区二区视频| 国产精品私人自拍| 午夜久久久影院| 国产高清精品在线| 欧美亚洲综合在线| 26uuu国产电影一区二区| 日韩理论在线观看| 男女性色大片免费观看一区二区| 国产盗摄一区二区| 欧美美女视频在线观看| 久久亚洲捆绑美女| 亚洲妇熟xx妇色黄| 国产盗摄一区二区三区| 欧美日韩卡一卡二| 国产精品入口麻豆九色| 午夜视黄欧洲亚洲| av电影在线观看不卡| 91精品免费观看| 中文字幕亚洲不卡| 久久国产麻豆精品| 色94色欧美sute亚洲线路二| 精品人伦一区二区色婷婷| 一区二区三区日韩欧美精品| 国内外成人在线| 在线播放欧美女士性生活| 一区二区中文视频| 精品一区二区三区欧美| 欧美亚洲综合在线| 中文字幕日本不卡| 国产乱妇无码大片在线观看| 欧美色精品天天在线观看视频| 中文字幕精品一区| 国产在线一区观看| 337p亚洲精品色噜噜| 亚洲精品美腿丝袜| 成人激情免费视频| 久久综合久久久久88| 视频一区视频二区在线观看| 91网站最新地址| 亚洲国产高清不卡| 狠狠色综合色综合网络| 欧美久久高跟鞋激| 亚洲综合一区二区精品导航| caoporen国产精品视频| 久久久不卡影院| 久久精品国产亚洲a| 678五月天丁香亚洲综合网| 亚洲另类在线一区| 成人av集中营| 国产精品视频yy9299一区| 日韩丝袜美女视频| 五月天婷婷综合| 欧美在线免费视屏| 亚洲高清免费视频| 欧美日韩亚洲国产综合| 亚洲一区二区三区四区五区黄| 91亚洲精华国产精华精华液| 国产欧美1区2区3区| 国产a区久久久| 中文一区二区在线观看| 夫妻av一区二区| 中文字幕一区在线观看视频| a美女胸又www黄视频久久| 色天天综合色天天久久| 狠狠色丁香久久婷婷综| 欧美人妇做爰xxxⅹ性高电影| 亚洲伦理在线精品| 欧美三级电影网| 亚洲va韩国va欧美va精品| 精品视频1区2区| 偷窥国产亚洲免费视频| 欧美一区二区在线免费观看| 日韩av网站在线观看| 日韩久久久精品| 国产精品亚洲午夜一区二区三区 | 亚洲男人天堂av| 欧美日韩一区视频| 丝袜亚洲另类丝袜在线| 欧美一二三四在线| 国产自产高清不卡| 中文字幕人成不卡一区| 欧美午夜精品一区| 免播放器亚洲一区| 国产欧美日产一区| 91麻豆国产香蕉久久精品| 亚洲v日本v欧美v久久精品| 日韩欧美精品三级| 成人涩涩免费视频| 亚洲精品乱码久久久久久| 91精品国产综合久久久久| 国内成人精品2018免费看| 中文字幕一区二区在线观看| 欧美日韩免费在线视频| 久久福利视频一区二区| 成人免费一区二区三区视频 |