亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在winform下實(shí)現(xiàn)左右布局多窗口界面的方法之續(xù)篇

 更新時(shí)間:2016年02月29日 09:56:39   作者:夢(mèng)在旅途  
這篇文章主要介紹了在winform下實(shí)現(xiàn)左右布局多窗口界面的方法之續(xù)篇 的相關(guān)資料,需要的朋友可以參考下

在上篇文章在winform下實(shí)現(xiàn)左右布局多窗口界面的方法已經(jīng)實(shí)現(xiàn)了左右布局多窗口界面,今天本來(lái)是研究基于winform的插件編程,沒(méi)想到順便又找到了另一種實(shí)現(xiàn)方案,這種實(shí)現(xiàn)方案更簡(jiǎn)單,要寫(xiě)的代碼也很少,具體實(shí)現(xiàn)如下。

可視化設(shè)計(jì)部份:

1.父窗口:ParentForm的IsMdiContainer 設(shè)置為 true,即:this.IsMdiContainer=true;

2.在父窗口中添加一個(gè)頂部菜單:menuStrip1,并新增一個(gè)菜單項(xiàng):Windows,且將menuStrip1的MdiWindowListItem設(shè)置為該Windows菜單對(duì)象,即: this.menuStrip1.MdiWindowListItem = this.windowsToolStripMenuItem;

3.在父窗口中添加一個(gè)樹(shù)形菜單:treeView1,并將其Dock設(shè)為左靠齊,即:this.treeView1.Dock = System.Windows.Forms.DockStyle.Left;且將margin設(shè)為0;

4.在父窗口中添加一個(gè)Panel:panel1,且將其width設(shè)為3;

以下是設(shè)計(jì)后自動(dòng)生成的代碼:

namespace WinFormTest
{
partial class ParentForm
{
/// <summary>
/// 必需的設(shè)計(jì)器變量。
/// </summary>
private System.ComponentModel.IContainer components = null;
/// <summary>
/// 清理所有正在使用的資源。
/// </summary>
/// <param name="disposing">如果應(yīng)釋放托管資源,為 true;否則為 false。</param>
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Windows 窗體設(shè)計(jì)器生成的代碼
/// <summary>
/// 設(shè)計(jì)器支持所需的方法 - 不要
/// 使用代碼編輯器修改此方法的內(nèi)容。
/// </summary>
private void InitializeComponent()
{
this.menuStrip1 = new System.Windows.Forms.MenuStrip();
this.windowsToolStripMenuItem = new System.Windows.Forms.ToolStripMenuItem();
this.treeView1 = new System.Windows.Forms.TreeView();
this.panel1 = new System.Windows.Forms.Panel();
this.menuStrip1.SuspendLayout();
this.SuspendLayout();
// 
// menuStrip1
// 
this.menuStrip1.Items.AddRange(new System.Windows.Forms.ToolStripItem[] {
this.windowsToolStripMenuItem});
this.menuStrip1.Location = new System.Drawing.Point(0, 0);
this.menuStrip1.MdiWindowListItem = this.windowsToolStripMenuItem;
this.menuStrip1.Name = "menuStrip1";
this.menuStrip1.Size = new System.Drawing.Size(684, 25);
this.menuStrip1.TabIndex = 0;
this.menuStrip1.Text = "menuStrip1";
// 
// windowsToolStripMenuItem
// 
this.windowsToolStripMenuItem.Name = "windowsToolStripMenuItem";
this.windowsToolStripMenuItem.Size = new System.Drawing.Size(73, 21);
this.windowsToolStripMenuItem.Text = "Windows";
// 
// treeView1
// 
this.treeView1.Dock = System.Windows.Forms.DockStyle.Left;
this.treeView1.Location = new System.Drawing.Point(0, 25);
this.treeView1.Margin = new System.Windows.Forms.Padding(0);
this.treeView1.Name = "treeView1";
this.treeView1.Size = new System.Drawing.Size(228, 380);
this.treeView1.TabIndex = 3;
this.treeView1.NodeMouseDoubleClick += new System.Windows.Forms.TreeNodeMouseClickEventHandler(this.treeView1_NodeMouseDoubleClick);
// 
// panel1
// 
this.panel1.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Top | System.Windows.Forms.AnchorStyles.Bottom) 
| System.Windows.Forms.AnchorStyles.Left)));
this.panel1.BackColor = System.Drawing.Color.Red;
this.panel1.BorderStyle = System.Windows.Forms.BorderStyle.FixedSingle;
this.panel1.Cursor = System.Windows.Forms.Cursors.VSplit;
this.panel1.Location = new System.Drawing.Point(230, 28);
this.panel1.Margin = new System.Windows.Forms.Padding(0);
this.panel1.Name = "panel1";
this.panel1.Size = new System.Drawing.Size(3, 100);
this.panel1.TabIndex = 5;
// 
// Form1
// 
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 12F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(684, 405);
this.Controls.Add(this.panel1);
this.Controls.Add(this.treeView1);
this.Controls.Add(this.menuStrip1);
this.IsMdiContainer = true;
this.MainMenuStrip = this.menuStrip1;
this.Name = "Form1";
this.Text = "Form1";
this.Load += new System.EventHandler(this.Form1_Load);
this.Resize += new System.EventHandler(this.Form1_Resize);
this.menuStrip1.ResumeLayout(false);
this.menuStrip1.PerformLayout();
this.ResumeLayout(false);
this.PerformLayout();
}
#endregion
private System.Windows.Forms.MenuStrip menuStrip1;
private System.Windows.Forms.ToolStripMenuItem windowsToolStripMenuItem;
private System.Windows.Forms.TreeView treeView1;
private System.Windows.Forms.Panel panel1;
}
}

編碼部份:

其實(shí)上面的設(shè)計(jì)后,如果通過(guò)以下定義的方法打開(kāi)一個(gè)子窗口,則直接實(shí)現(xiàn)了左右布局且包含多子窗口的界面。

private void ShowChildForm<TForm>() where TForm : Form, new()
{
Form childForm = new TForm();
childForm.MdiParent = this;
childForm.Name = "ChildForm - " + DateTime.Now.Millisecond.ToString();
childForm.Text = childForm.Name;
childForm.Show();
}

當(dāng)然仍然有不完美的地方,那就是左邊菜單欄寬度不能動(dòng)態(tài)調(diào)整,而又沒(méi)有用到splitContainer,故我們只有自己來(lái)實(shí)現(xiàn),其實(shí)也很簡(jiǎn)單,步驟如下: 

1.在父窗口構(gòu)造函數(shù)中加入初始化panel1(用作分割器)位置及訂閱相關(guān)事件,代碼如下:

public ParentForm()
{
InitializeComponent();
panel1.MouseDown += panel1_MouseDown;
panel1.MouseUp += panel1_MouseUp;
panel1.MouseMove += panel1_MouseMove;
panel1.Top = menuStrip1.Height;
panel1.Left = treeView1.Left + treeView1.Width;
panel1.Height = panel1.Parent.Height;
}

上述代碼的作用是:1.保證panel1的高度與位置與左側(cè)樹(shù)形菜單控件相匹配;2.訂閱的三個(gè)Mouse事件主要是為了后面實(shí)現(xiàn)移動(dòng)panel1。

2.實(shí)現(xiàn)訂閱的三個(gè)Mouse事件所對(duì)應(yīng)的方法,分別為鼠標(biāo)按下、鼠標(biāo)移動(dòng)、鼠標(biāo)松開(kāi),代碼如下:

private bool startMove = false; //用于標(biāo)記是否在移動(dòng)中
void panel1_MouseMove(object sender, MouseEventArgs e)
{
if (startMove)
{
panel1.Left += e.X;
}
}
void panel1_MouseUp(object sender, MouseEventArgs e)
{
if (startMove)
{
panel1.Left += e.X;
startMove = false;
this.treeView1.Width = panel1.Left;
}
}
void panel1_MouseDown(object sender, MouseEventArgs e)
{
startMove = true;
} 

上述代碼作用:按下鼠標(biāo)標(biāo)記為開(kāi)始移動(dòng),然后移動(dòng)鼠標(biāo),若是標(biāo)記移動(dòng)中,說(shuō)明是要移動(dòng)panel1,故直接將鼠標(biāo)當(dāng)前的X坐標(biāo)位置累加到panel1.Left屬性上,從而實(shí)現(xiàn)移動(dòng),當(dāng)鼠標(biāo)彈起后,則將樹(shù)形菜單的寬度設(shè)置為panel1.Left,從而實(shí)現(xiàn)樹(shù)形菜單隨panel1的移動(dòng)而改變大小。

同時(shí)為了保證panel1的高度始終與樹(shù)形菜單相同,在父窗口的Resize方法加入動(dòng)態(tài)調(diào)整panel1的高度,代碼如下:

private void ParentForm_Resize(object sender, EventArgs e)
{
panel1.Height = panel1.Parent.Height;
}

到此就完成了整個(gè)的實(shí)現(xiàn)方案,為了便于模擬在樹(shù)形菜單中雙擊打開(kāi)子窗口的效果,同時(shí)也添加了如下代碼:

private void ParentForm_Load(object sender, EventArgs e)
{
LoadMenuNodes();
}
private void LoadMenuNodes() //實(shí)現(xiàn)情況應(yīng)該是從數(shù)據(jù)庫(kù)及用戶(hù)權(quán)限來(lái)進(jìn)行動(dòng)態(tài)創(chuàng)建菜單項(xiàng)
{
this.treeView1.Nodes.Clear();
var root = this.treeView1.Nodes.Add("Root");
for (int i = 1; i <= 10; i++)
{
var section = root.Nodes.Add("Section-" + i);
int maxNodes = new Random(i).Next(1, 10);
for (int n = 1; n <= maxNodes; n++)
{
section.Nodes.Add(string.Format("Level-{0}-{1}", i, n));
}
}
}
private void treeView1_NodeMouseDoubleClick(object sender, TreeNodeMouseClickEventArgs e)
{
if (e.Node.Nodes.Count <= 0)//當(dāng)非父節(jié)點(diǎn)(即:實(shí)際的功能節(jié)點(diǎn))
{
ShowChildForm<ChildForm>();
}
}

附上完整的實(shí)現(xiàn)代碼:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace WinFormTest
{
public partial class ParentForm : Form
{
private bool startMove = false;
public ParentForm()
{
InitializeComponent();
panel1.MouseDown += panel1_MouseDown;
panel1.MouseUp += panel1_MouseUp;
panel1.MouseMove += panel1_MouseMove;
panel1.Top = menuStrip1.Height;
panel1.Left = treeView1.Left + treeView1.Width;
panel1.Height = panel1.Parent.Height;
}
void panel1_MouseMove(object sender, MouseEventArgs e)
{
if (startMove)
{
panel1.Left += e.X;
}
}
void panel1_MouseUp(object sender, MouseEventArgs e)
{
if (startMove)
{
panel1.Left += e.X;
startMove = false;
this.treeView1.Width = panel1.Left;
}
}
void panel1_MouseDown(object sender, MouseEventArgs e)
{
startMove = true;
}
private void ParentForm_Load(object sender, EventArgs e)
{
LoadMenuNodes();
}
private void treeView1_NodeMouseDoubleClick(object sender, TreeNodeMouseClickEventArgs e)
{
if (e.Node.Nodes.Count <= 0)//當(dāng)非父節(jié)點(diǎn)(即:實(shí)際的功能節(jié)點(diǎn))
{
ShowChildForm<ChildForm>();
}
}
private void ParentForm_Resize(object sender, EventArgs e)
{
panel1.Height = panel1.Parent.Height;
}
private void LoadMenuNodes() //實(shí)現(xiàn)情況應(yīng)該是從數(shù)據(jù)庫(kù)及用戶(hù)權(quán)限來(lái)進(jìn)行動(dòng)態(tài)創(chuàng)建菜單項(xiàng)
{
this.treeView1.Nodes.Clear();
var root = this.treeView1.Nodes.Add("Root");
for (int i = 1; i <= 10; i++)
{
var section = root.Nodes.Add("Section-" + i);
int maxNodes = new Random(i).Next(1, 10);
for (int n = 1; n <= maxNodes; n++)
{
section.Nodes.Add(string.Format("Level-{0}-{1}", i, n));
}
}
}
private void ShowChildForm<TForm>() where TForm : Form, new()
{
Form childForm = new TForm();
childForm.MdiParent = this;
childForm.Name = "ChildForm - " + DateTime.Now.Millisecond.ToString();
childForm.Text = childForm.Name;
childForm.Show();
}
}
}

最終效果如下圖示:

說(shuō)明:我這里為了體現(xiàn)分割器,故將其背景色設(shè)為紅色,便于大家觀察,這種解決方案與之前的解決方案功能上是相同的,但有一點(diǎn)小小區(qū)別,之前的解決方案中子窗口的標(biāo)題欄是在父窗口的容器內(nèi),而本文的解決方案中子窗口在最大化后,子窗口的標(biāo)題欄會(huì)與父窗口合并,如下圖示,至于大家用哪種依實(shí)際場(chǎng)景。


關(guān)于在winform下實(shí)現(xiàn)左右布局多窗口界面的方法之續(xù)篇的相關(guān)知識(shí)就給大家介紹到這里,后續(xù)時(shí)間我會(huì)繼續(xù)研究winform關(guān)于插件式編程(近期工作任務(wù)要求),到時(shí)候同樣會(huì)分享給大家,也歡迎大家一起交流,當(dāng)然高手可以無(wú)視。

相關(guān)文章

  • C#圖形區(qū)域剪切的實(shí)現(xiàn)方法

    C#圖形區(qū)域剪切的實(shí)現(xiàn)方法

    這篇文章主要介紹了C#圖形區(qū)域剪切的實(shí)現(xiàn)方法,涉及C#圖形操作的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • c# winform異步不卡界面的實(shí)現(xiàn)方法

    c# winform異步不卡界面的實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于c# winform異步不卡界面的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用c#具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 基于WPF實(shí)現(xiàn)擬物音量控件

    基于WPF實(shí)現(xiàn)擬物音量控件

    這篇文章主要為大家詳細(xì)介紹了如何基于WPF實(shí)現(xiàn)簡(jiǎn)單的擬物音量控件,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)或工作有一定幫助,感興趣的小伙伴可以了解一下
    2023-05-05
  • .net2.0+ Winform項(xiàng)目實(shí)現(xiàn)彈出容器層

    .net2.0+ Winform項(xiàng)目實(shí)現(xiàn)彈出容器層

    在實(shí)際工作中,如果能像菜單一樣彈出自定義內(nèi)容,會(huì)方便很多,比如查詢(xún)時(shí),比如下拉列表顯示多列信息時(shí),比如在填寫(xiě)某個(gè)信息需要查看一些信息樹(shù)時(shí)。這個(gè)時(shí)候自定義彈出界面就顯的非常重要了
    2015-08-08
  • WPF+SkiaSharp實(shí)現(xiàn)自繪投籃小游戲

    WPF+SkiaSharp實(shí)現(xiàn)自繪投籃小游戲

    這篇文章主要介紹了如何利用WPF+SkiaSharp實(shí)現(xiàn)自繪投籃小游戲。此案例主要是針對(duì)光線投影法碰撞檢測(cè)功能的示例,順便做成了一個(gè)小游戲,很簡(jiǎn)單,但是,效果卻很不錯(cuò),感興趣的可以動(dòng)手嘗試一下
    2022-08-08
  • c# 網(wǎng)絡(luò)編程之tcp

    c# 網(wǎng)絡(luò)編程之tcp

    這篇文章主要介紹了c# 網(wǎng)絡(luò)編程之tcp的的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下
    2021-02-02
  • C#中this用法系列(二) 通過(guò)this修飾符為原始類(lèi)型擴(kuò)展方法

    C#中this用法系列(二) 通過(guò)this修飾符為原始類(lèi)型擴(kuò)展方法

    定義一個(gè)靜態(tài)類(lèi),類(lèi)中定義靜態(tài)方法,方法中參數(shù)類(lèi)型前邊加上this修飾符,即可實(shí)現(xiàn)對(duì)參數(shù)類(lèi)型的方法擴(kuò)展,下面通過(guò)實(shí)例代碼給大家介紹下,需要的朋友參考下吧
    2016-12-12
  • Unity實(shí)戰(zhàn)之FlyPin(見(jiàn)縫插針)小游戲的實(shí)現(xiàn)

    Unity實(shí)戰(zhàn)之FlyPin(見(jiàn)縫插針)小游戲的實(shí)現(xiàn)

    這篇文章主要介紹了利用Unity制作FlyPin(見(jiàn)縫插針)小游戲的實(shí)現(xiàn)方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起試一試
    2022-01-01
  • 深入分析C# 線程同步

    深入分析C# 線程同步

    這篇文章主要介紹了C# 線程同步的的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06
  • C# PadLeft、PadRight用法詳解

    C# PadLeft、PadRight用法詳解

    本文主要介紹了C# PadLeft、PadRight用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02

最新評(píng)論