我正在尝试将StackLayout中的小部件水平居中,但我既是新手又不擅长数学,无法理解正确的公式。每个小部件在StackLayout中宽度为128像素,每个小部件之间的间距为20像素。这是我的代码:
padding: ((root.width - ((int((root.width - ((int(root.width / 128) - 1) * 20)) / 128) - 1) * 20)) % 128) / 2, 0, 0, 0
spacing: 20
它在某种程度上很好用。例如,当窗口宽度为任何小于或等于255个像素时,每行完美地居中一个128像素的小部件。但是,一旦窗口调整到256像素宽,每个小部件就会被硬性定位到左侧,并带有0的填充。当我将窗口从256逐渐增大到275时,填充也会相应增加。在窗口宽度达到276像素时,小部件会弹回到硬性左侧位置,填充为0,在每行放置第二个小部件(这是正确的操作方式)。
通过插入公式值,我可以看出这是为什么,但我不确定如何解决它。任何帮助都将不胜感激。谢谢。