<i id='qCeCj'><tr id='qCeCj'><dt id='qCeCj'><q id='qCeCj'><span id='qCeCj'><b id='qCeCj'><form id='qCeCj'><ins id='qCeCj'></ins><ul id='qCeCj'></ul><sub id='qCeCj'></sub></form><legend id='qCeCj'></legend><bdo id='qCeCj'><pre id='qCeCj'><center id='qCeCj'></center></pre></bdo></b><th id='qCeCj'></th></span></q></dt></tr></i><div id='qCeCj'><tfoot id='qCeCj'></tfoot><dl id='qCeCj'><fieldset id='qCeCj'></fieldset></dl></div>

  1. <small id='qCeCj'></small><noframes id='qCeCj'>

    <legend id='qCeCj'><style id='qCeCj'><dir id='qCeCj'><q id='qCeCj'></q></dir></style></legend>

    <tfoot id='qCeCj'></tfoot>
        <bdo id='qCeCj'></bdo><ul id='qCeCj'></ul>

      Kivy - 基础应用程序有奇怪的对齐方式

      时间:2023-10-10
      <tfoot id='UV4hR'></tfoot>
      <i id='UV4hR'><tr id='UV4hR'><dt id='UV4hR'><q id='UV4hR'><span id='UV4hR'><b id='UV4hR'><form id='UV4hR'><ins id='UV4hR'></ins><ul id='UV4hR'></ul><sub id='UV4hR'></sub></form><legend id='UV4hR'></legend><bdo id='UV4hR'><pre id='UV4hR'><center id='UV4hR'></center></pre></bdo></b><th id='UV4hR'></th></span></q></dt></tr></i><div id='UV4hR'><tfoot id='UV4hR'></tfoot><dl id='UV4hR'><fieldset id='UV4hR'></fieldset></dl></div>

          <small id='UV4hR'></small><noframes id='UV4hR'>

            <tbody id='UV4hR'></tbody>

              <legend id='UV4hR'><style id='UV4hR'><dir id='UV4hR'><q id='UV4hR'></q></dir></style></legend>
                <bdo id='UV4hR'></bdo><ul id='UV4hR'></ul>
                本文介绍了Kivy - 基础应用程序有奇怪的对齐方式的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                问题描述

                我正在尝试构建一个基本的 Kivy 应用程序.添加基本​​元素并运行应用程序后,所有元素都挤在左下角.它在 android 和 Linux 上显示如下.

                I am trying to build a basic Kivy app. After adding the basic elements, and running the app, all of the elements are crammed into the bottom left corner. It shows up like this on android and Linux.

                Main.py:

                from kivy.app import App
                from kivy.uix.widget import Widget
                
                class SublimeLauncher(Widget):
                    pass
                
                class SublimeLauncherApp(App):
                    def build(self):
                        return SublimeLauncher()
                
                if __name__ == "__main__":
                    SublimeLauncherApp().run()
                

                sublimelauncher.kv:

                sublimelauncher.kv:

                #:kivy 1.2.0
                <SublimeLauncher>:
                    FloatLayout:
                        BoxLayout:
                            orientation: 'vertical'
                            spacing: 10
                            Label:
                                text: "Enter the path to the folder to open.
                Press OK if you would like to open without a directory"
                            TextInput:
                                id: folderpath
                            Button:
                                text: 'OK'
                

                我第一次尝试只使用 BoxLayout,但在某处读取的根小部件始终与应用程序一样大.如何声明应用程序的大小?还是布局?你会怎么做一些像对话框这样的事情?

                I first tried it with just the BoxLayout, but read somewhere the root widget is always as big as the app. How do I declare the size of the app? Or the layout? How would you go about doing something like a dialog box?

                也许我遗漏了一些非常基本的东西,但我似乎无法弄清楚.

                Maybe I am missing something very basic, but I can't seem to figure it out.

                这就是我所看到的......

                here is what I am seeing..

                推荐答案

                由于你的根小部件不是布局(你让 SublimeLauncher 继承 Widget),它不会't 设置其子级大小/位置.所以你的 FloatLayout 有默认值,因为你也没有手动覆盖它们.

                As your root widget is not a layout (you made SublimeLauncher inherit Widget), it doesn't set its children size/positions. So your FloatLayout have the defaults, since you don't override them manually either.

                pos: 0, 0
                size: 100, 100
                

                这些默认值当然会限制孩子,因为 FloatLayout 会根据他们的 size_hint 属性来限制他们的大小.

                And these defaults of course constraints the child, since FloatLayout by constraint their size based on their size_hint property.

                正如 Nykakin 指出的那样,您想给他们更多的空间.

                You want to give them more space, as Nykakin pointed out.

                此外,由于您的文本比标签大(您也没有设置 halign 和 text_size),因此它的纹理以标签的中心为中心,因此它的某些部分超出了屏幕.你想看看 kivy/examples/widgets/textalign.py

                Also, as your text is bigger than the Label (you didn't set halign and text_size either) its texture is centered on the center of the Label, and so some part of it is out of screen. You want to have a look at kivy/examples/widgets/textalign.py

                这篇关于Kivy - 基础应用程序有奇怪的对齐方式的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                上一篇:Python Spyder 初始化 Hello World Kivi 应用程序一次? 下一篇:Kivy ScrollView - 不滚动

                相关文章

                最新文章

                <tfoot id='FYwg1'></tfoot>
                  <legend id='FYwg1'><style id='FYwg1'><dir id='FYwg1'><q id='FYwg1'></q></dir></style></legend>

                    <small id='FYwg1'></small><noframes id='FYwg1'>

                    • <bdo id='FYwg1'></bdo><ul id='FYwg1'></ul>
                    <i id='FYwg1'><tr id='FYwg1'><dt id='FYwg1'><q id='FYwg1'><span id='FYwg1'><b id='FYwg1'><form id='FYwg1'><ins id='FYwg1'></ins><ul id='FYwg1'></ul><sub id='FYwg1'></sub></form><legend id='FYwg1'></legend><bdo id='FYwg1'><pre id='FYwg1'><center id='FYwg1'></center></pre></bdo></b><th id='FYwg1'></th></span></q></dt></tr></i><div id='FYwg1'><tfoot id='FYwg1'></tfoot><dl id='FYwg1'><fieldset id='FYwg1'></fieldset></dl></div>