Winform学生信息管理系统主页面设计(2)

时间:2021-11-27 08:28:44

在上次的学生登录窗口的设计(winform学生信息管理系统登陆窗体设计(1) )中,需要修改的地方为:

1、登录窗口的最大化和最小化,这个一般的登录窗口不需要,因此我们也不做,单击学生信息管理系统的窗体设计找到属性maximizebox和属性(窗口的最大化)和minimizbox(窗口的最小化)是true,把它们改为false。

2、登录窗口设计的属性acceptbutton将其改为确定按钮的唯一名字(也就是button1),因此在按下回车键后我们也能登录到学生信息管理系统主页面。

3、在登录名称后的textbox1控件需要输入登录者的名字admin,而登录密码后的textbox2控件需要输入登陆者的秘密123456,因为在控件属性设置时将其密码隐藏为*,因此我们并不能看见。

Winform学生信息管理系统主页面设计(2)

      要想进入到学生信息管理系统主页面还需要在这个windowsforms下再添加一个窗体,右击windowsforms,选择添加,选择windows窗体,进入到添加新项的对话框,名字保持不变为form2,最后单击添加即可。在这里我们需要做的东西很多:

Winform学生信息管理系统主页面设计(2)

1、将窗体的text属性改为学生信息管理系统,再将属性windowstate改为maximized(第一次出现使其最大化),最后还需要将属性ismdicontainer(将主页面的窗体覆盖到登录窗之上)改为true。

 2、需要向窗体上添加控件菜单栏,在控件中我们选择menustrip控件,依次添加想要构建的主菜单项,学生管理系统的设计者或管理员对所有的模块都是可用的,若是学生或教师则对有些模块不可用,我们这个以后再进行,在这里我们就是作为管理员或设计者来设计这个系统的,因此对所有的模块可见,需要添加的菜单项为:系统管理,成绩管理,课程管理,班级管理,学生管理,专业管理,教师管理,此外还需要其它的一些菜单项,比如窗体,帮助,退出。

3、在窗体上还需要添加statusstrip控件,这个控件的作用是状态栏,将状态栏的属性name改为tssl_name。

Winform学生信息管理系统主页面设计(2)

4、在窗体上再添加一个工具栏,就是添加toolstrip控件,这个工具栏放在菜单栏的下面,在工具栏中添加一个button控件,单击它会出现一个新的子窗体对话框,这个子窗体我们稍后下一步添加。

Winform学生信息管理系统主页面设计(2)

5、进行子窗体的添加,就像添加主页面窗体一样再次添加一个名为children窗体,这个子窗体我们先不做任何的改动,单单就是为了打开它,进行必要的说明。

Winform学生信息管理系统主页面设计(2)

6、在主页面的窗体的菜单栏的退出,我奥们单击它需要退出整个程序,这就需要添加click事件,我们右击窗体打开代码,回到主页面窗体中点击退出,找到click事件,双击后面的空白处返回到代码编译写入:

?
1
2
3
4
5
<span style="font-size:18px;">   
private void 退出toolstripmenuitem_click(object sender, eventargs e)
    {
      application.exit();//单击主菜单中的退出我们退出整个程序
    }</span>

Winform学生信息管理系统主页面设计(2)

7、在添加的工具栏的button控件,我们单击它会出现名为children的子窗体,由于主页面是mdi窗体,因此重复单击它出现很多名为children的子窗体,依然是如上上一步骤的那样添加click事件,写入的代码为:

?
1
2
3
4
5
6
7
<span style="font-size:18px;">   
private void toolstripbutton1_click(object sender, eventargs e)
    {
      children qq = new children();//创建一个子窗体的实例
      qq.mdiparent = this;//要求子窗体的父窗体是mdi窗体
      qq.show();
    }</span>

Winform学生信息管理系统主页面设计(2)

这样基本上主页面窗体就算是设计完毕。

下面进行的是连接登录窗体和主页面窗体:

1、输入你所写的信息后单击登录窗口的确定按钮后进入主页面窗体,这就需要在登录窗体的确定按钮(button1)添加click事件,此外还需要获取在textbox1中输入的信息,写入的代码为:

?
1
2
3
4
5
6
7
<span style="font-size:18px;"
private void button1_click(object sender, eventargs e)
  {
    string str = textbox1.text;//获取你在textbox1中输入的信息
    form2 ad = new form2(str);//创建一个学生信息管理系统主界面的对象
    ad.show();//点击确定后进入学生信息管理系统主界面
  }</span>

2、单击登录窗口中的取消按钮(button2)退出整个程序。也是添加click事件,写入代码为:

?
1
2
3
4
5
<span style="font-size:18px;">
private void button2_click(object sender, eventargs e)
{
  application.exit();//点击取消退出整个程序
}</span>

3、我们所在主页面中添加的状态栏所显示的信息如要为我们在登录窗口输入的信息那么就需要在主页面的窗体中的构造函数做一些修改,将无参数的构造函数改为带一个字符串类型参数的构造函数,将参数传递给状态栏的属性text,写入的代码为:

?
1
2
3
4
5
6
<span style="font-size:18px;">   
public form2(string s)
    {
      initializecomponent();
      tssl_name.text = s;
    }</span>

4、我们在打开主页面窗体有时候需要隐藏登录窗体,这就需要在单击确定按钮后隐藏登录窗体,在第一个步骤的代码中添加 this.hide()语句。因此步骤一完整的代码为:

?
1
2
3
4
5
6
7
8
<span style="font-size:18px;"
private void button1_click(object sender, eventargs e)
   {
     string str = textbox1.text;//获取你在textbox1中输入的信息
     form2 ad = new form2(str);//创建一个学生信息管理系统主界面的对象
     ad.show();//点击确定后进入学生信息管理系统主界面
     this.hide();//单击确定后隐藏登录窗口
   }</span>

在这里说明一个问题,就是在单击主页面的右上方的x按钮时并没有退出整个程序,因为是隐藏了登录窗口,如果退出整个程序,需要点击主页面的自己设置的退出,这才是退出整个程序。
执行调试,进行错误的修改和处理,完整的form1(登录窗体)代码为:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<span style="font-size:18px;">namespace windowsforms
{
  public partial class form1 : form
  {
    public form1()
    {
      initializecomponent();
    }
 
    private void button1_click(object sender, eventargs e)
    {
      string str = textbox1.text;//获取你在textbox1中输入的信息
      form2 ad = new form2(str);//创建一个学生信息管理系统主界面的对象
      ad.show();//点击确定后进入学生信息管理系统主界面
      this.hide();//单击确定后隐藏登录窗口
    }
 
    private void button2_click(object sender, eventargs e)
    {
      application.exit();//点击取消退出整个程序
    }
  }
}</span>

完整的主页面窗体的代码为:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<span style="font-size:18px;">namespace windowsforms
{
  public partial class form2 : form
  {
    public form2(string s)
    {
      initializecomponent();
      tssl_name.text = s;//将登陆窗口textbox1输入的信息传递给状态栏text属性
    }
 
    private void 退出toolstripmenuitem_click(object sender, eventargs e)
    {
      application.exit();//单击主菜单中的退出我们退出整个程序
    }
 
    private void menustrip1_itemclicked(object sender, toolstripitemclickedeventargs e)
    {
 
    }
 
    private void toolstripbutton1_click(object sender, eventargs e)
    {
      children qq = new children();//创建一个子窗体的实例
      qq.mdiparent = this;//要求子窗体的父窗体是mdi窗体
      qq.show();
    }
  }
}</span>

可以找出你保存程序的位置打开你所构建的程序:运行一下试试,对比一下和自己想的有什么区别,再进行修改。

Winform学生信息管理系统主页面设计(2)

以上基本就是学生信息管理系统主页面的构建,希望对大家的学习有所帮助。