如何使win98/95应用程序具用记忆技巧
发表时间:2024-06-16 来源:明辉站整理相关软件相关文章人气:
[摘要]很多应用程序都具有自动记忆应用程序状态的功能。这些状态包括应用程序窗口和位置和大小。工具栏的位置与排列方式以及程序界面元素的其化状态。这种功能在下次启动应用程序后进入上次的运行状态,使用户只需一次界面布局便可永久使用,极其方便。在win98/95系统中,应用程序的有关信息是保存在注册表中,所以在应...
很多应用程序都具有自动记忆应用程序状态的功能。这些状态包括应用程序窗口和位置和大小。工具栏的位置与排列方式以及程序界面元素的其化状态。这种功能在下次启动应用程序后进入上次的运行状态,使用户只需一次界面布局便可永久使用,极其方便。
在win98/95系统中,应用程序的有关信息是保存在注册表中,所以在应用程序中实现状态的保存与恢复,首先应弄懂与窗口。工具栏和注册表等用关的函数和数据结构的用法。
一。用关窗口和工具栏的记忆函数
1。读取窗口状态函数
BOOL Getwindowplacement(WINDOWPLACEMENT wp)
2.设置窗口状态函数
BOOL Setwindowplacement(WINDOWPLACEMENT wp)
3.保存工具栏状态函数
void SaveBarState(-T(CString))
4.恢复工具栏状态函数
void LoadBarState(-T(CString))
其他工具的状态保存与恢复函数请参阅联机帮助
二。用关注册和字符串的记忆函数
1. 读取注册表中的字符串函数
CString AfxGetApp()->GetProfileString(szString,......);
2.将字符串写入注册表函数
void WriteProfileString(xzString,......,szBuffer);
3.读取注册表中参数值函数
int GetProdileint(-T("General"),-T("ColumnsT"),Default));
4:将字符串转换成变量函数
int _stscanf(strBuffer,szFormat,nParamenter)
5:将变量转换成字符串函数
void wsprintf(szBuffer,szFormat,nParamenter)
三,有关窗口状态记忆和数据结构
窗口状态在保存和恢复时都必须使用数据结构,WINDOWPLACDMENT其具体结构如下:
struct WINDOWPLACEMENT{
UINT wp.flags,//窗口状态标志
UINT wp.showCmd,//窗口显示状态
int wp.ptMinPosition.x,//窗口最小化x坐标
int WP.ptMinPosition.x,//窗口最小化y坐标
int wp.ptMaxPosition.x,//窗口最大化x坐标
int wp.ptMaxPostion.y,//窗口最大化y坐标
int wp.rcNormalPosition.left,//窗口正常时左坐标
int wp.rcNormalPosition.top,//窗口正常时顶坐标
int wp.rcNormalPosition.right,//窗口正常时右坐标
ent wp.rcNormalPosition.bottom//窗口正常时底坐标
}LPWINDOWPLACEMENT
四,记忆窗口和工具栏状态的注意事项
要正确保存和恢复应用程序界面状态,必须对应用于程序窗口和工具栏窗口等均进行保存和恢复,这需要在应用程序的建立和关闭过程功能函数中均进行状态处理。
虽然SaveBarState()和LoadBarState()函数可以保存和恢复工具栏的所有默认位置和状态,但用户自己实现的功能参数部分并不能被保存,所以应单独编写这些参数的保存代码。如工具栏的排序列格式,列参数,颜色状态标志和是否存在动态提示功能标志等。
五,记忆应用程序状态的实现步骤
1,首先利用类向导ClassWizard为已建立的应用程序类增加关闭WM-CLOSE消息处理功能函数OnClose().
2,在MainFrm.cpp中为应用程序状态设置成员变量
satic TCHAR BASED-CODE szSetion[]=-T("Settings"):
static TCHAR BASED-CODE szWindowPos[]=-T("WindowPos"):
static TCHAR szFormat[]-T(%u,%u,%d,%d,%d,%d,%d,%d,%d,%d"):
3,编制窗口位置状态读取和定入函数
static BOOL PASCAL NEAR ReadWindowPlacement(
LPWINDOWPLACEMENT pwp)
{//窗口位置状态读取函数,从注册文件中
CString strBuffer=AfxGetApp()->GetProfileString(szSection,szWindowpos);
if(strBuffer,IsEmpty()) return FALSE;
WINDOWPLACEMENT wp;//窗口位置数据结构
int nRead=-stscanf(strBuffer,szFonmat,
&wp.flags,&wp,showCmd,//为数据结构读取数值
&wp.[tMinposition.x,&wp.ptMinposition.y,
&wp.ptMaxposition.x,&wp.ptMaxposition.y,
&wp.rcNormalplsition,left,&wp.rcNormalposition.top,
&wp.rcNormalposition.right,&wp.rcNormalposition.bot,tom);
if(nRead!=10) return FALSE;
wp.length=sizeof wp;//结构大小
*pwp=wp; //结构传递
return TRUE;
}
static void PASCAL NEAR WriteWindowPlacement(
LPWINDOWPLACEMENT pwp)
{//窗口位置状态写入函数,定到注册文件
TCHAR szBuffer[sizeof("-32767")*8+sizeof("65535")*21];
wsprintf(szBuffer,szFormat,//将参数值转换为字符串
pwp->flags.pwp_>showCmd,
pwp_>ptMinPosition.x.pwp->ptMinposition.y,
pwp->ptMaxPosition,x,pwp->ptMaxPosition.y,
pwp->rcNormalPosition,left,pwp->rcNormalPosition.top,
pwp=rcNormalPosition.pwp=>rcNormalPosition.bottom);
AfxGetApp()->WriteProfileString(xzSection.szWindowPos.szBuffer);
}
4,在应用程序建立函数OnCreate()中增加状态读取和设置功能
WINDOWPLACEMENT wp;//保存主窗口及工具栏窗口位置状态
if (ReadWindoePlacement(&wp))//读取位置状态信息
SetWindowPlacement(&wp);//设置位置状态信息
5,在应用程序建立函数NnCreate()中增加工具栏等状态恢复功能
m-wndDockToolBar.SetColumns(AfxGetApp()-GetProfileInt(-T("General"),-T("ColumnsT"),3));//恢复列格式,默认为3m-wndDockNextBar.SetColumns(AfxGetApp()->GetProfileInt(-T("General"-T("ColumnsN"),3));
LoadBarState(-T("General"));//恢复保存的状态和位置......//其它工具状态的恢复
6。在应用程序关闭函数OnClose()中完善状态保存功能
void CMainFrame::OnClose()
{ //保存工具栏等的状态
SaveBarState(-T("General"))//保存工具栏状态......//其它工具状态的保存
AfxGetApp()->WriteProfileInt(-T("General"),//写入列数
-T("ColumnsT"),m-wndDockTAoolBar.GetColumns());
AfxGetDApp ()=>WriteProfileInt(-T("General"),//写入列数
-T("ColumnsN"),m-wndDockNextBar.GetColumns());
AfxGetApp()->WriteProfileInt(-T("General"),
-T("Color"),(m-bColor!=0));//写入颜色值
AfxGetApp()->WriteProfileInt(-T("General"),
-T("ToolTips"),(m-bToolTips!=0));//写入提示功能
WINDOWPLACEMENT wp;
wp.length=sizeof wp;
if (GetWindowPlacement(&wp)){
wp.flags=0;
if (IsZoomed()) wp.flags =WPF=RESTORETOMAXIMIZED;//如果窗口被放大,则保存为最大化状态
WriteWindowPlacement(&wp);
}
CFrameWnd::OnClose();
}