data:image/s3,"s3://crabby-images/2f91e/2f91ef5132b5002a4243cdfd49af224db3e3853a" alt="Visual C#通用范例开发金典"
第1章 窗体与界面设计
● 菜单的使用
● 窗体的设计
● 对话框的使用
● MDI应用程序
1.1 菜单应用
我们经常需要对菜单进行操作,使菜单满足各种操作需求,使界面更加美观,软件更加人性化。本节主要介绍菜单的使用,通过以下实例,可以帮助用户实现菜单的创建、菜单事件的响应及一些特殊的菜单操作。
1.1.1 创建基本菜单
范例1-1 创建专业化菜单
实例位置:光盘\ch01\1-1
范例说明
About the Example
本范例讲解如何创建专业化的菜单,请注意菜单控件MenuStrip的使用。程序运行效果如图1-1和图1-2所示。
data:image/s3,"s3://crabby-images/18478/1847819e6da31484a7395ad2e3b371714e651ed6" alt=""
图1-1 基本菜单界面
data:image/s3,"s3://crabby-images/b7720/b77207605f1444e9f806667e6aacf4729ef71305" alt=""
图1-2 带级联的菜单界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件拖放到设计界面上,单击MenuStrip控件的Type Here文本区域,可以输入菜单项的名称,如&File,然后按下回车键。
3.在File下面的文本区域中输入如下内容,创建一个文件菜单。
&New &Open - &Font - &Save &Exit
创建完成后,菜单如图1-1所示,其中,“-”符号会自动变成菜单项之间的分隔线。
4.实际应用程序的菜单应该呈现级联样式,单击【Font】菜单项,在其右侧会出现子菜单。
可在其文本区域输入如下内容,创建一个关于字体的子菜单:
&Bold &Italic &Underline
最终效果如图1-2所示。
抛砖引玉
About the Guidance
可以按照上述创建过程创建多个主菜单和子菜单。
提示:
用户可以选择想要操作的菜单项,但由于菜单项没有制作相应的操作,所以,鼠标点击时没有任何反应。本书的范例1-2将详细讲解如何触发菜单的相应事件。
范例1-2 创建右键菜单
实例位置:光盘\ch01\1-2
范例说明
About the Example
本范例讲解如何创建右键菜单,重点请注意菜单控件ContextMenuStrip的使用。程序运行效果如图1-3和图1-4所示。
data:image/s3,"s3://crabby-images/4ef07/4ef07d4f6f6249563774fa2e304ce3b329a2f7ca" alt=""
图1-3 程序设计界面
data:image/s3,"s3://crabby-images/d280c/d280cc8d463c467779b2ccc1eaf49283900e4374" alt=""
图1-4 程序运行界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把ContextMenuStrip控件拖放到设计界面上,Name属性设置为“cmMenu”。
3.单击ContextMenuStrip控件的Type Here文本区域,可以输入菜单项的名称,如&New,然后按下回车键。
4.创建完成后,菜单如图1-3所示。
5.添加RichTextBox控件,设置Name属性为“rchShow”。
6.设置Form和RichTextBox的ContextMenuStript属性为“cmMenu”。
7.双击ContextMenuStrip控件的菜单项,添加Open事件。
程序代码
Codes
private void miOpen_Click(object sender, EventArgs e) { OpenFileDialog dlgOpen = new OpenFileDialog(); dlgOpen.Filter = "文本文件(*.txt)|*.txt"; if (dlgOpen.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(dlgOpen.FileName,RichTextBoxStreamType .PlainText); } }
范例1-3 在菜单中添加图标
实例位置:光盘\ch01\1-3
范例说明
About the Example
本范例实现的是为每个菜单项添加图标,使菜单更专业化,更像Office的应用程序菜单。程序运行效果如图1-5和图1-6所示。
data:image/s3,"s3://crabby-images/a10fc/a10fc7f2f1b86caac78dd5f184e85709bb2550a6" alt=""
图1-5 设置图标前的菜单界面
data:image/s3,"s3://crabby-images/1702d/1702db2e6300cd25197aa69ad354033da9c420c9" alt=""
图1-6 设置图标后的菜单界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件拖放到设计界面上,创建【New】和【Open】菜单项,如图1-5所示。
3.单击【New】菜单项,把Name属性改为“miNew”,单击Image属性后面的图标,弹出选择资源对话框,可以挑选在菜单项上显示的图标,如图1-6所示。
4.【Open】菜单项的设置同上。
范例1-4 菜单事件的响应
实例位置:光盘\ch01\1-4
范例说明
About the Example
本范例是在前一例的基础上创建各个菜单项的响应事件,使用户单击菜单时能执行相应的操作。程序运行效果如图1-7和图1-8所示。
data:image/s3,"s3://crabby-images/96c5c/96c5ce2c286dbb4306f1bad2ef3ee33f02d3b2b7" alt=""
图1-7 基本菜单界面
data:image/s3,"s3://crabby-images/64abd/64abd798b42a4bc1a0d153d04533aa15ad29c26f" alt=""
图1-8 RichTextBox属性设置
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件拖放到设计界面上,按照前一例的方法创建菜单界面,如图1-7所示。
3.将RichTextBox控件拖放入设计界面,并在属性面板修改Name属性为“rchShow”,Dock属性改为“Fill”,如图1-8所示。
4.双击各个菜单项,会出现代码界面,并自动添加Click事件。输入代码,实现各个菜单功能。
5.输入所有菜单项的代码,运行程序,单击菜单即可实现相应功能。
程序代码
Codes
1.打开一个文件(双击【Open】菜单项)
private void miOpen_Click(object sender, EventArgs e) { try { //打开文件对话框 OpenFileDialog ofd = new OpenFileDialog(); //对话框标题 ofd.Title = "打开文件"; //设置打开文件类型 ofd.Filter = "TextDocument(*.rtf)|*.rtf"; if (ofd.ShowDialog() == DialogResult.OK) { //文本框显示文件内容 this.rchShow.LoadFile(ofd.FileName, RichTextBoxStreamType.PlainText); this.Text = ofd.FileName; } } catch(IOException ex) { MessageBox.Show(ex.Message); } }
2.设置字体为粗体(双击【Bold】菜单项)
private void miBold_Click(object sender, EventArgs e) { Font oldFont=this.rchShow.SelectionFont; Font newFont; if (oldFont.Bold) { newFont = new Font(oldFont, oldFont.Style & ~FontStyle.Bold); } else { newFont = new Font(oldFont,oldFont.Style|FontStyle.Bold); } this.rchShow.SelectionFont = newFont; }
3.设置字体为斜体(双击【Italic】菜单项)
private void miItalic_Click(object sender, EventArgs e) { Font oldFont = this.rchShow.SelectionFont; Font newFont; if (oldFont.Italic) { newFont = new Font(oldFont, oldFont.Style & ~FontStyle.Italic); } else { newFont = new Font(oldFont, oldFont.Style | FontStyle.Italic); } this.rchShow.SelectionFont = newFont; }
4.设置字体有下划线(双击【Underline】菜单项)
private void miUnderline_Click(object sender, EventArgs e) { Font oldFont = this.rchShow.SelectionFont; Font newFont; if (oldFont.Underline) { newFont = new Font(oldFont, oldFont.Style &~FontStyle.Underline); } else { newFont = new Font(oldFont, oldFont.Style | FontStyle.Underline); } this.rchShow.SelectionFont = newFont; }
5.退出程序(双击【Exit】菜单项)
private void miExit_Click(object sender, EventArgs e) { Application.Exit(); }
1.1.2 菜单的特殊操作
范例1-5 动态合并菜单
实例位置:光盘\ch01\1-5
范例说明
About the Example
开发过MDI窗体的读者可能知道,当MDI子窗体最大化时,子窗体和主窗体的菜单能够自动合并。本范例将实现这一个功能。程序运行效果如图1-9和图1-10所示。
data:image/s3,"s3://crabby-images/b9d22/b9d22d25a058637ced7634c65b3d365f20ad547a" alt=""
图1-9 父窗体界面
data:image/s3,"s3://crabby-images/60d4f/60d4f322b52db2b694c75c264e747596763e1b20" alt=""
图1-10 子窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.选择窗体,修改相应属性。注意将IsMdiContainer的属性修改为“True”。
3.添加两个菜单控件MenuStrip,添加如下菜单项,并且设置相应属性。
4.在项目上单击鼠标右键,选择【添加】→【添加新项目】命令,输入名称frmEditor,添加MDI子窗口。
程序代码
Codes
1.父窗体构造函数
public frmContainer() { InitializeComponent(); //显示孩子窗口 frmEditor child = new frmEditor(this); child.Show(); }
2.子窗口构造函数
public frmEditor(frmContainer parent) { InitializeComponent(); //设置子窗口的父窗口 this.MdiParent = parent; }
提示:
设置为MatchOnly的菜单项不能在菜单之间移动,但对于&File,两个菜单项的文本匹配,它们的菜单项是可以合并的。【File】菜单项是根据MergeIndex属性进行合并的。MergeIndex为MatchOnly的菜单项原地不动,其他菜单项的MergeIndex属性为“Insert”。
范例1-6 存放历史信息的菜单
实例位置:光盘\ch01\1-6
范例说明
About the Example
本范例将实现以下功能:打开一个新的对话框,可以在菜单下显示打开历史信息,并且安排它们的位置。程序运行效果如图1-11和图1-12所示。
data:image/s3,"s3://crabby-images/fb406/fb406fead145cdb65086f7ec61acfcb2e1d2edd2" alt=""
图1-11 父窗体界面
data:image/s3,"s3://crabby-images/927dd/927dd3487e6dbd67ec4b34c81723a6a95e6a81a9" alt=""
图1-12 子窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.选择窗体,修改相应属性。注意将IsMdiContainer的属性修改为“True”。
3.添加菜单控件MenuStrip,在项目上单击鼠标右键,选择【添加】→【添加新项目】命令,输入名称FrmContainer,创建父窗体,输入名称frmChild,创建子窗体,如图1-11和图1-12所示。
程序代码
Codes
1.PEnd Sub双击frmContainer窗体,声明一个私有变量,用于统计子窗体的个数
private int count;
2.修改frmContainer的构造函数
public frmContainer() { InitializeComponent(); count = 1; frmChild newChild = new frmChild(this, count); newChild.Show(); }
3.双击【打开一个新的子窗口】菜单,输入代码
private void miNew_Click(object sender, EventArgs e) { frmChild newChild = new frmChild(this,++count); newChild.Show(); }
4.修改frmChild的构造函数
public frmChild(frmContainer parent,int count) { InitializeComponent(); this.MdiParent = parent; this.Text = "子窗口" + count.ToString(); }
范例1-7 显示和隐藏菜单
实例位置:光盘\ch01\1-7
范例说明
About the Example
本范例是通过菜单项的Checked和CheckOnClick属性实现菜单的显示和隐藏功能。程序运行效果如图1-13和图1-14所示。
data:image/s3,"s3://crabby-images/3f3ad/3f3ad10e9a00e0db637a29d4de338fd6d34c54fe" alt=""
图1-13 箭头形窗体运行界面
data:image/s3,"s3://crabby-images/06159/06159e561018308c612c482730a65bebe33f0259" alt=""
图1-14 箭头形窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件拖放到设计界面上,并添加【操作】和【帮助】菜单,如图1-13所示。
3.给【操作】菜单添加【显示帮助菜单】菜单项,并且修改其属性CheckOnClick为“True”,修改属性Checked为“True”。如图1-14所示。
4.选择【显示帮助菜单】菜单的CheckedChanged事件,双击添加事件处理程序,以实现菜单的显示和隐藏功能。
程序代码
Codes
显示和隐藏菜单
private void miShowHelp_CheckedChanged(object sender, EventArgs e) { //参数sender传入的参数设置为ToolStripMenuItem控件 ToolStripMenuItem mi = sender as ToolStripMenuItem; miHelp.Visible = mi.Checked; }
范例1-8 显示菜单中的选中标记
实例位置:光盘\ch01\1-8
范例说明
About the Example
本范例实现用户自定义显示或隐藏菜单项。程序运行效果如图1-15和图1-16所示。
data:image/s3,"s3://crabby-images/6e5d7/6e5d79feaad28cd38a9631033e810235e127aca8" alt=""
图1-15 窗体界面
data:image/s3,"s3://crabby-images/bb63b/bb63b1b2d43e0d54520145c6078ccfafa0e6c503" alt=""
图1-16 属性设置界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件拖放到设计界面上,并添加【Show Help Menu】和【Help】菜单,前一个菜单项的Name属性为“miShow”,后一个菜单项的Name属性为“miHelp”,如图1-15所示。
3.选中【Show Help Menu】菜单,设置属性Checked为“True”,CheckOnClick为“True”,CheckState为“Checked”。如图1-16所示。
4.选择【Show Help Menu】菜单的CheckedChanged事件,双击添加事件处理程序。
程序代码
Codes
private void miShow_CheckedChanged(object sender, EventArgs e) { ToolStripMenuItem tsmi = sender as ToolStripMenuItem; this.miHelp.Visible = tsmi.Checked; }
1.2 窗体应用
一个完善的界面不仅更加友好,而且可以使软件使用的效率得到极大的提高。本节主要介绍窗体的常用属性、设计方法及窗体的基本操作。
1.2.1 窗体的外观设置
范例1-9 设置窗体的标题栏
实例位置:光盘\ch01\1-9
范例说明
About the Example
本范例向用户展示如何自定义窗体标题和修改标题栏图标。程序运行效果如图1-17~图1-19所示。
data:image/s3,"s3://crabby-images/e9917/e9917844919c32f938610f1b4468278649dbd646" alt=""
图1-17 窗体界面
data:image/s3,"s3://crabby-images/ae477/ae4773382c83402dafed64fa3a3c5be23e536d41" alt=""
图1-19 窗体图片属性设置
data:image/s3,"s3://crabby-images/767de/767de0674c99469f1808571011bf53ff25a0f9a5" alt=""
图1-18 窗体标题属性设置
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体界面设计器,属性Text可显示窗体标题,属性Icon可显示窗体图标,如图1-17至图1-19所示。
注意:
1.应将窗体标题栏中的文字设置为有意义的文字,而且不是所有窗体都有标题栏的。
2.标题文字可以按以下几种情况命名。
(1)程序的名称:当窗体唯一时,可以用此种命名方式。
(2)窗口的目的:最常见的命名方式。
(3)窗体的名称:不要只用窗体的名称,而应该将其转换为具有意义的名称。
范例1-10 窗体的最大化和最小化
实例位置:光盘\ch01\1-10
范例说明
About the Example
本范例通过两种方式实现窗体的最大化和最小化:一种是为窗体添加最大化、最小化按钮,另一种是通过修改窗体属性来实现。程序运行效果如图1-20~图1-24所示。
data:image/s3,"s3://crabby-images/9ee7c/9ee7c445d17cfa7cfc5af8e94d393681b4484415" alt=""
图1-20 窗体界面
data:image/s3,"s3://crabby-images/fdd47/fdd471919dcf92696333ed659e3a03eab26c4ce9" alt=""
图1-24 最大和最小界面比例设置
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.在默认情况下,最大化和最小化按钮是存在的,可以单击窗体,按照下表修改属性,去除最大化和最小化按钮。修改结果如图1-20和图1-21所示。如果不希望用户使用【关闭】按钮,可以将ControlBox的属性设置为“False”。但是,需要注意的是,如果ControlBox为False,最大化和最小化按钮也会被自动隐藏。如图1-22和图1-23所示。
data:image/s3,"s3://crabby-images/107d9/107d9e1055afe73c02f9e67bea96dd2a2d7a5657" alt=""
图1-21 最大化和最小化属性设置
data:image/s3,"s3://crabby-images/825b9/825b9822a59baabed7524cce84713f11dd326a98" alt=""
图1-22 窗体界面
data:image/s3,"s3://crabby-images/a4435/a44351fa179e65fcb91aa48b5e3c9b7482dafddd" alt=""
图1-23 属性设置
3.用户也可以通过修改属性MinimumSize和MaximumSize来限制窗体最大化和最小化的大小。如图1-24所示。
范例1-11 设置窗体的外观和行为
实例位置:光盘\ch01\1-11
范例说明
About the Example
本范例通过设置FormBorderStyle属性修改窗体边框的外观和行为。程序运行效果如图1-25所示。
data:image/s3,"s3://crabby-images/1765a/1765ae08d621e07c7f1adc25e71f8f44772ce9d8" alt=""
图1-25 窗体外观属性设置
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,在属性窗口中有FormBorderStyle属性,包含7个属性值,分别是None、FixedSingle、Fixed3D、FixedDialog、Sizable、FixedToolWindow和SizableToolWindow。如图1-25所示。
3.设置每一个属性值,观察窗口的外观。
● None:窗体边框消失,标题栏也消失了,窗体不可以最大最小化,无法显示标题栏文本。
● FixedToolWindow:窗体的标题栏比正常显示要小,文字的字体也会变小,标题栏除标题栏文字外,只有一个【关闭】按钮。
● Sizable:最常用的窗体外观样式。
● FixedSingle:与Sizable类似。
● Fixed3D:窗体边框呈现三维立体外观。
● FixedDialog:标题栏的图标无法显示。
● SizeableToolWindows:与FixedToolWindows类似。
范例1-12 创建和卸载窗体
实例位置:光盘\ch01\1-12
范例说明
About the Example
本范例向用户展示了创建和卸载窗体的过程,并理解两种窗体模式:无模式窗体和模式窗体的不同。程序运行效果如图1-26所示。
data:image/s3,"s3://crabby-images/83083/83083a5527b19872db049dbd67b083a4661eaec2" alt=""
图1-26 窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.在窗体界面上拖放Label和Button控件,实现图1-26所示的程序界面。
3.双击每个按钮访问Click事件,输入相应代码,实现创建和卸载窗体功能。
程序代码
Codes
1.创建窗体
Form newform;
2.“无模式窗体”标签下的“显示窗体”代码
private void btnOpen_Click(object sender, EventArgs e) { newform= new Form(); newform.MaximizeBox = false; newform.MinimizeBox = false; //显示窗体 newform.Show(); this.btnClose.Enabled = true; this.btnOpen.Enabled = false; }
3.“无模式窗体”标签下的“卸载窗体”代码
private void btnClose_Click(object sender, EventArgs e) { this.Close(); this.btnClose.Enabled = false; this.btnOpen.Enabled = true; }
4.“模式窗体”标签下的“显示窗体”代码
private void btnOpenDialog_Click(object sender, EventArgs e) { newform = new Form(); newform.MaximizeBox = false; newform.MinimizeBox = false; //显示窗口 newform.ShowDialog(); this.btnCloseDialog.Enabled = true; this.btnOpenDialog.Enabled = false; }
5.“模式窗体”标签下的“卸载窗体”代码
private void btnCloseDialog_Click(object sender, EventArgs e) { this.Close(); this.btnCloseDialog.Enabled = false; this.btnOpenDialog.Enabled = true; }
注意:
用户显示窗体有两种形式:模式窗体和无模式窗体。无模式窗体不会使其他窗体无法使用(无模式窗体的显示代码为Show()方法)。无模式窗体的典型例子就是Word中的“查找和替换”窗口。当此窗口可见时,仍然可以操作其他窗口。模式窗口则相反,它处于显示状态时,其他应用窗体都不可以使用,除非模式窗体关闭(模式窗体的显示代码为ShowDialog()方法)。模式窗体的常用应用是对话框,如Word的打印对话框。
范例1-13 显示和隐藏窗体
实例位置:光盘\ch01\1-13
范例说明
About the Example
本范例是向用户展示窗体的显示和隐藏过程,并理解使窗体“消失”的两种含义:隐藏窗体和卸载窗体。程序运行效果如图1-27所示。
data:image/s3,"s3://crabby-images/38073/38073e5cb4dc7e0113f1e280087da40d20d302ee" alt=""
图1-27 窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.在窗体界面上拖放Label和Button控件,实现图1-27所示的程序界面。
3.双击每个按钮访问Click事件,输入相应代码,实现显示和隐藏窗体功能。
程序代码
Codes
1.创建窗体代码
Form newform= new Form(); public Form1() { InitializeComponent(); this.btnShow.Enabled = true; this.btnUnShow.Enabled = false; }
2.【显示窗体】按钮代码
private void btnShow_Click(object sender, EventArgs e) { //显示窗体 newform.Visible = true; this.btnUnShow.Enabled = true; this.btnShow.Enabled = false; }
3.【隐藏窗体】按钮代码
private void btnUnShow_Click(object sender, EventArgs e) { //隐藏窗体 newform.Visible = false; this.btnShow.Enabled = true; this.btnUnShow.Enabled = false; }
注意:
此窗体“消失”有两种方式:第一种是隐藏,这时窗体不关闭也不释放资源,只是用户不可见。实现窗体隐藏的代码是Visible属性为“false”。被隐藏的窗体仍然驻留在内存中,并且窗体中的所有控件和变量都保持其值,当需要再次显示窗体时,只要Visible属性为“true”即可。第二种是卸载,这时窗体被关闭并释放所占资源,用户同样不可见。实现窗体卸载的代码是Close()方法。
范例1-14 指定窗体的初始位置
实例位置:光盘\ch01\1-14
范例说明
About the Example
本范例通过设置窗体的StartPosition属性来控制窗体第一次在屏幕上显示的位置。
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,StartPosition属性有如下5个值,如表1-1所示。
表1-1 StartPosition属性
data:image/s3,"s3://crabby-images/1dee4/1dee4f6228b485ef475026f4e7ab29f212eb8b8e" alt=""
3.分别选择这5个值,观察运行程序在屏幕中的位置。
范例1-15 获取桌面大小
实例位置:光盘\ch01\1-15
范例说明
About the Example
本范例是通过读取C#的Screen对象相关属性,获取屏幕信息。程序运行效果如图1-28所示。
data:image/s3,"s3://crabby-images/e7b5f/e7b5fe71fc0a584831e6704a320a1e52cc0cb909" alt=""
图1-28 程序界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.拖放Label控件和Button控件,实现图1-28所示的程序界面。
3.双击【获取】按钮,输入代码,实现获取屏幕宽和高的信息。
程序代码
Codes
private void btnGet_Click(object sender, EventArgs e) { this.lblWidth.Text = Screen.PrimaryScreen.WorkingArea.Width.ToString(); this.lblHeight.Text = Screen.PrimaryScreen.WorkingArea.Height.ToString(); }
范例1-16 使窗体标题栏文字右对齐
实例位置:光盘\ch01\1-16
范例说明
About the Example
本范例设置窗体的RightToLeft属性,实现窗体标题的右对齐。程序运行效果如图1-29所示。
data:image/s3,"s3://crabby-images/259ef/259efb8fa2bf3805599e5a9bb67ccbb634c2d4e7" alt=""
图1-29 标题栏设置
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,修改RightToLef属性为“yes”,设置Text属性为“标题显示在右边”,如图1-29所示。
范例1-17 设置窗体的背景图片
实例位置:光盘\ch01\1-17
范例说明
About the Example
本范例设置窗体的BackGroundImage属性,将图像添加到窗体背景中。程序运行效果如图1-30和图1-31所示。
data:image/s3,"s3://crabby-images/1e030/1e030f09be7fd653ab2076d0582213b9a28b7baa" alt=""
图1-30 窗体大小属性设置
data:image/s3,"s3://crabby-images/0951c/0951c213f9bc0c36d97cc79e0d0504b85bad4cd9" alt=""
图1-31 设置背景图片
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,修改窗体大小为“600,500”,如图1-30所示。
3.修改BackGroundImage属性,单击 按钮,弹出选择资源对话框,单击“本地资源”单选按钮,如图1-31所示。
4.单击【导入】按钮,导入任意符合格式的图片文件。
5.返回选择资源对话框,单击【确定】按钮,图片便可以显示在窗体中。
范例1-18 随机更换主界面背景
实例位置:光盘\ch01\1-18
范例说明
About the Example
本范例是通过使用ImageList控件和Random函数实现窗体背景的随机变换。程序运行效果如图1-32所示。
data:image/s3,"s3://crabby-images/2924e/2924e7527913b3dc1c5946c3ae959a4d23f7c9e8" alt=""
图1-32 添加图片
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把ImageList控件拖放到设计界面上,选择属性Images,添加8张图片,如图1-32所示。
3.双击窗体,激发Load事件,输入代码,实现随机变换背景图片的功能。
程序代码
Codes
private void Form1_Load(object sender, EventArgs e) { //产生一个随机数 Random random = new Random(); int i = random.Next(imageList1.Images.Count); this.BackgroundImage=imageList1.Images[i]; }
范例1-19 带分割栏的窗体
实例位置:光盘\ch01\1-19
范例说明
About the Example
本范例实现一个带有分割栏的窗体。程序运行效果如图1-33和图1-34所示。
data:image/s3,"s3://crabby-images/e8a03/e8a037505e892f102b327d6d8ec022aa7b0681a3" alt=""
图1-33 窗体菜单界面
data:image/s3,"s3://crabby-images/1058b/1058b17cd52eb30fa5f5ef732ed7804abec6ba69" alt=""
图1-34 窗体分割界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把Menu控件拖放到设计界面上,添加【File】菜单,如图1-33所示。
3.把splitContainer控件拖放到设计界面上,实现窗体的分割,如图1-34所示。
范例1-20 控件随窗体自动调整
实例位置:光盘\ch01\1-20
范例说明
About the Example
本范例讲解如何通过设置Anchor属性实现控件随着窗体自动调整。程序运行效果如图1-35和图1-36所示。
data:image/s3,"s3://crabby-images/d20cc/d20cc0e8b83eab3cbe4da616e0f8f48cb20c1f8f" alt=""
图1-35 窗体界面
data:image/s3,"s3://crabby-images/53b0f/53b0ff84d5103e5cdd710d751181b9c5d41966fc" alt=""
图1-36 拉大窗体后界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把Button控件拖放到设计界面上,设置Name属性为“btnText”,设置Text属性为“控件随窗体自动调整”,设置Anchor属性为“Left,Right,Top,Button”,如图1-35所示。
3.运行程序,拉大窗体,按钮随之增大,效果如图1-36所示。
范例1-21 使用任意组件拖动窗体
实例位置:光盘\ch01\1-21
范例说明
About the Example
本范例通过按钮控件的MouseDown()方法和MouseMove()方法实现拖动窗体的功能。程序运行效果如图1-37所示。
data:image/s3,"s3://crabby-images/165c3/165c315d82be5fa2bd6a6394ac41dc6f03510d18" alt=""
图1-37 程序界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把Button控件拖放到设计界面上,设置Name属性为“btnDraw”,设置Text属性为“此按钮可以用来随意拖动窗体”,双击MouseDown和MouseMove事件,添加代码,如图1-37所示。
程序代码
Codes
1.定义两个变量分别存放鼠标产生按下事件时的(x,y)坐标
private int startX; private int startY;
2.鼠标按下时产生的事件
private void btnDraw_MouseDown(object sender, MouseEventArgs e) { //如果按的是鼠标左键 if (e.Button == MouseButtons.Left) { //获得鼠标在产生事件时的x坐标 startX = e.X; //获得鼠标在产生事件时的y坐标 startY = e.Y; } }
3.鼠标拖动时产生的事件
private void btnDraw_MouseMove(object sender, MouseEventArgs e) { //如果单击鼠标左键 if (e.Button == MouseButtons.Left) { //窗体的左边缘重新定位 this.Left += e.X - startX; //窗体的上边缘重新定位 this.Top += e.Y - startY; } }
范例1-22 动态设置提示字体
实例位置:光盘\ch01\1-22
范例说明
About the Example
本范例通过使用ToolTip控件实现动态显示提示字体的功能。程序运行效果如图1-38所示。
data:image/s3,"s3://crabby-images/2a57c/2a57cdffa62cf3b097ff201badcd4b4f8aa29318" alt=""
图1-38 程序界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把ToolTip控件拖放到设计界面上,设置Name属性为“tt”,双击Draw事件,添加代码,如图1-38所示。
3.添加Label控件拖放到设计界面上,设置Name属性为“lblToolTip”,Text属性为“鼠标移动到标签上,显示提示字”,tt的ToolTip属性为“Show Tooltip”。
程序代码
Codes
private void tt_Draw(object sender, DrawToolTipEventArgs e) { //使用系统颜色绘制提示字的背景色 e.DrawBackground(); //使用系统边框颜色绘制提示字的边框 e.DrawBorder(); using (StringFormat sf = new StringFormat()) { //文本的垂直对齐 sf.Alignment = StringAlignment.Center; //文本的水平对齐 sf.LineAlignment = StringAlignment.Center; sf.HotkeyPrefix = System.Drawing.Text.HotkeyPrefix.None; sf.FormatFlags = StringFormatFlags.NoWrap; using (Font f = new Font("宋体", 9)) { //绘制提示字 e.Graphics.DrawString(e.ToolTipText, f, SystemBrushes. ActiveCaptionText, e.Bounds, sf); } } }
1.2.2 窗体效果
范例1-23 创建半透明渐显窗体
实例位置:光盘\ch01\1-23
范例说明
About the Example
本范例是使用窗体的Opacity属性和Timer控件实现窗体的半透明渐显效果。程序运行效果如图1-39~图1-41所示。
data:image/s3,"s3://crabby-images/4f500/4f5008e21e4c75f13be387a2dec0c7105eb85b6e" alt=""
图1-39 设置背景图片属性
data:image/s3,"s3://crabby-images/84827/848271cd4d591b66c3a0f0e86668fb06516afbd0" alt=""
图1-41 设置计数器属性
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,设置BackGroundImage属性,如图1-39所示。
3.设置Opacity属性为“50%”,表示程序刚运行时为半透明,如图1-40所示。
data:image/s3,"s3://crabby-images/9cdf3/9cdf3ec418e84d7eba85986eff7c72f45d034761" alt=""
图1-40 设置透明度属性
4.添加Timer控件,设置属性Enabled为“True”;设置Interval属性为“1000”,表示计数间隔为1秒,如图1-41所示。
5.双击Timer控件的Tick事件,添加代码,以便实现自动计数功能,使透明度可以自动变化。
程序代码
Codes
//设置计数器的计数函数 private void timer1_Tick(object sender, EventArgs e) { this.Opacity += 0.1; }
范例1-24 创建透明窗体
实例位置:光盘\ch01\1-24
范例说明
About the Example
本范例是窗体的Opacity属性创建透明窗体。程序运行效果如图1-42所示。
data:image/s3,"s3://crabby-images/d5c17/d5c1736b108b056d491109af3e1a1cd8d9c92f62" alt=""
图1-42 透明窗体
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.设置窗体的BackColor属性为“Chartreuse”,如图1-42所示。
3.设置窗体的Opacity属性为“48%”,这样,程序运行时,窗体就可以显示透明度为48%的外观样式了。
范例1-25 创建可滚动窗体
实例位置:光盘\ch01\1-25
范例说明
About the Example
本范例通过设置窗体的AutoScroll属性实现窗体的可滚动效果。程序运行效果如图1-43和图1-44所示。
data:image/s3,"s3://crabby-images/6226b/6226b7fffc7ca15dd89b73356e411d15ffb6299b" alt=""
图1-43 窗体界面
data:image/s3,"s3://crabby-images/43731/43731d6cafd04cbe65ae04176a6355132bc25b16" alt=""
图1-44 窗体运行效果
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.拖入一个Label控件,输入文本为滚动窗体实例,如图1-43所示。
3.设置属性AutoScroll为“True”,这样,程序运行时,拖动窗体的右下角使窗体缩小,就能发现窗体上的一些控件看不见了,窗体右边和下面可以出现滚动条,如图1-44所示。
范例1-26 关闭窗口前加入关闭对话框
实例位置:光盘\ch01\1-26
范例说明
About the Example
本范例是对窗体添加FormClosing事件,当用户要关闭窗体时,会弹出关闭确认对话框以便用户确认。程序运行效果如图1-45和图1-46所示。
data:image/s3,"s3://crabby-images/e22d6/e22d6fd2152d37af162823e0fa375b8bdfbccbd7" alt=""
图1-45 窗体界面
data:image/s3,"s3://crabby-images/b4fa7/b4fa7f868bf97954f9c3c33a5fc2cdbb248cb60a" alt=""
图1-46 窗体运行效果
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.拖入一个Label控件,输入“关闭对话框确认实例”,如图1-45所示。
3.双击窗体事件FormClosing事件。输入代码,运行程序时就能出现关闭程序对话框。
程序代码
Codes
private void Form1_FormClosing(object sender, FormClosingEventArgs e) { if(MessageBox.Show("确认要关闭此窗体吗?","确认对话",MessageBoxButtons.YesNo) ==DialogResult.Yes) { e.Cancel=false; } else { e.Cancel=true; } }
范例1-27 防止窗体在任务栏里出现
实例位置:光盘\ch01\1-27
范例说明
About the Example
本范例是通过窗体的ShowInTaskbar属性设置窗体是否出现在任务栏中。程序运行效果如图1-47所示。
data:image/s3,"s3://crabby-images/8e50a/8e50aa9ebc7145cf7b106dd1834e9e015ba3e65a" alt=""
图1-47 设置显示在任务栏属性
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.设置窗体的ShowInTaskbar属性为“False”,如图1-47所示。
3.运行程序,就可以看到窗体不会出现在任务栏中,但用户可以按【Alt+Tab】组合键切换到该窗体。
范例1-28 窗体中的滚动字幕
实例位置:光盘\ch01\1-28
范例说明
About the Example
本范例是使用Timer控件控制字体的循环滚动。程序运行效果如图1-48所示。
data:image/s3,"s3://crabby-images/20bec/20bec65c9a91008bf00a63d189933faa956a5dda" alt=""
图1-48 窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.拖放Label控件和Button控件,实现图1-48所示的程序界面。
3.添加Timer控件,设置属性,如表1-2所示。
表1-2 Timer属性设置
data:image/s3,"s3://crabby-images/03dd6/03dd690d6b1169a8f632adcdfd710f85980aaf60" alt=""
4.双击Timer控件的Ticker事件,输入代码,实现字幕的滚动。
5.双击【开始】和【停止】按钮的Click事件,实现字母滚动的开始和停止。
程序代码
Codes
1.Ticker事件
private void timer1_Tick(object sender, EventArgs e) { this.lblWord.Top -= 10; if (this.lblWord.Bottom < 0) { this.lblWord.Top = this.Height; } }
2.【开始】按钮
private void btnBegin_Click(object sender, EventArgs e) { timer1.Enabled = true; }
3.【停止】按钮
private void btnStop_Click(object sender, EventArgs e) { timer1.Enabled = false; }
1.3 对话框应用
本节主要讲解常见的几种对话框的使用:打开文件对话框、保存文件对话框、浏览文件夹对话框、颜色对话框和字体对话框。
1.3.1 打印对话框
范例1-29 PrintSetupDialog对话框的使用
实例位置:光盘\ch01\1-29
范例说明
About the Example
本范例通过使用打印设置对话框控件PrintSetupDialog帮助用户对需要打印的文件进行设置,程序运行效果如图1-49和图1-50所示。
data:image/s3,"s3://crabby-images/26d5e/26d5e6949ba58cfd7ddbb6278f84c742e86fd6e0" alt=""
图1-49 窗体界面
data:image/s3,"s3://crabby-images/fb567/fb567f8be4ff13e4b8cea2ddbc649ee43370dd65" alt=""
图1-50 页面设置界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】、【Open】、【Print Preview】、【Print Setup】和【Print】菜单,如图1-49所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-3所示。
表1-3 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/5256d/5256dae356c61a76ced2d83b2e0f73f7d0ea00a0" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
5.双击“工具箱”打印栏中的PrintDocument控件,设置Name属性为“pd”,双击PrintPage事件,输入代码实现打印处理过程。
6.双击“工具箱”打印栏中的PrintSetupDialog控件,设置Name属性为“dlgPS”,设置Document属性为“pd”,使要打印的代码和对话框关联起来。
程序代码
Codes
1.打开文件
private void miOpen_Click(object sender, EventArgs e) { try { if (this.dlgOpen.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(this.dlgOpen.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.打印设置
private void miPS_Click(object sender, EventArgs e) { this.dlgPS.ShowDialog(); }
3.打印页面
private void pd_PrintPage(object sender, PrintPageEventArgs e) { int x = e.MarginBounds.Left; int y = e.MarginBounds.Top; lines = this.rchShow.Text.Split(param); while (linesPrinted < lines.Length) { e.Graphics.DrawString(lines[linesPrinted++], new Font("Arial", 10), Brushes.Black, x, y); y += 15; if (y >= e.PageBounds.Height -80) { e.HasMorePages = true; return; } } linesPrinted = 0; e.HasMorePages = false; }
范例1-30 PrintPreviewDialog对话框的使用
实例位置:光盘\ch01\1-30
范例说明
About the Example
本范例通过使用打印设置对话框控件PrintPreviewDialog帮助用户对需要打印的文件进行预览,程序运行效果如图1-51和图1-52所示。
data:image/s3,"s3://crabby-images/e9b8d/e9b8d96511d6002fd085466a554f34613360b731" alt=""
图1-51 窗体界面
data:image/s3,"s3://crabby-images/146e4/146e4ca0d2f77f3f44538fdce7a98116c0356291" alt=""
图1-52 页面预览界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】、【Open】、【Print Preview】、【Print Setup】和【Print】菜单,如图1-51所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-3所示。
表1-3 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/5256d/5256dae356c61a76ced2d83b2e0f73f7d0ea00a0" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
5.双击“工具箱”打印中的PrintDocument控件,设置Name属性为“pd”,双击PrintPage事件,输入代码实现打印处理过程。
6.双击“工具箱”打印中的PrintPreviewDialog控件,设置Name属性为dlgpp,设置Document属性为“pd”,使要打印的代码和对话框关联起来。
程序代码
Codes
1.打开文件
private void miOpen_Click(object sender, EventArgs e) { try { if (this.dlgOpen.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(this.dlgOpen.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.打印预览
private void miPp_Click(object sender, EventArgs e) { this.dlgpp.ShowDialog(); }
3.打印页面
char[] param ={ '\n' }; private string[] lines; private int linesPrinted; private void pd_PrintPage(object sender, PrintPageEventArgs e) { int x = e.MarginBounds.Left; int y = e.MarginBounds.Top; lines = this.rchShow.Text.Split(param); while (linesPrinted < lines.Length) { e.Graphics.DrawString(lines[linesPrinted++], new Font("Arial", 10), Brushes.Black, x, y); y += 15; if (y >= e.PageBounds.Height -80) { e.HasMorePages = true; return; } } linesPrinted = 0; e.HasMorePages = false; }
范例1-31 PrintDialog对话框的使用
实例位置:光盘\ch01\1-31
范例说明
About the Example
本范例通过使用打印设置对话框控件PrintDialog帮助用户打印文件,程序运行效果如图1-53和图1-54所示。
data:image/s3,"s3://crabby-images/349b1/349b1b94f87fa14e8ed9ba00cf0571fce4b8e84f" alt=""
图1-53 窗体界面
data:image/s3,"s3://crabby-images/9bbd1/9bbd14f5bcd4b20a76d3f093dfd85a5715643949" alt=""
图1-54 页面打印界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】、【Open】、【Print Preview】、【Print Setup】和【Print】菜单,如图1-53所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-3所示。
表1-3 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/5256d/5256dae356c61a76ced2d83b2e0f73f7d0ea00a0" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
5.双击“工具箱”打印中的PrintDocument控件,设置Name属性为“pd”,双击PrintPage事件,输入代码实现打印处理过程。
6.双击“工具箱”打印中的PrintPreviewDialog控件,设置Name属性为“dlgpp”,设置Document属性为“pd”,使要打印的代码和对话框关联起来。
程序代码
Codes
1.打开文件
private void miOpen_Click(object sender, EventArgs e) { try { if (this.dlgOpen.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(this.dlgOpen.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.打印页面
char[] param ={ '\n' }; private string[] lines; private int linesPrinted; private void pd_PrintPage(object sender, PrintPageEventArgs e) { int x = e.MarginBounds.Left; int y = e.MarginBounds.Top; lines = this.rchShow.Text.Split(param); while (linesPrinted < lines.Length) { e.Graphics.DrawString(lines[linesPrinted++], new Font("Arial", 10), Brushes.Black, x, y); y += 15; if (y >= e.PageBounds.Height -80) { e.HasMorePages = true; return; } } linesPrinted = 0; e.HasMorePages = false;
3.打印文件
private void miPrint_Click(object sender, EventArgs e) { try { if (this.dlgprint.ShowDialog() == DialogResult.OK) { pd.Print(); } } catch (InvalidPrinterException ex) { MessageBox.Show(ex.Message); } }
1.3.2 打开文件对话框
范例1-32 设置打开文件类型
实例位置:光盘\ch01\1-32
范例说明
About the Example
本范例通过使用打开文件对话框控件OpenFileDialog帮助用户浏览文件系统,选择要操作的文件。并且使用Filter属性设置要打开的文件类型。程序运行效果如图1-55和图1-56所示。
data:image/s3,"s3://crabby-images/80639/806392fbadc41ae511f2814a46a8cea1db5a7d3e" alt=""
图1-55 窗体界面
data:image/s3,"s3://crabby-images/18ec1/18ec1d53aa9b7d469fc8d21f05b2110067b65d3e" alt=""
图1-56 选择文件界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】和【打开文件】菜单,如图1-55所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-4所示。
表1-4 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/6967d/6967d9a9760007303d7ccdf2683e1456e75c99a0" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
程序代码
Codes
private void miOpen_Click(object sender, EventArgs e) { try { //判断是否选择了文件 if (dlgOpenFile.ShowDialog() == DialogResult.OK) {//将文件加载到RichTextBox中 this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
范例1-33 设置起始路径
实例位置:光盘\ch01\1-33
范例说明
About the Example
本范例通过使用打开文件对话框控件OpenFileDialog帮助用户浏览文件系统,选择要操作的文件。并且使用InitialDirectory属性设置要打开的起始路径。程序运行效果如图1-57和图1-58所示。
data:image/s3,"s3://crabby-images/3f44c/3f44c9da368ee5b87211dd442630dc738c8b029f" alt=""
图1-57 窗体界面
data:image/s3,"s3://crabby-images/d81fc/d81fce255b416df62e8df44eb0c87619563c463a" alt=""
图1-58 运行界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】和【打开文件】菜单,如图1-57所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-5所示。
表1-5 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/94b68/94b68171b3aeda32dfedb250512061b2ab6e3f6e" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
程序代码
Codes
private void miOpen_Click(object sender, EventArgs e) { try { //判断是否选择了文件 if (dlgOpenFile.ShowDialog() == DialogResult.OK) {//将文件加载到RichTextBox中 this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
范例1-34 选择多个文件
实例位置:光盘\ch01\1-34
范例说明
About the Example
本范例通过使用打开文件对话框控件OpenFileDialog帮助用户浏览文件系统,选择要操作的文件。并且使用Multiselect属性设置是否允许选择多个文件。程序运行效果如图1-59和图1-60所示。
data:image/s3,"s3://crabby-images/0fa39/0fa393a77ed5fdcc0dbd03d2899a1acafbc4284e" alt=""
图1-59 窗体界面
data:image/s3,"s3://crabby-images/dd006/dd006e6cff8ebae88c2ff0192de301c3ec340225" alt=""
图1-60 运行界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】和【打开多个文件】菜单,如图1-59所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-6所示。
表1-6 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/2d393/2d3937117bed8c039f795f5674c70b3c89441482" alt=""
4.双击【打开文件】菜单项,输入代码,实现打开文件对话框的弹出和用户选择文件的功能。
程序代码
Codes
private void miMultiSel_Click(object sender, EventArgs e) { try { if (this.dglOpen.ShowDialog() == DialogResult.OK) { StringBuilder sb=new StringBuilder(); foreach (string s in this.dglOpen.FileNames) { sb.Append(File.ReadAllText(s)).AppendLine(); } if (sb.Length > 0) { this.rchShow.Text = sb.ToString(); } } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
1.3.3 保存文件对话框
范例1-35 设置保存文件类型
实例位置:光盘\ch01\1-35
范例说明
About the Example
本范例通过使用保存文件对话框控件SaveFileDialog帮助用户保存文件,并且使用Filter属性设置要保存的文件类型。程序运行效果如图1-61和图1-62所示。
data:image/s3,"s3://crabby-images/9d18c/9d18c02f52fa2335b052e8912a154240daed545e" alt=""
图1-61 窗体界面
data:image/s3,"s3://crabby-images/f6fc2/f6fc2a9cd6370c063a1e1a52b9491f8411026165" alt=""
图1-62 选择保存类型界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】和【打开文件】和【保存文件】菜单,如图1-61所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-7所示。
表1-7 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/9a3ea/9a3ea5fe7bcc4e6a19b3c4aa5e910bca2d2516dc" alt=""
4.双击【打开文件】菜单项,输入代码实现保存文件对话框的弹出和用户选择文件的功能。
5.双击工具箱对话框中的SaveFileDialog控件,设置属性,如表1-8所示。
表1-8 SaveFileDialog属性设置
data:image/s3,"s3://crabby-images/609ac/609ac0e4ab35dfb59bba1d4c170d77abeb554320" alt=""
6.双击【保存文件】菜单项,输入代码,实现保存文件对话框的弹出和用户保存文件的功能。
程序代码
Codes
1.【打开文件】菜单项代码
private void miOpen_Click(object sender, EventArgs e) { try { if (dlgOpenFile.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.【保存文件】菜单项代码
private void miClose_Click(object sender, EventArgs e) { try { if (dlgSaveFile.ShowDialog() == DialogResult.OK) { this.rchShow.SaveFile(dlgSaveFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
范例1-36 设置保存文件类型
实例位置:光盘\ch01\1-36
范例说明
About the Example
本范例通过使用保存文件对话框控件SaveFileDialog帮助用户保存文件,并且使用InitialDirectory属性设置要保存的文件类型。程序运行效果如图1-63和图1-64所示。
data:image/s3,"s3://crabby-images/3fb95/3fb9522ea94d2ee97b8a56ad97ba1c0d8b693324" alt=""
图1-63 窗体界面
data:image/s3,"s3://crabby-images/a5a59/a5a592a17c348b56ef8f9b7b3b941e52d1759945" alt=""
图1-64 选择保存类型界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】和【打开文件】和【保存文件】菜单,如图1-63所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-9所示。
表1-9 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/efeff/efeffa2afd1f13c9ab5effccdfc0e077d551da8b" alt=""
4.双击【打开文件】菜单项,输入代码实现保存文件对话框的弹出和用户选择文件的功能。双击工具箱对话框中的SaveFileDialog控件,设置属性,如表1-10所示。
表1-10 SaveFileDialog属性设置
data:image/s3,"s3://crabby-images/a129d/a129d8b096922966da8998ebbd37866ce64d1f93" alt=""
5.双击【保存文件】菜单项,输入代码,实现保存文件对话框的弹出和用户保存文件的功能。
程序代码
Codes
1.【打开文件】菜单项代码
private void miOpen_Click(object sender, EventArgs e) { try { if (dlgOpenFile.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.【保存文件】菜单项代码
private void miClose_Click(object sender, EventArgs e) { try { if (dlgSaveFile.ShowDialog() == DialogResult.OK) { this.rchShow.SaveFile(dlgSaveFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
1.3.4 浏览文件夹对话框
范例1-37 设置不显示新建文件夹
实例位置:光盘\ch01\1-37
范例说明
About the Example
本范例通过使用文件夹浏览对话框控件FolderBrowerDialog帮助用户选择文件。程序运行效果如图1-65和图1-66所示。
data:image/s3,"s3://crabby-images/33bb4/33bb4fae0299eea2b2546d0ba69f70a984482e78" alt=""
图1-65 窗体界面
data:image/s3,"s3://crabby-images/ca0b2/ca0b28b340dac41df80549731e5bb521f8d2ad43" alt=""
图1-66 含新建文件夹的程序界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】和【打开文件夹】菜单,如图1-65所示。
3.双击工具箱对话框中的FolderBrowerDialog控件,设置属性,如表1-11所示。
表1-11 FolderBrowerDialog属性设置
data:image/s3,"s3://crabby-images/bd42c/bd42cbce62caf20e0b9123f5d9a18cc4429976e8" alt=""
4.单击【打开文件夹】菜单项,输入代码实现保存文件对话框的弹出和用户选择文件的功能。
程序代码
Codes
private void miOpen_Click(object sender, EventArgs e) { try { if (this.dlgFB.ShowDialog() == DialogResult.OK) { this.rchShow.Text = "选择的文件夹名为:" + this.dlgFB.SelectedPath; } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
范例1-38 设置根文件夹
实例位置:光盘\ch01\1-38
范例说明
About the Example
本范例通过使用文件夹浏览对话框控件FolderBrowerDialog帮助用户选择文件。程序运行效果如图1-67和图1-68所示。
data:image/s3,"s3://crabby-images/33b8a/33b8a87fd32a381bf6d79674bc6d39f791ff642d" alt=""
图1-67 窗体界面
data:image/s3,"s3://crabby-images/a4cbc/a4cbcd7904cee089ca747b9996a4ebe5caabd278" alt=""
图1-68 择保存类型界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【File】和【打开文件夹】菜单,如图1-67所示。
3.双击工具箱对话框中的FolderBrowerDialog控件,设置属性,如表1-12所示。
表1-12 FolderBrowerDialog属性设置
data:image/s3,"s3://crabby-images/5e484/5e4845f7cb7be9a3ffa2e8ecd670794922c7262c" alt=""
4.单击【打开文件夹】菜单项,输入代码实现保存文件对话框的弹出和用户选择文件的功能。
程序代码
Codes
private void miOpen_Click(object sender, EventArgs e) { try { if (this.dlgFB.ShowDialog() == DialogResult.OK) { this.rchShow.Text="选择的文件夹名为:"+this.dlgFB.SelectedPath; } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
1.3.5 其他
范例1-39 字体对话框
实例位置:光盘\ch01\1-39
范例说明
About the Example
本范例通过使用字体对话框控件FontDialog帮助用户编辑文本字体。程序运行效果如图1-69所示。
data:image/s3,"s3://crabby-images/9a0df/9a0df3e68c227c780f8b6cee93b38f33ba32b219" alt=""
图1-69 窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】和【打开文件】和【字体】菜单,如图1-69所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-13所示。
表1-13 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/c2481/c24811d18efaedf56fe8ff4a3a06569325d51dc5" alt=""
4.双击【打开文件】菜单项,输入代码实现保存文件对话框弹出和用户选择文件的功能。
5.双击工具箱对话框中的FontDialog控件,并设置Name属性为“dlgFont”。
6.双击【字体】菜单项,输入代码,实现文件内容的字体编辑。
程序代码
Codes
1.【打开文件】菜单项代码
private void miOpen_Click(object sender, EventArgs e) { try { if (dlgOpenFile.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.“字体”设置
private void miFont_Click(object sender, EventArgs e) { if (dlgFont.ShowDialog() == DialogResult.OK) { this.rchShow.Font = dlgFont.Font; } }
范例1-40 颜色对话框
实例位置:光盘\ch01\1-40
范例说明
About the Example
本范例通过使用颜色对话框控件ColorDialog帮助用户编辑字体颜色。程序运行效果如图1-70所示。
data:image/s3,"s3://crabby-images/10878/108783da2baeef4750fd0d1f3d407982d45dcae4" alt=""
图1-70 窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.把MenuStrip控件和RichTextBox控件拖放到设计界面上,并添加【操作】、【打开文件】和【颜色设置】菜单,如图1-70所示。
3.双击工具箱对话框中的OpenFileDialog控件,设置属性,如表1-14所示。
表1-14 OpenFileDialog属性设置
data:image/s3,"s3://crabby-images/6351c/6351c1e2d46b0359b5763760e11a165f32b2a845" alt=""
4.双击【打开文件】菜单项,输入代码实现保存文件对话框的弹出和用户选择文件的功能。
5.双击工具箱对话框中的ColorDialog控件,并设置Name属性为“dlgColor”。
6.双击【颜色设置】菜单项,输入代码,实现文件内容的字体编辑。
程序代码
Codes
1.【打开文件】菜单项代码
private void miOpen_Click(object sender, EventArgs e) { try { if (dlgOpenFile.ShowDialog() == DialogResult.OK) { this.rchShow.LoadFile(dlgOpenFile.FileName, RichTextBoxStreamType.PlainText); } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
2.“颜色”设置
private void miFont_Click(object sender, EventArgs e) { try { if(dlgColor.ShowDialog()==DialogResult.OK) { this.rchShow.SelectionColor = dlgColor.Color; } } catch (Exception ex) { MessageBox.Show(ex.Message); } }
1.4 MDI应用程序
本节着重介绍MDI多文档应用程序的创建和使用。
范例1-41 创建一个简单的MDI应用程序
实例位置:光盘\ch01\1-41
范例说明
About the Example
本范例通过创建一个MDI应用程序,实现多文档操作,并且比较三种Windows应用程序的不同。程序运行效果如图1-71和图1-72所示。
data:image/s3,"s3://crabby-images/ba44e/ba44e4fd90098052a7be6aa16543225501fdd7a7" alt=""
图1-71 父窗体界面
data:image/s3,"s3://crabby-images/0cefe/0cefebdb5a1509ec8638bdd78c3a2fc0f88fb650" alt=""
图1-72 创建子窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,设置属性,如表1-15所示。设置结果如图1-71所示。
表1-15 属性设置
data:image/s3,"s3://crabby-images/e534d/e534dda7eaf021fa31c8406fa53b37bba8fe5e07" alt=""
3.在frmParent窗体单击鼠标右键,单击【查看代码】菜单项,进入代码编辑页,修改窗体的构造函数,实现父窗体和子窗体的绑定。
4.在MDIAppEX项目单击鼠标右键,选择【添加】→【Windows窗体】菜单项,弹出添加新项对话框,如图1-72所示。
5.在frmChild窗体单击鼠标右键,单击【查看代码】菜单项,进入代码编辑页,修改窗体的构造函数,使子窗体绑定到父窗体上。
程序代码
Codes
1.父窗体的构造函数
public frmChild(frmParent parent) { InitializeComponent(); this.MdiParent = parent; }
2.子窗体的构造函数
public frmParent() { InitializeComponent(); frmChild child = new frmChild(this); child.Show(); }
注意:
1.Windows一般可以编写3种应用程序
基于对话框的应用程序—给用户提供一个对话框,该对话框提供了用户所需要的功能,如字体对话框、颜色对话框。
单一文档界面(SDI)—给用户提供一个菜单、一个或多个工具栏和一个窗口,用户可以执行功能,如写字板。
多文档界面(MDI)—给用户提供一个菜单、一个或多个工具栏和多个窗口,用户可以执行功能,如Word应用程序。
2.MDI应用程序的相关知识
MDI应用程序至少由两个窗口组成:一个窗口叫MDI容器(Container),另一个窗口叫MDI子窗口。一个MDI容器可以放置多个MDI子窗口,实现多文档状态。
范例1-42 创建一个MDI文本编辑器
实例位置:光盘\ch01\1-42
范例说明
About the Example
本程序运行效果如图1-73和图1-74所示。范例通过MDI窗体和以前所学的关于菜单和窗体的知识,创建一个简单的MDI文本编辑器。
data:image/s3,"s3://crabby-images/19789/19789f0cca68836ccff52430663c2ef40f59067c" alt=""
图1-73 父窗体界面
data:image/s3,"s3://crabby-images/b80ec/b80ec29eb7e5d745702c0681d2e3a338525b6da7" alt=""
图1-74 子窗体界面
关键步骤
Key Steps
1.创建一个新的Windows工程。
2.单击窗体,设置属性,如表1-16所示。设置结果如图1-73所示。
表1-16 属性设置
data:image/s3,"s3://crabby-images/7758f/7758f4492d86102a25a3d264ee65f4c6b290360a" alt=""
3.在frmContainer窗体上单击鼠标右键,单击【查看代码】菜单项,进入代码编辑页,修改窗体的构造函数,实现父窗体和子窗体的绑定。
4.在MDIEditorEX项目上单击鼠标右键,选择【添加】→【Windows窗体】菜单项,弹出添加新项对话框。
5.在frmEditor窗体上单击鼠标右键,单击【查看代码】菜单项,进入代码编辑页,修改窗体的构造函数,使子窗体绑定到父窗体上。
6.把MenuStrip控件拖放到frmEditor设计界面上,并添加【File】和【Format】菜单和相应的子菜单,按照表1-17设置各个菜单项,设置后界面如图1-74所示。
表1-17 属性设置
data:image/s3,"s3://crabby-images/feb33/feb336a19e48439f37ffc96ec360888ff87b78d0" alt=""
7.双击各个菜单项,实现各个菜单项的功能。
data:image/s3,"s3://crabby-images/deb7a/deb7adfb6ebf7b0b279d6f8a47da881a95a19c4e" alt=""
程序代码
Codes
1.父窗体构造函数
public frmContainer() { InitializeComponent(); frmEditor child = new frmEditor(this); child.Show(); }
2.子窗体构造函数
public frmEditor(frmContainer parent) { InitializeComponent(); this.MdiParent = parent; }
3.新建文件
private void miNew_Click(object sender, EventArgs e) { this.rchtxtShow.Clear(); }
4.打开文件
private void miOpen_Click(object sender, EventArgs e) { try { if (dlgOpen.ShowDialog() == DialogResult.OK) { if (dlgOpen.FilterIndex == 1) { this.rchtxtShow.LoadFile(dlgOpen.FileName, RichTextBoxStreamType.RichText); } } } catch(Exception ex) { MessageBox.Show(ex.Message); } }
5.保存文件
private void miSave_Click(object sender, EventArgs e) { try { if (dlgSave.ShowDialog() == DialogResult.OK) { if (dlgSave.FilterIndex == 1) { this.rchtxtShow.SaveFile(dlgSave.FileName, RichTextBoxStreamType.RichText); } } } catch(Exception ex) { MessageBox.Show(ex.Message); } }
6.关闭子窗体
private void miClose_Click(object sender, EventArgs e) { this.Close(); }
7.设置粗体字体
private void miBold_Click(object sender, EventArgs e) { Font oldFont = this.rchtxtShow.SelectionFont; Font newFont; if (oldFont.Bold) { newFont = new Font(oldFont, oldFont.Style & ~FontStyle.Bold); } else { newFont = new Font(oldFont, oldFont.Style | FontStyle.Bold); } this.rchtxtShow.SelectionFont = newFont; }
8.设置斜体字体
private void miItalic_Click(object sender, EventArgs e) { Font oldFont = this.rchtxtShow.SelectionFont; Font newFont; if (oldFont.Italic) { newFont = new Font(oldFont, oldFont.Style & ~FontStyle.Italic); } else { newFont = new Font(oldFont, oldFont.Style | FontStyle.Italic); } this.rchtxtShow.SelectionFont = newFont; }
9.设置下画线字体
private void miUnderline_Click(object sender, EventArgs e) { Font oldFont = this.rchtxtShow.SelectionFont; Font newFont; if (oldFont.Underline) { newFont = new Font(oldFont, oldFont.Style & ~FontStyle.Underline); } else { newFont = new Font(oldFont, oldFont.Style | FontStyle.Underline); } this.rchtxtShow.SelectionFont = newFont; }
1.5 本章小结
一个好的界面是一个软件成功的关键因素。纵观Office、QQ和IE,这些软件的流行与它们优秀的设计界面是分不开的,在开发时可以参照这些界面,熟悉操作会让用户更快地掌握软件的使用方法。