成都网站建设设计

将想法与焦点和您一起共享

C#Window控件及窗体的基本使用

可视界面通常都用于与用户进行交互,所以是必学的一部分,

十载的平桥网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销的优势是能够根据用户设备显示端的尺寸不同,自动调整平桥建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“平桥网站设计”,“平桥网站推广”以来,每个客户项目都认真落实执行。

C#下的可视界面我觉得在封装上弄得比较好,页面属性都放在Form1.Designer.cs文件的InitializeComponent()函数里,Form1.cs文件调用初始化函数,进行相关的事件的操作(如:经常所见的button的Click操作)。在visual studio的工具箱里可以拖动组建,右键选择属性可以设置组件的属性。

简单的窗口例子,当要关闭窗口的时候弹出对话框:

在Form1.cs文件里新建函数:

private void Form1_FormClosing(object sender, FormClosingEventArgs e)
{
    DialogResult dr = MessageBox.Show("是否关闭窗体?", "提示", MessageBoxButtons.YesNo, MessageBoxIcon.Warning);
    if (dr == DialogResult.Yes)
    {
        e.Cancel = false;
    }
    else
    {
        e.Cancel = true;
    }
}

在Form1.Designer.cs文件里的InitializeComponent()函数中设置:

this.FormClosing += new System.Windows.Forms.FormClosingEventHandler(this.Form1_FormClosing);

this.FormClosing += new System.Windows.Forms.FormClosingEventHandler(this.Form1_FormClosing);

表示窗口的FormClosing属性通过调用Form1_FormClosing函数实现。

窗体可以调用Show()、Hide()和Close()方法。另外有触发窗体事件的Activated事件、Load事件,和FormClosing事件的语法格式类似。

常用控件及其简单设置

1.Label控件:

label1.Font = new Font("楷体", 12);
label1.Text = "再累也要开心D";
label2.ForeColor = Color.Blue;

2.TextBox控件:

textBox1.PasswordChar = '@';//根据自己的喜好设置密码显示的方式
textBox2.UseSystemPasswordChar = true;//设置默认的系统密码显示
textBox1.ReadOnly = true;//只读属性
textBox1.Multiline = true;//设置多行显示

3.RichTextBox控件:(可以显示字体、颜色、链接、文本加载、图像功能)

实例:button1打开文件、button2打开图片。richTextBox1显示文件和图片内容;

设置richTextBox1的属性:

richTextBox1.BorderStyle = BorderStyle.Fixed3D;//设置边框样式
richTextBox1.DetectUrls = true;//设置自动识别超链接
richTextBox1.ScrollBars = RichTextBoxScrollBars.Both;//设置滚动条

点击button1后显示打开文件对话框,选择文件后再richTextBox1中显示文件内容:

OpenFileDialog openfile = new OpenFileDialog();//实例化打开文件对话框
openfile.Filter = "rtf文件(*.rtf)|*.rtf";//设置文件筛选器
if (openfile.ShowDialog() == DialogResult.OK)
{
    richTextBox1.Clear();//清空文本框
    //加载文件
    richTextBox1.LoadFile(openfile.FileName, RichTextBoxStreamType.RichText);
}

同理,显示图片的设置:

OpenFileDialog openpic = new OpenFileDialog();
openpic.Filter = "bmp文件(*.bmp)|*.bmp|jpg文件(*.jpg)|*.jpg|ico文件(*.ico)|*.ico";
openpic.Title = "打开图片";
if (openpic.ShowDialog() == DialogResult.OK)
{
    Bitmap bmp = new Bitmap(openpic.FileName);//使用选择的图片实例化Bitmap对象
    Clipboard.SetDataObject(bmp, false);//将图像置于系统剪贴板中
    //判断richTextBox1控件是否可以粘贴图片信息
    if (richTextBox1.CanPaste(DataFormats.GetFormat(DataFormats.Bitmap)))
        richTextBox1.Paste();
}

Button控件:

button1.BackgroundImage = Properties.Resources.a;
button1.BackgroundImageLayout = ImageLayout.Stretch;//拉伸图像
button2.Image = Properties.Resources.a;
button2.ImageAlign = ContentAlignment.MiddleLeft;//设置图片对齐方式
button3.FlatStyle = FlatStyle.Flat;//设置button3的外观样式
button3.Text = "确定";
button4.TextAlign = ContentAlignment.MiddleRight;//设置文本对齐方式

GroupBox控件:(分组控件,其所包含的控件集周围显示边框和标题,但没有滚动条)

TabControl控件:

设置选项卡的外观样式:

tabControl1.Appearance = TabAppearance.Normal;

实例:点击button1后增加一个选项卡,button2移除一个选项卡

//声明一个字符串变量,用于生成新增选项卡的名称
string Title = "新增选项卡 " + (tabControl1.TabCount + 1).ToString();
TabPage tp = new TabPage(Title);
//使用tabcontrol控件的tabpages属性的add方法添加新的选项卡
tabControl1.TabPages.Add(tp);

移除选项卡:

if (tabControl1.SelectedIndex == 0)
{
    MessageBox.Show("请选择要移除的选项卡");
}
else
{
    tabControl1.TabPages.Remove(tabControl1.SelectedTab);
}

MenuStrip控件(菜单栏——拖动控件就可以进行相关设置):

另在输入框输入“新建(&N)”会在运行时显示“新建(N)”,可以“Alt+N”来调用

ToolStrip控件(工具栏——下拉栏有8个不同类型的控件——这个控件没怎么用,说不太清楚)

Button:包含文本和图象中可以让用户选择的项;

Label:包含文本和图象的项,不可以让用户选择,可以显示超链接

SplitButton:在Button的基础上增加一个下拉列表

DropDownButton:用于下拉列表选择项

Separator:分隔符

ComboBox:显示一个Combox的项

TextBox和ProgressBar和ComboBox的意义类似。

StatusStrip控件:

放在窗体的最底部,用于显示窗体对象的一些相关信息。

窗体加载时显示系统当前时间:

toolStripStatusLabel1.Text="当前时间:"+DateTime.Now.ToLongTimeString();

ListBox控件:

实例:用ListBox显示获取到的文件列表

设置ListBox属性:

listBox1.HorizontalScrollbar = true;//水平
listBox1.ScrollAlwaysVisible = true;//垂直
listBox1.SelectionMode = SelectionMode.MultiExtended;//实现在控件中选择多项

点击button1(打开文件)后:

//实例化浏览文件夹对话框
FolderBrowserDialog fbd = new FolderBrowserDialog();
if (fbd.ShowDialog() == DialogResult.OK)
{
    //获取选择的文件夹的路径
    textBox1.Text = fbd.SelectedPath;
    //使用获取的文件夹路径实例化DirectoryInfo类对象
    DirectoryInfo dinfo = new DirectoryInfo(textBox1.Text);
    //获取指定文件夹下的所有子文件夹及文件
    FileSystemInfo[] finfo = dinfo.GetFileSystemInfos();
    //将获取到的子文件夹及文件添加到ListBox控件中
    listBox1.Items.AddRange(finfo);
    label2.Text = "(" + listBox1.Items.Count + "项}";
}

选择ListBox其中的项:

private void listBox1_SelectedIndexChanged(object sender, EventArgs e)
{
    label3.Text = "你选择的是:";
    for(int i = 0 ; i < listBox1.SelectedItems.Count ; i++)
    {
        label3.Text += listBox1.SelectedItems[i]+"、";
    }
}

ListView控件:(主用于显示带图标的列表项)

实例(为ListView的Group添加项,另外可以设置添加、移除和清空项功能):

listView1.View = View.SmallIcon;//设置View属性,设置样式
//为listView1建立两个组
listView1.Groups.Add(new ListViewGroup("名称", HorizontalAlignment.Left));
listView1.Groups.Add(new ListViewGroup("类别", HorizontalAlignment.Left));
listView1.Items.Add("name1");
listView1.Items.Add("name2");
listView1.Items.Add("lei1");

对上面的项进行分组(设置它们的Group属性):

//添加到第一个分组的写法
listView1.Items[0].Group = listView1.Groups[0];
//加入第二分组
listView1.Items[2].Group = listView1.Groups[1];

添加项:

listView1.Items.Add(textBox1.Text.Trim());

删除项:

listView1.Items.RemoveAt(listView1.SelectedItems[0].Index);
listView1.SelectedItems.Clear();

清空项:

listView1.Items.Clear();

TreeView控件:(用于显示节点层次结构)

treeView1.ContextMenuStrip = contextMenuStrip1;//设置树控件的快捷菜单
TreeNode tn = treeView1.Nodes.Add("根节点");
TreeNode pn1 = new TreeNode("节点1");
//将节点1放到根节点下的节点中
tn.Nodes.Add(pn1);
TreeNode cn1 = new TreeNode("节点1下的节点");
pn1.Nodes.Add(cn1);
//快捷菜单下的全部展开跟全部折叠
treeView1.ExpandAll();
treeView1.CollapseAll();

treeView1也通常和p_w_picpathList控件用,一起显示带图片的节点:

p_w_picpathList1.Images.Add(Image.FromFile("1.png"));
p_w_picpathList1.Images.Add(Image.FromFile("2.png"));
treeView1.ImageList = p_w_picpathList1;
p_w_picpathList1.ImageSize = new Size(16,16);
//设置treeView1控件节点的图标在p_w_picpathList1控件中的索引时0
treeView1.ImageIndex = 0;
//选择某个节点后显示的图标在p_w_picpathList1控件中的索引为1
treeView1.SelectedImageIndex = 1;

ImageList控件:(主用于存储图片资源,然后在控件中显示出来,简化图片的管理)

p_w_picpathList1.ColorDepth = ColorDepth.Depth42Bit;//设置图像的颜色深度

加载图片:

p_w_picpathList1.Images.Clear();//清除图像
string Path = "C:\\Users\\lucky\\Desktop\\1.jpg";
Image img = Image.FromFile(Path, true);
p_w_picpathList1.Images.Add(img);
p_w_picpathList1.ImageSize = new Size(215, 135);
//设置pictureBox1的图像索引时p_w_picpathList1控件索引为0的图片
pictureBox1.Image = p_w_picpathList1.Images[0];

清除图片:

p_w_picpathList1.Images.RemoveAt(0);
pictureBox1.Image = null;

登陆常用到的KeyUp事件:

private void txtUserName_KeyUp(object sender, KeyEventArgs e)
{
    if (e.KeyValue == 13)//判断是否按下Enter键
        txtUserPwd.Focus();
}

字体滚动实例:

private void timer1_Tick(object sender, EventArgs e)
{
    //设置label1左边缘与其容器的工作区左边缘之间的距离
    label1.Left -= 2;
    //当label1右边缘与其容器的工作区左边缘之间的距离小于0时
    if (label1.Right < 0)
    {
        //设置label1左边缘与其容器的工作区左边缘之间的距离为该窗体的宽度
        label1.Left = this.Width;
    }
}

开始滚动:

timer1.Enabled = true;

新闻标题:C#Window控件及窗体的基本使用
网页网址:http://chengdu.cdxwcx.cn/article/iicjij.html