代码拉取完成,页面将自动刷新
// DlgPtzTrackParamCfg.cpp : implementation file
//
#include "stdafx.h"
#include "clientdemo.h"
#include "DlgPtzTrackParamCfg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CDlgPtzTrackParamCfg dialog
CDlgPtzTrackParamCfg::CDlgPtzTrackParamCfg(CWnd* pParent /*=NULL*/)
: CDialog(CDlgPtzTrackParamCfg::IDD, pParent)
{
//{{AFX_DATA_INIT(CDlgPtzTrackParamCfg)
m_nTrackTime = 0;
//}}AFX_DATA_INIT
m_lServerID = -1;
m_lChannel = -1;
m_iDevIndex = -1;
memset(&m_struPtzTrackParam,0,sizeof(m_struPtzTrackParam));
m_struPtzTrackParam.dwSize = sizeof(m_struPtzTrackParam);
}
void CDlgPtzTrackParamCfg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CDlgPtzTrackParamCfg)
DDX_Control(pDX, IDC_COMBO_AUTOTRACK_ENABLE, m_comboAutoTrackEnable);
DDX_Control(pDX, IDC_COMBO_TRACKMODE, m_comboTrackMode);
DDX_Text(pDX, IDC_EDIT_TRACKTIME, m_nTrackTime);
//}}AFX_DATA_MAP
//DDX_Text(pDX, IDC_EDIT_TRACKSTATUS, m_sTrackStatus);
}
BEGIN_MESSAGE_MAP(CDlgPtzTrackParamCfg, CDialog)
//{{AFX_MSG_MAP(CDlgPtzTrackParamCfg)
ON_BN_CLICKED(IDC_BTN_SAVE, OnBtnSave)
//}}AFX_MSG_MAP
// ON_BN_CLICKED(IDC_BTN_GETTRACKSTATUS, &CDlgPtzTrackParamCfg::OnBnClickedBtnGettrackstatus)
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDlgPtzTrackParamCfg message handlers
BOOL CDlgPtzTrackParamCfg::OnInitDialog()
{
CDialog::OnInitDialog();
InitCtrlState();
if (GetPtzTrackParam())
{
LoadWndContent();
}
return TRUE;
}
void CDlgPtzTrackParamCfg::InitCtrlState()
{
m_comboTrackMode.ResetContent();
char szLan[32] = "\0";
g_StringLanType(szLan,"一直跟踪","Track Always");
m_comboTrackMode.InsertString(0,szLan);
m_comboTrackMode.SetItemData(0,PTZ_TRACK_MODE_ALWAYS);
g_StringLanType(szLan,"跟踪指定时间","Track a Specified Time");
m_comboTrackMode.InsertString(1,szLan);
m_comboTrackMode.SetItemData(1,PTZ_TRACK_MODE_BYTIME);
g_StringLanType(szLan,"跟踪下一目标","Track Next Target");
m_comboTrackMode.InsertString(2,szLan);
m_comboTrackMode.SetItemData(2,PTZ_TRACK_MODE_NEXT);
}
BOOL CDlgPtzTrackParamCfg::GetPtzTrackParam()
{
BOOL bRet = FALSE;
DWORD dwReturn = 0;
if (!NET_DVR_GetDVRConfig(m_lServerID, NET_DVR_GET_PTZ_TRACK_PARAM,m_lChannel,&m_struPtzTrackParam,
sizeof(m_struPtzTrackParam),&dwReturn))
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_FAIL_T, "NET_DVR_GET_PTZ_TRACK_PARAM Chan[%d]", m_lChannel);
bRet = FALSE;
}
else
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_SUCC_T, "NET_DVR_GET_PTZ_TRACK_PARAM Chan[%d]", m_lChannel);
bRet = TRUE;
}
return bRet;
}
BOOL CDlgPtzTrackParamCfg::SetPtzTrackParam()
{
BOOL bRet = FALSE;
if (!NET_DVR_SetDVRConfig(m_lServerID, NET_DVR_SET_PTZ_TRACK_PARAM,m_lChannel,&m_struPtzTrackParam,
sizeof(m_struPtzTrackParam)))
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_FAIL_T, "NET_DVR_SET_PTZ_TRACK_PARAM Chan[%d]", m_lChannel);
bRet = FALSE;
}
else
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_SUCC_T, "NET_DVR_SET_PTZ_TRACK_PARAM Chan[%d]", m_lChannel);
bRet = TRUE;
}
return bRet;
}
void CDlgPtzTrackParamCfg::OnBtnSave()
{
SaveWndContent();
char szError[32] = "\0";
if (SetPtzTrackParam())
{
g_StringLanType(szError, "保存成功","Saved successfully");
}
else
{
g_StringLanType(szError, "保存失败","Save failed");
}
AfxMessageBox(szError);
}
void CDlgPtzTrackParamCfg::LoadWndContent()
{
m_nTrackTime = m_struPtzTrackParam.dwTrackTime;
int nCount = m_comboTrackMode.GetCount();
for (int i = 0; i < nCount; i++)
{
if (m_comboTrackMode.GetItemData(i) == m_struPtzTrackParam.byTrackMode)
{
m_comboTrackMode.SetCurSel(i);
break;
}
}
m_comboAutoTrackEnable.SetCurSel(m_struPtzTrackParam.byAutoTrackEnable);
UpdateData(FALSE);
}
void CDlgPtzTrackParamCfg::SaveWndContent()
{
UpdateData(TRUE);
m_struPtzTrackParam.dwSize = sizeof(m_struPtzTrackParam);
m_struPtzTrackParam.byTrackMode = m_comboTrackMode.GetItemData(m_comboTrackMode.GetCurSel());
m_struPtzTrackParam.dwTrackTime = m_nTrackTime;
m_struPtzTrackParam.byAutoTrackEnable = m_comboAutoTrackEnable.GetCurSel();
}
void CDlgPtzTrackParamCfg::OnBnClickedBtnGettrackstatus()
{
// TODO: 在此添加控件通知处理程序代码
NET_DVR_PTZTRACKSTATUS struPtzTrackStatus = {0};
char szLan[512] = {0};
NET_DVR_STD_CONFIG struCfg = {0};
struCfg.lpCondBuffer = &m_lChannel;
struCfg.dwCondSize = sizeof(m_lChannel);
struCfg.lpOutBuffer = &struPtzTrackStatus;
struCfg.dwOutSize = sizeof(struPtzTrackStatus);
memset(m_szStatusBuf, 0, ISAPI_STATUS_LEN);
struCfg.lpStatusBuffer = m_szStatusBuf;
struCfg.dwStatusSize = ISAPI_STATUS_LEN;
if (!NET_DVR_GetSTDConfig(m_lServerID,NET_DVR_GET_PTZTRACKSTATUS,&struCfg))
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_FAIL_T, "NET_DVR_GET_PTZTRACKSTATUS");
OutputDebugString(m_szStatusBuf);
sprintf(szLan, "Error Code:%d, Error Info:%s", NET_DVR_GetLastError(), NET_DVR_GetErrorMsg());
}
else
{
g_pMainDlg->AddLog(m_iDevIndex, OPERATION_SUCC_T, "NET_DVR_GET_PTZTRACKSTATUS");
sprintf(szLan,"dwSize:%d, ID:%d, LinkageType:%d", struPtzTrackStatus.dwSize, struPtzTrackStatus.byID,
struPtzTrackStatus.byLinkageType);
}
AfxMessageBox(szLan);
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。