📄 page3.cpp
字号:
// Page3.cpp : implementation file
//
#include "stdafx.h"
#include "Afd.h"
#include "Page3.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
extern CAfdApp theApp;
/////////////////////////////////////////////////////////////////////////////
// CPage3 property page
IMPLEMENT_DYNCREATE(CPage3, CPropertyPage)
CPage3::CPage3() : CPropertyPage(CPage3::IDD)
{
//{{AFX_DATA_INIT(CPage3)
m_sLog = _T("");
m_sPing = _T("");
m_sSpeed = _T("");
m_sTermKB = _T("");
m_sTermTime = _T("");
m_sTimeout = _T("");
m_iTonePulse = -1;
m_bHangUp = FALSE;
m_bLog = FALSE;
m_bPing = FALSE;
m_bRedial = FALSE;
m_bSpeed = FALSE;
m_bTerm = FALSE;
m_bTimeout = FALSE;
m_bInterfaceStartMinimized = FALSE;
m_bInterfaceMinimizeOnConnect = FALSE;
//}}AFX_DATA_INIT
dwTraffic = new DWORD[200 * sizeof(DWORD)];
if (dwTraffic)
{
for (int i = 0; i < 200; i++) dwTraffic[i] = 0;
}
uTimer = UINT_MAX;
}
CPage3::~CPage3()
{
if (dwTraffic) delete [] dwTraffic;
}
void CPage3::DoDataExchange(CDataExchange* pDX)
{
CPropertyPage::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CPage3)
DDX_Text(pDX, IDC_EDIT_LOG, m_sLog);
DDX_Text(pDX, IDC_EDIT_PING, m_sPing);
DDX_Text(pDX, IDC_EDIT_SPEED, m_sSpeed);
DDX_Text(pDX, IDC_EDIT_TERMINATE, m_sTermKB);
DDX_Text(pDX, IDC_EDIT_TERMTIME, m_sTermTime);
DDX_Text(pDX, IDC_EDIT_TIMEOUT, m_sTimeout);
DDX_Radio(pDX, IDC_RADIO1, m_iTonePulse);
DDX_Check(pDX, IDC_CHECK_HANGUP, m_bHangUp);
DDX_Check(pDX, IDC_CHECK_LOG, m_bLog);
DDX_Check(pDX, IDC_CHECK_PING, m_bPing);
DDX_Check(pDX, IDC_CHECK_REDIAL, m_bRedial);
DDX_Check(pDX, IDC_CHECK_SPEED, m_bSpeed);
DDX_Check(pDX, IDC_CHECK_TERMINATE, m_bTerm);
DDX_Check(pDX, IDC_CHECK_TIMEOUT, m_bTimeout);
DDX_Check(pDX, IDC_CHECK_INTERFACE_START_MINIMIZED, m_bInterfaceStartMinimized);
DDX_Check(pDX, IDC_CHECK_INTERFACE_START_MINIMIZED2, m_bInterfaceMinimizeOnConnect);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CPage3, CPropertyPage)
//{{AFX_MSG_MAP(CPage3)
ON_WM_DESTROY()
ON_WM_TIMER()
ON_BN_CLICKED(IDC_BUTTON_FILE_LOG, OnButtonFileLog)
ON_BN_CLICKED(IDC_BUTTON_VEW_LOG, OnButtonVewLog)
ON_BN_CLICKED(IDC_CHECK_HANGUP, OnCheckHangup)
ON_BN_CLICKED(IDC_CHECK_LOG, OnCheckLog)
ON_BN_CLICKED(IDC_CHECK_PING, OnCheckPing)
ON_BN_CLICKED(IDC_CHECK_REDIAL, OnCheckRedial)
ON_BN_CLICKED(IDC_CHECK_SPEED, OnCheckSpeed)
ON_BN_CLICKED(IDC_CHECK_TERMINATE, OnCheckTerminate)
ON_BN_CLICKED(IDC_CHECK_TIMEOUT, OnCheckTimeout)
ON_BN_CLICKED(IDC_RADIO1, OnRadio1)
ON_BN_CLICKED(IDC_RADIO2, OnRadio2)
ON_EN_KILLFOCUS(IDC_EDIT_LOG, OnKillfocusEditLog)
ON_EN_KILLFOCUS(IDC_EDIT_PING, OnKillfocusEditPing)
ON_EN_KILLFOCUS(IDC_EDIT_SPEED, OnKillfocusEditSpeed)
ON_EN_KILLFOCUS(IDC_EDIT_TERMINATE, OnKillfocusEditTerminate)
ON_EN_KILLFOCUS(IDC_EDIT_TERMTIME, OnKillfocusEditTermtime)
ON_EN_KILLFOCUS(IDC_EDIT_TIMEOUT, OnKillfocusEditTimeout)
ON_BN_CLICKED(IDC_CHECK_INTERFACE_START_MINIMIZED, OnCheckInterfaceStartMinimized)
ON_BN_CLICKED(IDC_CHECK_INTERFACE_START_MINIMIZED2, OnCheckInterfaceStartMinimized2)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CPage3 message handlers
//初始化属性页
BOOL CPage3::InitPropertyPage()
{
if (!dwTraffic) return FALSE;
CString sModFileName;
//获得完整的路径和文件名
GetModuleFileName(NULL, sModFileName.GetBuffer(MAX_PATH), MAX_PATH);
sModFileName.ReleaseBuffer();
sModFileName.MakeReverse();
m_sLog = sModFileName.Right(sModFileName.GetLength() - sModFileName.Find('\\'));
m_sLog.MakeReverse();
m_sLog += _T("afd.log");
UpdateData(FALSE);
LoadAllFromIni();
dwInitBytesRecv = theApp.pPerf[PERF_BytesRecvd]->GetData();
dwInitBytesSent = theApp.pPerf[PERF_BytesXmit]->GetData();
TimeBeginSession = CTime::GetCurrentTime();
LastTrafficCheck = CTime::GetCurrentTime();
LastPingCheck = CTime::GetCurrentTime();
if (UINT_MAX == uTimer) uTimer = SetTimer(1, 1000 * 60, NULL);
theApp.LOG("Program started.");
return TRUE;
}
BOOL CPage3::OnInitDialog()
{
CPropertyPage::OnInitDialog();
return TRUE;
}
void CPage3::OnDestroy()
{
KillTimer(uTimer);
theApp.LOG("Program finished.");
theApp.LOG("-----------------");
CPropertyPage::OnDestroy();
}
//定时器事件
void CPage3::OnTimer(UINT nIDEvent)
{
for (int i = 199; i > 0; i--) dwTraffic[i] = dwTraffic[i - 1];
DWORD dwBytesSent = theApp.pPerf[PERF_BytesXmit]->GetData();
dwBytesSent -= dwInitBytesSent;
DWORD dwBytesRecv = theApp.pPerf[PERF_BytesRecvd]->GetData();
dwBytesRecv -= dwInitBytesRecv;
dwTraffic[0] = dwBytesSent + dwBytesRecv;
BOOL bConnected = theApp.IsConnected();
// if (m_bPing && bConnected)
{
CTime ttt = CTime::GetCurrentTime();
CTimeSpan ts = ttt - LastPingCheck;
if (ts.GetTotalSeconds() >= atol(m_sPing) * 60) //
{
LastPingCheck = CTime::GetCurrentTime();
PingISPServer();
}
}
//
if (m_bTerm && bConnected)
{
CTime ttt = CTime::GetCurrentTime();
CTimeSpan ts = ttt - LastTrafficCheck;
if (ts.GetTotalSeconds() >= atol(m_sTermTime) * 60)
{
LastTrafficCheck = CTime::GetCurrentTime();
DWORD dw = 0;
int iTrafficTime = atol(m_sTermTime);
if (iTrafficTime > 180) iTrafficTime = 180;
for (i = 0; i < iTrafficTime; i++)
dw += dwTraffic[i];
DWORD dwTrafficKB = (DWORD) atol(m_sTermKB) * 1024;
if (dw <= dwTrafficKB)
{
CString sss; sss.LoadString(IDS_DISCONNECT_LOW_TRAFFIC);
theApp.SetLastCallText(sss);
theApp.LOG("Disconnected due to low traffic.");
TRACE("Disconnected due to low traffic.\n");
theApp.PushBigButton();
}
}
}
CPropertyPage::OnTimer(nIDEvent);
}
BOOL CPage3::OnSetActive()
{
return CPropertyPage::OnSetActive();
}
void CPage3::OnButtonFileLog()
{
UpdateData();
CString sss = m_sLog;
if (sss.IsEmpty()) sss = "*.*";
CFileDialog dlg(TRUE, NULL, sss,
OFN_EXPLORER | OFN_OVERWRITEPROMPT, "*.*", NULL);
int i = dlg.DoModal();
if (i != IDOK) return;
m_sLog = dlg.GetPathName();
UpdateData(FALSE);
SaveAllToIni();
}
void CPage3::OnButtonVewLog()
{
UpdateData();
if (!m_sLog.IsEmpty())
ShellExecute(0,"open", m_sLog, NULL, NULL, SW_SHOW);
}
void CPage3::OnCheckHangup()
{
SaveAllToIni();
}
void CPage3::OnCheckLog()
{
SaveAllToIni();
}
void CPage3::OnCheckPing()
{
SaveAllToIni();
// 镥骳蜞眍忤螯 磬鬣朦睇
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -