惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 无之无

别了博客园! 即将没落的博客园?!!! SQL里ROWCOUNT的使用 阿里云的背后故事(希望别被关了) - 无之无 LINQ:是BUG还是~~~ 集合代理类的实现 WPF对绑定到数据的树初始化选择项 SilverLight中的数据绑定 [请教]关于 .NET 应用的几个问题请教!!!( 如何解决 自定义控件 构造被设计器删除? 遭遇品牌电脑的尴尬 面对VS2005,我遇到了BUG? FOREACH的遍历 该死的微软,该死的文档,该死的ExecuteCommand 怪异的Windows Form事件 - 无之无 MDI窗体关闭问题解决一例 .Net再发行包与强名称 托管与非托管的混合编程问题 关于WMI
Windows Form的初始化大小记录处理问题
无之无 · 2005-11-10 · via 博客园 - 无之无

要让系统记录在应用退出的时候主窗体的大小和状态,采取了WebMatrix中的实现技术:在窗体构造的时候从“记忆”中更新窗体的大小和状态,在窗体关闭的时候,把窗体的大小刷新到“记忆”中:

加载“记忆”:

   try
   
{
    
//设置窗体初始位置与大小状态
    string strInfo = this._applicationIdentity.GetSetting("WindowMaximized");
    
if ((strInfo != null&& strInfo.Equals("true"))
    
{
     
base.WindowState = FormWindowState.Maximized;
    }

    
else
    
{
     
base.WindowState = FormWindowState.Normal;
    }

    
//设置窗体大小区域
    strInfo = this._applicationIdentity.GetSetting("WindowLeft"false);
    
if ((strInfo != null&& (strInfo.Length != 0))
    
{
     
int iLeft = Convert.ToInt32(strInfo);
     strInfo 
= this._applicationIdentity.GetSetting("WindowTop"false);
     
int iTop = Convert.ToInt32(strInfo);
     strInfo 
= this._applicationIdentity.GetSetting("WindowWidth"false);
     
int iWidth = Convert.ToInt32(strInfo);
     strInfo 
= this._applicationIdentity.GetSetting("WindowHeight"false);
     
int iHeight = Convert.ToInt32(strInfo);
     
base.Bounds = new Rectangle(iLeft, iTop, iWidth, iHeight);
    }

    
else
    
{
     
base.Bounds = Screen.FromPoint(Cursor.Position).WorkingArea;
    }

    
base.StartPosition = FormStartPosition.Manual;
   }

   
catch (Exception err)
   
{
    MessageBox.Show(
this, err.Message);
   }



保存“记忆”:

  try
   
{
    
//保存窗体位置等状态信息
    if (base.WindowState == FormWindowState.Maximized)
    
{
     
this._applicationIdentity.SetSetting("WindowMaximized""true");
    }

    
else if (base.WindowState != FormWindowState.Minimized)
    
{
     
this._applicationIdentity.SetSetting("WindowMaximized"null);
     Rectangle rectangle1 
= base.Bounds;
     
this._applicationIdentity.SetSetting("WindowLeft", Convert.ToString(rectangle1.Left));
     
this._applicationIdentity.SetSetting("WindowTop", Convert.ToString(rectangle1.Top));
     
this._applicationIdentity.SetSetting("WindowWidth", Convert.ToString(rectangle1.Width));
     
this._applicationIdentity.SetSetting("WindowHeight", Convert.ToString(rectangle1.Height));
    }

   }

   
catch (Exception)
   
{
   }


现在发现一个问题:

我想把这两段代码写在基类中,结果出现问题:窗体在正常状态下的大小不会在加载时有效应用,分析原因就是基类的构造先执行而派生类的后执行,在设计派生类的时候,派生类在设计时有修改窗体尺寸的代码。

如果在派生类中把修改窗体大小的代码删除(在InitializeComponent中)是不现实的,于是想到“一招”:在窗体HandleCreated的时候进行处理,呵呵,正常状态的大小是解决了,但窗体再也没有办法在初始化的时候设置为最大化了,永远都是正常状态。

又一次狂晕!!