[C#] 實作表格佈局 - TableLayoutPanel

閱讀時間約 6 分鐘
raw-image

當你需要在 C# Windows Forms 應用程式中以表格形式排列子控制項時,TableLayoutPanel 是一個非常有用的容器控制項。TableLayoutPanel 允許你將子控制項放入行和列的格子中,並且可以輕鬆地調整格子的大小和配置。在本節中,我們將介紹 TableLayoutPanel 的基本概念並實作一個簡單的範例。

介紹 TableLayoutPanel

TableLayoutPanel 是一個容器控制項,類似於表格。它允許你在行和列中放置子控制項,並且可以設定每個格子的大小和排列。主要的屬性包括:

  • RowCount:指定表格的行數。
  • ColumnCount:指定表格的列數。
  • RowStyles:用於設定每一行的大小和佈局方式。
  • ColumnStyles:用於設定每一列的大小和佈局方式。
  • Controls.Add:用於將子控制項添加到指定的行和列中。

實作 TableLayoutPanel 範例

現在,讓我們實作一個簡單的範例,展示如何使用 TableLayoutPanel 在 C# 中實現表格佈局。

MainForm 類別的建構函式中,加入程式碼以動態生成 TableLayoutPanel 和子控制項。

csharpCopy code
using System;
using System.Windows.Forms;

namespace TableLayoutPanelDemo
{
public partial class MainForm : Form
{
public MainForm()
{
InitializeComponent();
CreateTableLayout();
}

private void CreateTableLayout()
{
// 建立 TableLayoutPanel 控制項
TableLayoutPanel tableLayoutPanel1 = new TableLayoutPanel();
tableLayoutPanel1.RowCount = 2; // 表格有兩行
tableLayoutPanel1.ColumnCount = 3; // 表格有三列
tableLayoutPanel1.Dock = DockStyle.Fill; // 佔滿整個視窗

// 設定行和列的大小和佈局方式
tableLayoutPanel1.RowStyles.Add(new RowStyle(SizeType.Percent, 50F));
tableLayoutPanel1.RowStyles.Add(new RowStyle(SizeType.Percent, 50F));
tableLayoutPanel1.ColumnStyles.Add(new ColumnStyle(SizeType.Percent, 33.33F));
tableLayoutPanel1.ColumnStyles.Add(new ColumnStyle(SizeType.Percent, 33.33F));
tableLayoutPanel1.ColumnStyles.Add(new ColumnStyle(SizeType.Percent, 33.33F));

// 建立按鈕控制項並將其添加到 TableLayoutPanel 中的指定行和列
Button button1 = new Button();
button1.Text = "按鈕1";
tableLayoutPanel1.Controls.Add(button1, 0, 0); // 放入第一行第一列

Button button2 = new Button();
button2.Text = "按鈕2";
tableLayoutPanel1.Controls.Add(button2, 1, 0); // 放入第一行第二列

Button button3 = new Button();
button3.Text = "按鈕3";
tableLayoutPanel1.Controls.Add(button3, 2, 0); // 放入第一行第三列

Button button4 = new Button();
button4.Text = "按鈕4";
tableLayoutPanel1.Controls.Add(button4, 0, 1); // 放入第二行第一列

Button button5 = new Button();
button5.Text = "按鈕5";
tableLayoutPanel1.Controls.Add(button5, 1, 1); // 放入第二行第二列

Button button6 = new Button();
button6.Text = "按鈕6";
tableLayoutPanel1.Controls.Add(button6, 2, 1); // 放入第二行第三列

// 將 TableLayoutPanel 加入到主視窗
this.Controls.Add(tableLayoutPanel1);
}
}
}

執行程式,你將看到動態生成的 TableLayoutPanel 和按鈕,並且它們以表格形式排列在視窗中。你可以根據需要設定不同的行數、列數和子控制項的位置,以達到你想要的佈局效果。

使用 TableLayoutPanel 可以讓你更方便地管理控制項的佈局,特別是當你需要在表格中排列大量控制項時,這個功能將非常實用。

67會員
118內容數
這裡將以輕鬆風格,深入探討程式設計的基礎和高級概念。從程式語言到演算法,我們將以易懂的方式解釋每個主題,讓你輕鬆掌握。無論你是初學者或有經驗者,都能在這裡找到適合你的內容。無論你的目標是成為專業開發者還是擴展知識,我們都會陪伴你一同成長!
留言0
查看全部
發表第一個留言支持創作者!
程式輕鬆玩 的其他內容
在開發 C# Windows Forms 應用程式時,我們經常需要將多個控制項以流式佈局排列,以便在不同大小的視窗或面板中適應佈局變化。這時,FlowLayoutPanel 是一個非常實用的容器控制項,它可以自動調整子控制項的位置,使其按照流式佈局排列。
在這篇教學中,我們將學習如何在C#程式中取得系統時間並進行格式化,以滿足不同需求的日期和時間顯示。
在專案中,使用NuGet套件管理員來安裝Microsoft.Office.Interop.Excel套件。這個套件將幫助我們與Excel進行互動。
在這篇教學中,我們將學習如何在C#程式碼中使用字串插值來加入變數。字串插值是一種方便且易讀的方式,讓我們可以將變數值插入到字串中,而不必使用傳統的串接方法。現在,讓我們開始吧! 在這個範例中,我們將創建一個簡單的應用程式,使用字串插值在螢幕上顯示一條個人訊息。這個訊息包含姓名、年齡和城市。 us
在現代科技的快速發展下,AI繪圖工具已成為許多創作者的得力助手。我有幸使用這些工具,並深感它們對創作過程的影響。
在現代科技快速發展的時代,學習程式設計已經成為一項重要的技能。無論年齡如何,程式設計都可以為人們帶來許多價值和益處。從幼童到老年人,學習程式設計不僅能夠培養邏輯思維,還能提升解決問題的能力和創造力。讓我們一起探討在各個年齡層中學習程式設計的重要性,並看看它如何在不同階段深化思維和進行系統化整理。
在開發 C# Windows Forms 應用程式時,我們經常需要將多個控制項以流式佈局排列,以便在不同大小的視窗或面板中適應佈局變化。這時,FlowLayoutPanel 是一個非常實用的容器控制項,它可以自動調整子控制項的位置,使其按照流式佈局排列。
在這篇教學中,我們將學習如何在C#程式中取得系統時間並進行格式化,以滿足不同需求的日期和時間顯示。
在專案中,使用NuGet套件管理員來安裝Microsoft.Office.Interop.Excel套件。這個套件將幫助我們與Excel進行互動。
在這篇教學中,我們將學習如何在C#程式碼中使用字串插值來加入變數。字串插值是一種方便且易讀的方式,讓我們可以將變數值插入到字串中,而不必使用傳統的串接方法。現在,讓我們開始吧! 在這個範例中,我們將創建一個簡單的應用程式,使用字串插值在螢幕上顯示一條個人訊息。這個訊息包含姓名、年齡和城市。 us
在現代科技的快速發展下,AI繪圖工具已成為許多創作者的得力助手。我有幸使用這些工具,並深感它們對創作過程的影響。
在現代科技快速發展的時代,學習程式設計已經成為一項重要的技能。無論年齡如何,程式設計都可以為人們帶來許多價值和益處。從幼童到老年人,學習程式設計不僅能夠培養邏輯思維,還能提升解決問題的能力和創造力。讓我們一起探討在各個年齡層中學習程式設計的重要性,並看看它如何在不同階段深化思維和進行系統化整理。
你可能也想看
Google News 追蹤
Thumbnail
這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
Thumbnail
11/20日NVDA即將公布最新一期的財報, 今天Sell Side的分析師, 開始調高目標價, 市場的股價也開始反應, 未來一週NVDA將重新回到美股市場的焦點, 今天我們要分析NVDA Sell Side怎麼看待這次NVDA的財報預測, 以及實際上Buy Side的倉位及操作, 從
Thumbnail
Hi 大家好,我是Ethan😊 相近大家都知道保濕是皮膚保養中最基本,也是最重要的一步。無論是在畫室裡長時間對著畫布,還是在旅途中面對各種氣候變化,保持皮膚的水分平衡對我來說至關重要。保濕化妝水不僅能迅速為皮膚補水,還能提升後續保養品的吸收效率。 曾經,我的保養程序簡單到只包括清潔和隨意上乳液
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
這個秋,Chill 嗨嗨!穿搭美美去賞楓,裝備款款去露營⋯⋯你的秋天怎麼過?秋日 To Do List 等你分享! 秋季全站徵文,我們準備了五個創作主題,參賽還有機會獲得「火烤兩用鍋」,一起來看看如何參加吧~
Thumbnail
11/20日NVDA即將公布最新一期的財報, 今天Sell Side的分析師, 開始調高目標價, 市場的股價也開始反應, 未來一週NVDA將重新回到美股市場的焦點, 今天我們要分析NVDA Sell Side怎麼看待這次NVDA的財報預測, 以及實際上Buy Side的倉位及操作, 從
Thumbnail
Hi 大家好,我是Ethan😊 相近大家都知道保濕是皮膚保養中最基本,也是最重要的一步。無論是在畫室裡長時間對著畫布,還是在旅途中面對各種氣候變化,保持皮膚的水分平衡對我來說至關重要。保濕化妝水不僅能迅速為皮膚補水,還能提升後續保養品的吸收效率。 曾經,我的保養程序簡單到只包括清潔和隨意上乳液
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
我們這群自學生大量使用數位產品,孩子們都有一台自己的平板、筆記型電腦或桌上型電腦。不只是大量使用數位產品來娛樂,上課時也使用協作平台,交作業也可以直接傳給我檔案。法國哲學家米謝・塞荷稱這些孩子為「拇指姑娘」,巧妙地形容了這個「用手指來跟世界互動」的世代。