winform代码生成器(二)

代码下载 地址 http://pan.baidu.com/s/1nuZjyat

 

接着说 上文继续说,这次我们要生成主从表.

此方用到了第三方的 控件 DevExpress 的Gridview .大家可去网上下载,安装后再开发.

主从表的设计,我用的 是splitContainer1  控件,水平方向拆分,

 

 

看看表 设计器文件, 发生了什么变化.与之前的button控件一样,也就那4步

 

 

 

//1.创建 SplitContainer对象 
private System.Windows.Forms.SplitContainer splitContainer1;

//2.实例化button1 对象
this.splitContainer1 = new System.Windows.Forms.SplitContainer();
            ((System.ComponentModel.ISupportInitialize)(this.splitContainer1)).BeginInit(); //开始初始化化
this.splitContainer1.SuspendLayout(); //挂起布局

//3设置 SplitContainer的基本属性
this.splitContainer1.Dock = System.Windows.Forms.DockStyle.Fill;
this.splitContainer1.Location = new System.Drawing.Point(0, 0);
this.splitContainer1.Name = "splitContainer1";
this.splitContainer1.Orientation = System.Windows.Forms.Orientation.Horizontal;
this.splitContainer1.Size = new System.Drawing.Size(526, 387);
this.splitContainer1.SplitterDistance = 175;
this.splitContainer1.TabIndex = 0;

//把 SplitContainer绘制 到窗体
this.Controls.Add(this.splitContainer1);

((System.ComponentModel.ISupportInitialize)(this.splitContainer1)).EndInit();//结束初始化化

this.splitContainer1.ResumeLayout(false);  //恢复布局

 

为什么没有 Panel1, Panel2呢? 那上因为 里面没有数据,主从表我是这样设计 的

 

splitContainer1.Panel1 存放主表内容

splitContainer1.Panel2 存放从表内容Devexpress的GridControl控件(DevExpress.XtraGrid.v15.2.dll) 

 

我们向Panel1 加一个 button ,Panel2 加一个GridControl .

我们看看变化

splitContainer1 初始化化后,加入了 Panel1, Panel2

this.splitContainer1.Panel1.SuspendLayout();

this.splitContainer1.Panel2.SuspendLayout();

 

然后把

Button1 放入Panel1,

GridControl1  放入Panel2

 

最后 完成 splitContainer1 .

 

 

好了,知道怎么工作的,那就做个窗体模板,往里放控件就好了.

 

这时,我可以按 上篇文章 讲的那样,设计好 样子,然后把能提换的代码 用占位符,做出一个窗体模板,生成控件的代码也与上一篇类似.

 

从表名称 就是在一张表的名称后面加上Details,约定哈,可以在 app.config 里修改.

窗体上再放一个CheckBox ,用于判断对方是否 要创建主从表,也可能只想生成主表嘛

 

如何 向从表 Title 如何生成呢? 也分4步

//1.创建 ColumnTitle  对象 
private DevExpress.XtraGrid.Columns.GridColumn   ColumnTitle;

//2.实例化 ColumnTitle   

this. ColumnTitle = new DevExpress.XtraGrid.Columns.GridColumn();

//3.把  ColumnTitle  放入 gridView的 Columns 内
this.gridView1.Columns.AddRange(new DevExpress.XtraGrid.Columns.GridColumn[] {
this. ColumnTitle,
}

//4.设置 ColumnTitle  的属性
this. ColumnTitle.FieldName = " TableData"; //绑定的字段 
this. ColumnTitle.Name = "TotalPrice"; //标识该对象的名称
this. ColumnTitle.Visible = true;
this. ColumnTitle.Caption = "显示名称";

 

 

 

就可以在窗体中显示啦

 

 

 

然后 读取主从表,生成各自的 控件,放入相应的地方,

 

 

 

App.config

 

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <startup> 
        <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
    </startup>
  <appSettings>
    <add key="TimeFormat" value="yyyy-MM-dd"/>
    <!--时间格式化-->
    <add key="Details" value="Details"/>
    <!--从表后缀-->

  </appSettings>
</configuration>

 

 

posted @ 2017-04-18 19:48  likehc  阅读(1314)  评论(0编辑  收藏  举报