[C#] 實作流式佈局 - FlowLayoutPanel

閱讀時間約 5 分鐘
raw-image

在開發 C# Windows Forms 應用程式時,我們經常需要將多個控制項以流式佈局排列,以便在不同大小的視窗或面板中適應佈局變化。這時,FlowLayoutPanel 是一個非常實用的容器控制項,它可以自動調整子控制項的位置,使其按照流式佈局排列。本篇教學將帶你透過一個簡單的例子,學會如何在 C# 中使用 FlowLayoutPanel

設定 FlowLayoutPanel 的屬性

MainForm_Load 事件處理方法中,我們將設定 FlowLayoutPanel 的一些屬性,以確保流式佈局正常運作。以下是幾個重要的屬性:

private void MainForm_Load(object sender, EventArgs e)
{
// 建立 FlowLayoutPanel 控制項
FlowLayoutPanel flowLayoutPanel1 = new FlowLayoutPanel();
flowLayoutPanel1.FlowDirection = FlowDirection.LeftToRight;
flowLayoutPanel1.WrapContents = true;
flowLayoutPanel1.AutoScroll = true;
flowLayoutPanel1.Dock = DockStyle.Fill; // 佔滿整個視窗
}
  • FlowDirection 屬性指定子控制項排列的方向。在這裡,我們選擇從左到右排列。
  • WrapContents 屬性指定是否在達到容器邊界時換行。這裡我們設定為 true,這樣當視窗大小不足容納所有子控制項時,會換行排列。
  • AutoScroll 屬性指定當容器不足以顯示所有子控制項時,是否自動顯示捲軸。這樣,即使子控制項超出視窗範圍,我們也可以捲動查看它們。

設定子控制項的大小和事件處理方法

MainForm_Load 事件中,我們也可以設定子控制項的大小和事件處理方法。

using System;
using System.Windows.Forms;

namespace FlowLayoutPanelDemo
{
public partial class MainForm : Form
{
public MainForm()
{
InitializeComponent();
CreateControls();
}

private void CreateControls()
{
// 建立按鈕控制項
Button button1 = new Button();
button1.Text = "按鈕1";
button1.Size = new System.Drawing.Size(100, 30);
button1.Click += new EventHandler(button_Click);

Button button2 = new Button();
button2.Text = "按鈕2";
button2.Size = new System.Drawing.Size(100, 30);
button2.Click += new EventHandler(button_Click);

Button button3 = new Button();
button3.Text = "按鈕3";
button3.Size = new System.Drawing.Size(100, 30);
button3.Click += new EventHandler(button_Click);

// 加入子控制項到 FlowLayoutPanel
flowLayoutPanel1.Controls.Add(button1);
flowLayoutPanel1.Controls.Add(button2);
flowLayoutPanel1.Controls.Add(button3);

// 加入 FlowLayoutPanel 到主視窗
this.Controls.Add(flowLayoutPanel1);
}
}
}

實作子控制項的事件處理方法

最後,我們為子控制項的事件處理方法 button_Click 添加一些簡單的邏輯。

private void button_Click(object sender, EventArgs e)
{
// 在這裡可以寫點擊按鈕後的處理邏輯
MessageBox.Show($"你按下了按鈕:{((Button)sender).Text}");
}

這將使你的應用程式更靈活地適應不同大小的視窗或面板,並且可以自動調整子控制項的位置。這只是 FlowLayoutPanel 的基本用法,你可以根據你的需求添加更多子控制項和處理更多事件,以建立更豐富和互動的應用程式。

57會員
116Content count
這裡將以輕鬆風格,深入探討程式設計的基礎和高級概念。從程式語言到演算法,我們將以易懂的方式解釋每個主題,讓你輕鬆掌握。無論你是初學者或有經驗者,都能在這裡找到適合你的內容。無論你的目標是成為專業開發者還是擴展知識,我們都會陪伴你一同成長!
留言0
查看全部
發表第一個留言支持創作者!
程式輕鬆玩 的其他內容
在這篇教學中,我們將學習如何在C#程式中取得系統時間並進行格式化,以滿足不同需求的日期和時間顯示。
在專案中,使用NuGet套件管理員來安裝Microsoft.Office.Interop.Excel套件。這個套件將幫助我們與Excel進行互動。
在這篇教學中,我們將學習如何在C#程式碼中使用字串插值來加入變數。字串插值是一種方便且易讀的方式,讓我們可以將變數值插入到字串中,而不必使用傳統的串接方法。現在,讓我們開始吧! 在這個範例中,我們將創建一個簡單的應用程式,使用字串插值在螢幕上顯示一條個人訊息。這個訊息包含姓名、年齡和城市。 us
在現代科技的快速發展下,AI繪圖工具已成為許多創作者的得力助手。我有幸使用這些工具,並深感它們對創作過程的影響。
在現代科技快速發展的時代,學習程式設計已經成為一項重要的技能。無論年齡如何,程式設計都可以為人們帶來許多價值和益處。從幼童到老年人,學習程式設計不僅能夠培養邏輯思維,還能提升解決問題的能力和創造力。讓我們一起探討在各個年齡層中學習程式設計的重要性,並看看它如何在不同階段深化思維和進行系統化整理。
那是我第一次參加露營活動,選擇了新竹山作為目的地。我興奮地到場搭建帳篷,雖然花了不少時間,但最終還是成功地完成了。下午我們盡情地享受了整個下午,玩得開心滿足。 晚餐時,我們圍在營火旁烤肉,大家談笑風生,歡聲笑語充斥著整個露營地。我感受到與自然和諧相處的美好時光,這樣的體驗令我心情愉悅。
在這篇教學中,我們將學習如何在C#程式中取得系統時間並進行格式化,以滿足不同需求的日期和時間顯示。
在專案中,使用NuGet套件管理員來安裝Microsoft.Office.Interop.Excel套件。這個套件將幫助我們與Excel進行互動。
在這篇教學中,我們將學習如何在C#程式碼中使用字串插值來加入變數。字串插值是一種方便且易讀的方式,讓我們可以將變數值插入到字串中,而不必使用傳統的串接方法。現在,讓我們開始吧! 在這個範例中,我們將創建一個簡單的應用程式,使用字串插值在螢幕上顯示一條個人訊息。這個訊息包含姓名、年齡和城市。 us
在現代科技的快速發展下,AI繪圖工具已成為許多創作者的得力助手。我有幸使用這些工具,並深感它們對創作過程的影響。
在現代科技快速發展的時代,學習程式設計已經成為一項重要的技能。無論年齡如何,程式設計都可以為人們帶來許多價值和益處。從幼童到老年人,學習程式設計不僅能夠培養邏輯思維,還能提升解決問題的能力和創造力。讓我們一起探討在各個年齡層中學習程式設計的重要性,並看看它如何在不同階段深化思維和進行系統化整理。
那是我第一次參加露營活動,選擇了新竹山作為目的地。我興奮地到場搭建帳篷,雖然花了不少時間,但最終還是成功地完成了。下午我們盡情地享受了整個下午,玩得開心滿足。 晚餐時,我們圍在營火旁烤肉,大家談笑風生,歡聲笑語充斥著整個露營地。我感受到與自然和諧相處的美好時光,這樣的體驗令我心情愉悅。
你可能也想看
Thumbnail
1.加權指數與櫃買指數 週五的加權指數在非農就業數據開出來後,雖稍微低於預期,但指數仍向上噴出,在美股開盤後於21500形成一個爆量假突破後急轉直下,就一路收至最低。 台股方面走勢需觀察週一在斷頭潮出現後,週二或週三開始有無買單進場支撐,在沒有明確的反轉訊號形成前,小夥伴盡量不要貿然抄底,或是追空
Thumbnail
近期的「貼文發佈流程 & 版型大更新」功能大家使用了嗎? 新版式整體視覺上「更加凸顯圖片」,為了搭配這次的更新,我們推出首次貼文策展 ❤️ 使用貼文功能並完成這次的指定任務,還有機會獲得富士即可拍,讓你的美好回憶都可以用即可拍珍藏!
Thumbnail
宜蘭 冬山鄉 寗夏時光 C棟 親子民宿 📌來到寗夏彷彿能留住一整個燦爛夏季!我們一同住進夏天,喚醒沉睡已久的奔放心靈;深吸海岸香氣,嗅見遼闊無垠的自由氣息;微風輕吹,感受無拘無束的自在溫度,彼此對望,綻開笑顏,乘這希望的風,抓住這熱情的夏,明年再次相聚! ⬇️完整說明網址⬇️
Thumbnail
近年來全球3C產業發展蓬勃,現代兒童從小接觸手機、平板等3C產品,就連長輩也是每日睡前關燈使用手機直到入眠,新竹中國醫藥學院附設醫院眼科主任陳瑩山醫師表示,長時間的使用會使眼睛受到嚴重的損害,研究調查更指出目前台灣兒童的近視平均年齡相較以前足足降低了5歲,中老年人得到眼睛相關疾病更是提高6成以上。
Thumbnail
介紹 📷 定義 處理序(Process) (大陸:進程): 一個程序運行時,占用全部計算資源的總和 執行緒(Thread) (大陸:線程):是作業系統能夠進行運算排程的最小單位。 大部分情況下,它被包含在行程之中,是行程中的實際運作單位。 C#多線程和異步(一)——基本概念和使用方法 執行緒帶來的
Thumbnail
父母如何制定3C使用規則,需瞭解自己給予孩子使用3C的目的與時機,並制定好頻率與時間,確實執行並監督管理。
Thumbnail
​ 隨著台灣目前社會演變,男生義務役兵役期只有四個月,軍方不斷合併與解編下,許多軍方舊營區都分別荒廢、改建、拆除等不同命運。這篇就來介紹台灣當代文化實驗場C-LAB就是軍方遷移荒廢下改建的一個華麗變身複合性用途園區。 台灣當代文化實驗場C-LAB相關資訊:: 地址: 台北市大安區建國南路177號
Thumbnail
【「螢光異變」戶外裝置展】 #「螢光異變」戶外裝置展 【「螢光異變」戶外裝置展】 日期:即日起~2022/4/30 地點:臺灣當代文化實驗場C-LAB(臺北市大安區建國南路一段177號) 【偶希都理 臺灣旅遊~方格子】 https://vocus.cc/ohitori_taiwan/home
Thumbnail
「老師,孩子到底應該幾歲開始寫字?」 「我的孩子寫功課字寫得不好看,應該怎麼辦?」 「功課寫得慢就算了,還常常多一點、少一撇,看了真是昏倒。」 身為家長的您,是否心中經常常有這些疑問呢?  
Thumbnail
經過半年的觀察,我認為我們這裡的小孩在使用3C設備的狀態上,大致可以分成三種類型:抗拒型、創造型及逃避型。 抗拒型的孩子,通常是最初加入這個實驗的成員。他們過去被嚴格管制使用時間,這讓他們對於使用3C設備有極高的內在動力。
Thumbnail
我們這群自學生大量使用數位產品,孩子們都有一台自己的平板、筆記型電腦或桌上型電腦。不只是大量使用數位產品來娛樂,上課時也使用協作平台,交作業也可以直接傳給我檔案。法國哲學家米謝・塞荷稱這些孩子為「拇指姑娘」,巧妙地形容了這個「用手指來跟世界互動」的世代。
Thumbnail
1.加權指數與櫃買指數 週五的加權指數在非農就業數據開出來後,雖稍微低於預期,但指數仍向上噴出,在美股開盤後於21500形成一個爆量假突破後急轉直下,就一路收至最低。 台股方面走勢需觀察週一在斷頭潮出現後,週二或週三開始有無買單進場支撐,在沒有明確的反轉訊號形成前,小夥伴盡量不要貿然抄底,或是追空
Thumbnail
近期的「貼文發佈流程 & 版型大更新」功能大家使用了嗎? 新版式整體視覺上「更加凸顯圖片」,為了搭配這次的更新,我們推出首次貼文策展 ❤️ 使用貼文功能並完成這次的指定任務,還有機會獲得富士即可拍,讓你的美好回憶都可以用即可拍珍藏!
Thumbnail
宜蘭 冬山鄉 寗夏時光 C棟 親子民宿 📌來到寗夏彷彿能留住一整個燦爛夏季!我們一同住進夏天,喚醒沉睡已久的奔放心靈;深吸海岸香氣,嗅見遼闊無垠的自由氣息;微風輕吹,感受無拘無束的自在溫度,彼此對望,綻開笑顏,乘這希望的風,抓住這熱情的夏,明年再次相聚! ⬇️完整說明網址⬇️
Thumbnail
近年來全球3C產業發展蓬勃,現代兒童從小接觸手機、平板等3C產品,就連長輩也是每日睡前關燈使用手機直到入眠,新竹中國醫藥學院附設醫院眼科主任陳瑩山醫師表示,長時間的使用會使眼睛受到嚴重的損害,研究調查更指出目前台灣兒童的近視平均年齡相較以前足足降低了5歲,中老年人得到眼睛相關疾病更是提高6成以上。
Thumbnail
介紹 📷 定義 處理序(Process) (大陸:進程): 一個程序運行時,占用全部計算資源的總和 執行緒(Thread) (大陸:線程):是作業系統能夠進行運算排程的最小單位。 大部分情況下,它被包含在行程之中,是行程中的實際運作單位。 C#多線程和異步(一)——基本概念和使用方法 執行緒帶來的
Thumbnail
父母如何制定3C使用規則,需瞭解自己給予孩子使用3C的目的與時機,並制定好頻率與時間,確實執行並監督管理。
Thumbnail
​ 隨著台灣目前社會演變,男生義務役兵役期只有四個月,軍方不斷合併與解編下,許多軍方舊營區都分別荒廢、改建、拆除等不同命運。這篇就來介紹台灣當代文化實驗場C-LAB就是軍方遷移荒廢下改建的一個華麗變身複合性用途園區。 台灣當代文化實驗場C-LAB相關資訊:: 地址: 台北市大安區建國南路177號
Thumbnail
【「螢光異變」戶外裝置展】 #「螢光異變」戶外裝置展 【「螢光異變」戶外裝置展】 日期:即日起~2022/4/30 地點:臺灣當代文化實驗場C-LAB(臺北市大安區建國南路一段177號) 【偶希都理 臺灣旅遊~方格子】 https://vocus.cc/ohitori_taiwan/home
Thumbnail
「老師,孩子到底應該幾歲開始寫字?」 「我的孩子寫功課字寫得不好看,應該怎麼辦?」 「功課寫得慢就算了,還常常多一點、少一撇,看了真是昏倒。」 身為家長的您,是否心中經常常有這些疑問呢?  
Thumbnail
經過半年的觀察,我認為我們這裡的小孩在使用3C設備的狀態上,大致可以分成三種類型:抗拒型、創造型及逃避型。 抗拒型的孩子,通常是最初加入這個實驗的成員。他們過去被嚴格管制使用時間,這讓他們對於使用3C設備有極高的內在動力。
Thumbnail
我們這群自學生大量使用數位產品,孩子們都有一台自己的平板、筆記型電腦或桌上型電腦。不只是大量使用數位產品來娛樂,上課時也使用協作平台,交作業也可以直接傳給我檔案。法國哲學家米謝・塞荷稱這些孩子為「拇指姑娘」,巧妙地形容了這個「用手指來跟世界互動」的世代。