【kivy layout】FloatLayout類別的使用方法|Kivy基礎用法

更新 發佈閱讀 7 分鐘


本篇開始:

  • 我的開發環境是win11
  • python是3.10.7版本
  • kivy我設定在2.1.0版本
  • 編碼的工具是Visual Studio Code(VS Code)



【本篇說明】在 Kivy裡面有很多用於佈局(版面)的類別,像是常見的 FloatLayout、 BoxLayout、 GridLayout..等,今天要來介紹的是 FloatLayout,在字面上翻譯是"浮點的佈局",使用的效果像是可隨意指定子部件排列位置,所以在佈局版面上增加了許多彈性

1.首先在main.py寫下固定的程式碼

以下.py程式碼:(在vscode開啟python檔案,取名為main.py,以下簡稱.py)

from kivy.app import App
from kivy.uix.floatlayout import FloatLayout

class firstlayout(FloatLayout):
pass

class Mainapp(App):
def build(self):
return firstlayout()

if __name__ == "__main__":
Mainapp().run()

▲說明:

1.從 kivy.uix.floatlayout這個模組導入 FloatLayout類別

2.創建一個class 類別取名為 firstlayout(可自取無限定命名),然後在()填入 FloatLayout,目的是為了繼承 FloatLayout類別所有屬性及方法

3.這邊 kivy language(kv),我使用的是"相同命名方式",如果不太懂我說的,可先參考這篇:【kivy language】如何使用 kivy language(kv)


raw-image

▲說明:main.py程式碼


2.在vscode新增 kivy檔案,我取名 main.kv,並且放在同資料夾內

raw-image

▲說明:我的是放在以下路徑:桌面-> python-> Kivy-> test


3.在.kv加入 Widget部件內容

先使用4個 Button部件來展示(可參考這篇:【kivy Button】經常使用的Button(按鈕)語法。)

以下.kv程式碼:(在vscode編輯 main.kv,簡稱.kv)

<firstlayout>:
Button:
text:'green light'
size_hint: 0.2, 0.2
pos_hint:{'x':0, 'y':0}

Button:
text:'yellow light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.25, 'y':0.25}

Button:
text:'black light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.5, 'y':0.5}

Button:
text:'red light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.75, 'y':0.75}

▲說明:

1.先加入 <firstlayout>: (記得要使用角括號 < >),為了使用 main.py裡面的 class firstlayout的屬性,也就是 FloatLayout類別屬性

2.在 firstlayout裡面,添加 Button部件,這邊呼叫 Button需要先縮排,其後面的屬性也要縮排

3.大小使用 size_hint屬性,讓部件依照layout的視窗大小調整長與寬(長:視窗水平大小0.2,寬:視窗垂直大小0.2)

4.位置使用 pos_hint屬性,讓部件以視窗左下角的點作為參考點(也就是原點(0,0))來訂定位置


raw-image

▲說明:main.kv程式碼

raw-image

▲說明:執行python檔案


【說明】因為是使用 FloatLayout類別,所以可以自由指定部件位置,不受佈局版面的影響。

以下.kv程式碼:(在vscode編輯 main.kv,簡稱.kv)

<firstlayout>:
Button:
text:'green light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.75, 'y':0.75}

Button:
text:'yellow light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.5, 'y':0.5}

Button:
text:'black light'
size_hint: 0.2, 0.2
pos_hint:{'x':0.25, 'y':0.25}

Button:
text:'red light'
size_hint: 0.2, 0.2
pos_hint:{'x':0, 'y':0}
raw-image

▲說明:main.kv程式碼

raw-image

▲說明:執行python檔案


本篇小結

對於 FloatLayout類別的基本使用,是否都了解了呢? 之後分享 BoxLayout、 GridLayout就會感覺在版面佈局上的差異。


本篇結束:

在自學路上遇到困難是很正常的事,只要堅持到底,相信就會有所成果,期勉大家一同努力。



留言
avatar-img
留言分享你的想法!
avatar-img
艾肯比工程師
2會員
56內容數
主要分享應用程式開發過程、遭遇困難及解決技巧,提供給自學或獨立開發者做為參考,希望能對您們有所幫助。
艾肯比工程師的其他內容
2025/09/15
學習如何使用Kivy RoundedButton建立圓角按鈕,本文提供詳細步驟、程式碼範例和圖解說明,助你輕鬆掌握Kivy RoundedButton技巧。
Thumbnail
2025/09/15
學習如何使用Kivy RoundedButton建立圓角按鈕,本文提供詳細步驟、程式碼範例和圖解說明,助你輕鬆掌握Kivy RoundedButton技巧。
Thumbnail
2025/09/08
canvas.before,它的語法跟 canvas是相同的,分享兩種使用的時機(方式)。
Thumbnail
2025/09/08
canvas.before,它的語法跟 canvas是相同的,分享兩種使用的時機(方式)。
Thumbnail
2025/09/02
canvas,中文翻譯為"帆布",或可稱呼"帆布背景",是很常用的部件之一,本篇分享改變顏色、大小和位置等語法,並附上完整的程式碼範例與圖解說明。
Thumbnail
2025/09/02
canvas,中文翻譯為"帆布",或可稱呼"帆布背景",是很常用的部件之一,本篇分享改變顏色、大小和位置等語法,並附上完整的程式碼範例與圖解說明。
Thumbnail
看更多
你可能也想看
Thumbnail
浮動(float)是早期用來創建佈局的技術。元素可以向左或向右浮動,旁邊的元素會環繞浮動元素。浮動元素通常用於圖文混排或簡單的兩欄佈局。
Thumbnail
浮動(float)是早期用來創建佈局的技術。元素可以向左或向右浮動,旁邊的元素會環繞浮動元素。浮動元素通常用於圖文混排或簡單的兩欄佈局。
Thumbnail
不論是平面設計、介面設計,都能見排版這一詞。而排版的作用,即在明確的設計目標中,將所有元素做有組織的安排,精確地傳達訊息。
Thumbnail
不論是平面設計、介面設計,都能見排版這一詞。而排版的作用,即在明確的設計目標中,將所有元素做有組織的安排,精確地傳達訊息。
Thumbnail
打開 jupyter notebook 寫一段 python 程式,可以完成五花八門的工作,這是玩程式最簡便的方式,其中可以獲得很多快樂,在現今這種資訊發達的時代,幾乎沒有門檻,只要願意,人人可享用。 下一步,希望程式可以隨時待命聽我吩咐,不想每次都要開電腦,啟動開發環境,只為完成一個重複性高
Thumbnail
打開 jupyter notebook 寫一段 python 程式,可以完成五花八門的工作,這是玩程式最簡便的方式,其中可以獲得很多快樂,在現今這種資訊發達的時代,幾乎沒有門檻,只要願意,人人可享用。 下一步,希望程式可以隨時待命聽我吩咐,不想每次都要開電腦,啟動開發環境,只為完成一個重複性高
Thumbnail
Anytype主要分為四區塊:目錄欄(Widget組成)、主編輯畫面、導航選單、設定區。
Thumbnail
Anytype主要分為四區塊:目錄欄(Widget組成)、主編輯畫面、導航選單、設定區。
Thumbnail
當我們在撰寫一套系統的時候, 總是會提供一個介面讓使用者來觸發功能模組並回傳使用者所需的請求, 而傳統的安裝包模式總是太侷限, 需要個別主機獨立安裝, 相當繁瑣, 但隨著時代的演進與互聯網的崛起, 大部分的工作都可以藉由網頁端、裝置端來觸發, 而伺服端則是負責接收指令、運算與回傳結果, 雲端
Thumbnail
當我們在撰寫一套系統的時候, 總是會提供一個介面讓使用者來觸發功能模組並回傳使用者所需的請求, 而傳統的安裝包模式總是太侷限, 需要個別主機獨立安裝, 相當繁瑣, 但隨著時代的演進與互聯網的崛起, 大部分的工作都可以藉由網頁端、裝置端來觸發, 而伺服端則是負責接收指令、運算與回傳結果, 雲端
Thumbnail
本課程學習如何提取共同屬性,透過 Style 樣式包,套用至每個按鈕。來提升佈局的可讀性和好維護性。
Thumbnail
本課程學習如何提取共同屬性,透過 Style 樣式包,套用至每個按鈕。來提升佈局的可讀性和好維護性。
Thumbnail
本課程學習如何如何實作計算機介面,佈局文字元件及按鈕。學習使用 LinearLayout 垂直排列元件,調整背景色。透過 GridLayout 佈局計算機按鈕。
Thumbnail
本課程學習如何如何實作計算機介面,佈局文字元件及按鈕。學習使用 LinearLayout 垂直排列元件,調整背景色。透過 GridLayout 佈局計算機按鈕。
Thumbnail
本課程學習如何使用 LinearLayout 線性佈局中的 layout_weight 權重屬性。
Thumbnail
本課程學習如何使用 LinearLayout 線性佈局中的 layout_weight 權重屬性。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News