⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 medselectiondlg.cpp

📁 还不错
💻 CPP
字号:
// MedSelectionDlg.cpp : implementation file
//

#include "stdafx.h"
#include "HosptialMan.h"
#include "MedSelectionDlg.h"
#include "columns.h"
#include "column.h"
#include "COMDEF.H"
#include "_recordset.h"

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

/////////////////////////////////////////////////////////////////////////////
// CMedSelectionDlg dialog


CMedSelectionDlg::CMedSelectionDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CMedSelectionDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CMedSelectionDlg)
		// NOTE: the ClassWizard will add member initialization here
	//}}AFX_DATA_INIT
}


void CMedSelectionDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CMedSelectionDlg)
	DDX_Control(pDX, IDC_ADODC1, m_AdoMed);
	DDX_Control(pDX, IDC_ADODC2, m_AdoType);
	DDX_Control(pDX, IDC_DATACOMBO1, m_Type);
	DDX_Control(pDX, IDC_MEDICINE_DATAGRID, m_DataGrid);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CMedSelectionDlg, CDialog)
	//{{AFX_MSG_MAP(CMedSelectionDlg)
	ON_BN_CLICKED(IDC_SEL_BUTTON, OnSelButton)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CMedSelectionDlg message handlers

BEGIN_EVENTSINK_MAP(CMedSelectionDlg, CDialog)
    //{{AFX_EVENTSINK_MAP(CMedSelectionDlg)
	ON_EVENT(CMedSelectionDlg, IDC_DATACOMBO1, 1 /* Change */, OnChangeDatacombo1, VTS_NONE)
	//}}AFX_EVENTSINK_MAP
END_EVENTSINK_MAP()

void CMedSelectionDlg::RefreshData()
{
	CString cSql;
	cSql = "Select m.MedId,m.Flag,(CASE WHEN m.Flag=0 THEN '中药' ELSE '西药' END) AS 种类,";
	cSql += "m.MedName AS 药品名称,m.TypeId,b.TypeName AS 类别,";
	cSql += "m.UnitId,b1.TypeName AS 单位,m.BuyPrice AS 进货价格,m.SalePrice AS 门诊价格,";
	cSql += "m.Total AS 库存数量 From Medicine m,BaseType b,BaseType b1 ";
	cSql += "Where b.TypeId=2 AND m.TypeId=b.Id AND m.UnitId=b1.Id AND b1.TypeId=3";
	// 查询条件(类别)是否为空
	if(m_Type.GetBoundText()!="")
	{
		cSql += " AND m.TypeId="+m_Type.GetBoundText();
	}
//	MessageBox(cSql);
	m_AdoMed.SetRecordSource(cSql);
	m_AdoMed.Refresh();
	// 设置列宽度
	_variant_t vIndex;
	vIndex = long(0);
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(0);
	vIndex = long(1);
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(0);
	vIndex = long(2);  // 药品种类
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(40);
	vIndex = long(3);  // 药品名称
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(100);
	vIndex = long(4);  // 类别
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(0);
	vIndex = long(5);  // 类别
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(60);
	vIndex = long(6);  // 单位
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(0);
	vIndex = long(7);  // 单位
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(30);
	vIndex = long(8);  // 进货价格
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(80);
	vIndex = long(9);  // 门诊价格
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(80);
	vIndex = long(10);  // 库存数量
	m_DataGrid.GetColumns().GetItem(vIndex).SetWidth(80);
}

void CMedSelectionDlg::OnChangeDatacombo1() 
{
	// TODO: Add your control notification handler code here
	RefreshData();
}

BOOL CMedSelectionDlg::OnInitDialog() 
{
	CDialog::OnInitDialog();
	
	// TODO: Add extra initialization here
	RefreshData();
	return TRUE;  // return TRUE unless you set the focus to a control
	              // EXCEPTION: OCX Property Pages should return FALSE
}

void CMedSelectionDlg::OnSelButton() 
{
	if(m_AdoMed.GetRecordset().GetEof())
	{
		MessageBox("请选择记录!");
		return;
	}
	Reg_ItemId = m_DataGrid.GetItem(0);			//药品编号
	Reg_ItemName = m_DataGrid.GetItem(3);		//药品名称
	Reg_ItemUnit = m_DataGrid.GetItem(7);		//药品单位
	Reg_ItemSalePrice = m_DataGrid.GetItem(9);	//门诊价格
	Reg_ItemTotal = m_DataGrid.GetItem(10);		//药品数量
	OnOK();	
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -