学习kivy布局:八种排版方式

摘要

FloatLayout是一种自由、波动的布局,可以让子控件根据位置和大小的提示在对话框中随意摆放。使用它可以轻松适应对话框的大小和形状。

正文

kivy八种合理布局:FloatLayout、BoxLayout、AnchorLayout、GridLayout、PageLayout、RelativeLayout、ScatterLayout、StackLayout。

FloatLayout:波动合理布局,它容许将子构件根据部位主要参数(pos_hint)和规格主要参数(size_hint)置放在对话框的随意部位.大家用此合理布局可按对话框尺寸高宽比来置放小构件,而且当在不一样屏幕分辨率的移动设备中,对话框的尺寸更改时,置放在对话框内的小构件也会相对应的调节尺寸与部位,而不容易造成因对话框的尺寸转变而使合理布局乱成一团。

from kivy.app import App   #导进kivy的app类,它是全部kivy运用的基类
from kivy.uix.button import Button #引进控制
from kivy.uix.floatlayout import FloatLayout  #引进合理布局
from kivy.graphics import Rectangle,Color
class FloatLayoutApp(App):  #承继app类
    def build(self):  #完成app类的build()方式 
        def update_rect(layout,*args):
            #设定情况规格,可忽视
            layout.rect.pos=layout.pos
            layout.rect.size=layout.size
        float_layout=FloatLayout()
        #设定背景色(可忽视)
        with float_layout.canvas:
            Color(1,1,1,1)
            float_layout.rect=Rectangle(pos=float_layout.pos,size=float_layout.size)
            float_layout.bind(pos=update_rect,size=update_rect)
        #在合理布局内的【300,200】处加上一个规格为0.3,0.2的按键
        button=Button(text='FloatLayout',size_hint=(.3,.2),pos=(300,200))
        #这儿的pos主要参数不容易因对话框更改而更改部位,这个是固定不动部位,要随对话框转变而变化规律的得用pos_hint
        #将按键加上到合理布局内
        float_layout.add_widget(button)
        #回到合理布局
        return float_layout
if ._name._=='._main._':  #程序流程通道
        FloatLayoutApp().run() #运行应用软件

BoxLayout:小盒子合理布局,是能够将子构件水准或竖直开展排序的合理布局,相近Android中的线形合理布局,如果不设定一切尺寸,子构件可能以10px的间隔均分父对话框的尺寸。

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.boxlayout import BoxLayout
from kivy.graphics import Rectangle,Color
class BoxLayoutWidget(BoxLayout):
    def ._init._(self,**kwargs):
        super().._init._(**kwargs)
        with self.canvas:
            Color(1,1,1,1)
            self.rect=Rectangle(pos=self.pos,size=self.size)
            self.bind(pos=self.update_rect,size=self.update_rect)
        self.add_widget(Button(text='hello'))
        self.add_widget(Button(text='BoxLayout'))
    def update_rect(self,*args):
        #设定情况规格,可忽视
        self.rect.pos=self.pos
        self.rect.size=self.size
class BoxApp(App):
    def build(self):
        return BoxLayoutWidget()
if ._name._ =='._main._':
    BoxApp().run()

AnchorLayout:ps钢笔合理布局,此合理布局能够将子构件置放在左上角、上中、右上、左中、正中间,右中、左下,下中,右下方共9个部位处。

from kivy.app import App
from kivy.uix.anchorlayout import AnchorLayout
from kivy.uix.button import Button
from kivy.graphics import Rectangle,Color
class AnchorLayoutWidget(AnchorLayout):
    def ._init._(self,**kwargs):
        super().._init._(**kwargs)
        with self.canvas:
            # Color(1,1,1,1)
            self.rect=Rectangle(pos=self.pos,size=self.size)
            self.bind(pos=self.update_rect,size=self.update_rect)
        #嵌入第一个合理布局
        anchor_first=AnchorLayout(anchor_x='left',anchor_y='top')
        #加上按键
        anchor_first.add_widget(Button(text='hello',size_hint=[.3,.2],background_color=[0,1,1,1]))
        anchor_first.add_widget(Button(text='hello1',size_hint=[.3,.2],background_color=[1,0,1,1]))
        #嵌入第二个合理布局
        anchor_second=AnchorLayout(anchor_x='right',anchor_y='bottom')
        #加上按键
        anchor_second.add_widget(Button(text='anchor',size_hint=[.3,.2]))
        #加上到父合理布局中
        self.add_widget(anchor_first)
        self.add_widget(anchor_second)
    def update_rect(self,*args):
        #设定情况规格
        self.rect.pos=self.pos
        self.rect.size=self.size
class AnchorApp(App):
    def build(self):
        return AnchorLayoutWidget()
if ._name._ =='._main._':
    AnchorApp().run()

GridLayout:网格图合理布局,应用此合理布局能够将子构件排成几行两列的引流矩阵合理布局。当设置了行数cols或是个数rows后,子构件尺寸规格与子构件数量是多少产生变化时,此合理布局会依据该值开展拓展,但不容易超出界线值。

from kivy.app import App
from kivy.uix.gridlayout import GridLayout
from kivy.uix.button import Button
from kivy.graphics import Rectangle,Color
class GridLayoutWidget(GridLayout):
    def ._init._(self,**kwargs):
        super(GridLayoutWidget, self).._init._(**kwargs)
        with self.canvas:
            Color(1,1,1,1)
            self.rect=Rectangle(pos=self.pos,size=self.size)
            self.bind(pos=self.update_rect,size=self.update_rect)
        self.padding = 20
        self.spacing = 20
        self.cols=3
        for i in range(6):
            btn=Button(text=str(i),background_color=[0,1,1,1],size_hint=[.3,.2])
            self.add_widget(btn)
    def update_rect(self,*args):
        self.rect.pos=self.pos
        self.rect.size=self.size
class GridApp(App):
    def build(self):
        return GridLayoutWidget()
if ._name._ == '._main._':
    GridApp().run()

PageLayout:与其他合理布局不司,它是个多张动态性合理布局。此合理布局能够在对话框内建立好几个网页页面的合理布局,这种网页页面能够旋转,每一个页脸面构件均可做为独立的对话框网页页面开展开发设计。

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.pagelayout import PageLayout
class PageLayoutWidget(PageLayout):
    def ._init._(self,**kwargs):
        super(PageLayoutWidget, self).._init._(**kwargs)       bt0=Button(text='bt0',background_color=[.3,.9,.3,1])
        bt1=Button(text='bt1',background_color=[.9,.3,.3,1])
        self.add_widget(bt0)
        self.add_widget(bt1)
class PageApp(App):
    def build(self):
        return PageLayoutWidget()
if ._name._ =='._main._':
    PageApp().run()

RelativeLayout:相对性合理布局,与FloatLayout基本一致,但它精准定位属性x、center_x、right、y、center_y、top是相对性于上级领导父合理布局尺寸来讲的,并不是对于对话框的尺寸。

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.relativelayout import RelativeLayout
from kivy.uix.boxlayout import BoxLayout
from kivy.graphics import Rectangle,Color
class MyButton(Button):  #自定控制类
    #自定一个按键,明确提出公共性特性
    def ._init._(self,**kwargs):
        super(MyButton, self).._init._(**kwargs)
        self.font_size=20
        self.size_hint=[0.2,.2]
class RelativeLayoutWidget(RelativeLayout):
    pass
class BoxLayoutWidget(BoxLayout):
    def ._init._(self,**kwargs):
        super(BoxLayoutWidget, self).._init._(**kwargs)
        #设定背景色
        with self.canvas:
            Color(1,1,1,1)
            self.rect=Rectangle(pos=self.pos,size=self.size)
            self.bind(pos=self.update_rect,size=self.update_rect)
        #建立一个RelativeLayout合理布局
        relative_layout=RelativeLayoutWidget()
        #应用自定按键
        bt0=MyButton(text='按键0',pos_hint={'right':1,'top':1},background_color=(.1,.5,.6,1))
        bt1=MyButton(text='按键1',pos_hint={'x':0,'top':1},background_color=(1,0,0,1))
        bt_relative=MyButton(text='按键relative',pos_hint={'center_x':0.5,'center_y':0.5},background_color=(.4,.5,.6,1))
        bt2=MyButton(text='按键2',pos_hint={'x':0,'y':0},background_color=(0,0,1,1))
        bt3=MyButton(text='按键3',pos_hint={'right':1,'y':0},background_color=(.8,.9,.2,1))
        #向RelativeLayout合理布局汽车内循环加上原素
        for i in [bt0,bt1,bt_relative,bt2,bt3]:
            relative_layout.add_widget(i)
        #放一个空的BoxLayout团块
        self.add_widget(BoxLayout())
        #将RelativeLayout加上到合理布局中
        self.add_widget(relative_layout)
    def update_rect(self,*args):
        #设定情况规格,可忽视
        self.rect.pos=self.pos
        self.rect.size=self.size
class RelativeApp(App):
    def build(self):
        return BoxLayoutWidget()
if ._name._ =='._main._':
    RelativeApp().run()

ScatterLayout:分散化合理布局,与RelativeLayout相近。当合理布局变更部位时,合理布局内的小构件也会跟随父合理布局一起变化,而且子构件的部位及尺寸会相对性于父合理布局全自动调节,而且此合理布局还能够开展移动、转动、放缩合理布局。

from kivy.app import App
from kivy.uix.image import AsyncImage
from kivy.uix.boxlayout import BoxLayout
from kivy.uix.scatterlayout import ScatterLayout
from kivy.graphics import Rectangle,Color
class ScatterLayoutWidget(ScatterLayout):
    pass
class BoxLayoutWidget(BoxLayout):
        def ._init._(self,**kwargs):
            super(BoxLayoutWidget, self).._init._(**kwargs)
            with self.canvas:
                Color(1,1,1,1)
                self.rect=Rectangle(pos=self.pos,size=self.size)
                self.bind(pos=self.update_rect,size=self.update_rect)
                #建立一个ScatterLayout合理布局
            scatter_layout=ScatterLayoutWidget()
            #多线程上传图片
            image=AsyncImage(source='https://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png') #http://sck.rjkflm.com/images/logo1.png
            #将照片加上到ScatterLayout合理布局中
            scatter_layout.add_widget(image)
            #将ScatterLayout合理布局嵌入在BoxLayout合理布局中
            self.add_widget(scatter_layout)
        def update_rect(self,*args):
            #设定情况规格,可忽视
            self.rect.pos=self.pos
            self.rect.size=self.size
class ScatterApp(App):
    def build(self):
        return BoxLayoutWidget()
if ._name._ =='._main._':
    ScatterApp().run()

StackLayout:局部变量合理布局,在这里合理布局中,能够开展竖直或水准的排序子构件,而且每个小构件能够无须同样,排序的方位由orientation特性开展特定。

from kivy.app import App
from kivy.uix.button import Button
from kivy.uix.stacklayout import StackLayout
from kivy.graphics import Rectangle,Color
class StackLayoutWidget(StackLayout):
    def ._init._(self,**kwargs):
        super(StackLayoutWidget, self).._init._(**kwargs)
        with self.canvas:
            Color(1,1,1,1)
            self.rect=Rectangle(pos=self.pos,size=self.size)
            self.bind(pos=self.update_rect,size=self.update_rect)
        #解析xml加上按键
        for i in range(25):
            btn=Button(text=str(i),width=40 i*5,size_hint=(None,0.15))
            self.add_widget(btn)
    def update_rect(self,*args):
        self.rect.pos=self.pos
        self.rect.size=self.size
class StackApp(App):
    def build(self):
        return StackLayoutWidget()
if ._name._ =="._main._":
    StackApp().run()

之上每一种合理布局都是有编码实例,多对编码开展调节改动,可能更有体会心得。

关注不迷路

扫码下方二维码,关注宇凡盒子公众号,免费获取最新技术内幕!

温馨提示:如果您访问和下载本站资源,表示您已同意只将下载文件用于研究、学习而非其他用途。
文章版权声明 1、本网站名称:宇凡盒子
2、本站文章未经许可,禁止转载!
3、如果文章内容介绍中无特别注明,本网站压缩包解压需要密码统一是:yufanbox.com
4、本站仅供资源信息交流学习,不保证资源的可用及完整性,不提供安装使用及技术服务。点此了解
5、如果您发现本站分享的资源侵犯了您的权益,请及时通知我们,我们会在接到通知后及时处理!提交入口
0

评论0

请先

站点公告

🚀 【宇凡盒子】全网资源库转储中心

👉 注册即送VIP权限👈

👻 全站资源免费下载✅,欢迎注册!

记得 【收藏】+【关注】 谢谢!~~~

立即注册
没有账号?注册  忘记密码?

社交账号快速登录