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

📄 page3.cpp

📁 RAS高级编程是一个RAS拨号程序高级开发
💻 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 + -