wxPython 和 STC 边距 - 顶部和底部

Posted

技术标签:

【中文标题】wxPython 和 STC 边距 - 顶部和底部【英文标题】:wxPython and STC Margins - Top and Bottom 【发布时间】:2013-01-16 13:20:07 【问题描述】:

有没有办法在我的程序的顶部和底部为 3 和 4 实现填充?

或者有没有像添加 \n 之类的解决方法......

感觉好像行号和 Styled 文本离顶部和底部太近了。

【问题讨论】:

【参考方案1】:

使用嵌套在 sizer 中的相同颜色的面板作为一种肮脏的解决方法怎么样?

import wx
import wx.stc as stc

class MainWindow(wx.Frame):
    def __init__(self, *args, **kwargs):
        wx.Frame.__init__(self, *args, **kwargs)

        self.panel = wx.Panel(self)

        self.text = stc.StyledTextCtrl(self.panel)
        self.text.SetWindowStyle(self.text.GetWindowStyle() | wx.NO_BORDER)
        self.text.StyleSetSpec(stc.STC_STYLE_DEFAULT, "size:15,face:Courier New")
        self.text.SetWrapMode(stc.STC_WRAP_WORD)
        self.text.SetMarginLeft(50)
        self.text.StyleSetSpec(stc.STC_STYLE_LINENUMBER, "back:#FFFFFF")

        self.menu = wx.Menu()
        self.menu.Append(wx.ID_ABOUT, "&About", "Information about this program")
        self.menu_bar = wx.MenuBar()
        self.menu_bar.Append(self.menu, "&File")
        self.SetMenuBar(self.menu_bar)

        self.panel_top = wx.Panel(self.panel, size = (20, -1))
        self.panel_top.SetBackgroundColour(wx.WHITE)
        self.panel_bottom = wx.Panel(self.panel, size = (20, -1))
        self.panel_bottom.SetBackgroundColour(wx.WHITE)

        self.sizer = wx.BoxSizer(wx.VERTICAL)
        self.sizer.Add(self.panel_top, 0, wx.ALL | wx.EXPAND)
        self.sizer.Add(self.text, 1, wx.ALL | wx.EXPAND)
        self.sizer.Add(self.panel_bottom, 0, wx.ALL | wx.EXPAND)

        self.border = wx.BoxSizer()
        self.border.Add(self.sizer, 1, wx.ALL | wx.EXPAND, border=20)

        self.panel.SetSizerAndFit(self.border)

        self.text.Bind(stc.EVT_STC_CHANGE, self.OnChange)
        self.Show()

        self.text.SetText("Line!\n"*3)

    def OnChange(self, e):
        lines = self.text.GetLineCount()
        width = self.text.TextWidth(stc.STC_STYLE_LINENUMBER, str(lines)+" ")
        self.text.SetMarginWidth(0, width)


if __name__ == "__main__":
    app = wx.App(False)
    win = MainWindow(None)
    app.MainLoop()

对于你的代码,修改如下:

  self.panel_top = wx.Panel(self.panel, size = (20, -1))
  self.panel_top.SetBackgroundColour(wx.BLACK)
  self.panel_bottom = wx.Panel(self.panel, size = (20, -1))
  self.panel_bottom.SetBackgroundColour(wx.BLACK)

  #### Add the STC to a Sizer. ####
  sizer = wx.BoxSizer(wx.VERTICAL)
  sizer.Add(self.panel_top, 0, wx.EXPAND,border=20)
  sizer.Add(self.text, 1, wx.EXPAND,border=20)
  sizer.Add(self.panel_bottom, 0, wx.EXPAND,border=20)
  self.panel.SetSizer(sizer)

【讨论】:

这是我当前的代码。我将如何实施它? Sizer 把我搞糊涂了。 pastebin.com/K6hbSCUU 我已将 hack 添加到您的代码中。你应该真正学习如何使用 sizer,因为它们是 wxPython 的基础。 我正在慢慢学习,它有点混乱..我可能需要画一个图表,看看它是如何工作的..谢谢! 另外,是否可以实现自定义(更简单)滚动条而不是经典的 Windows 滚动条?我想要的是不同颜色的向上和向下滚动箭头,不同颜色的滚动 bg 和实际滚动块本身更纤细? 我不是风格化应用的粉丝,所以我不知道。你必须自己学习的东西。【参考方案2】:

不,我认为 Scintilla 没有控制顶部和底部边距大小的属性。

【讨论】:

以上是关于wxPython 和 STC 边距 - 顶部和底部的主要内容,如果未能解决你的问题,请参考以下文章

scss Sass用于创建顶部和底部边距类

php 在全局设置(Builder UI)中添加所有方向,即顶部,右侧,底部和左侧的边距

php 在全局设置(Builder UI)中添加所有方向,即顶部,右侧,底部和左侧的边距

到达页面底部后更改固定定位元素的边距顶部位置?

边距顶部/底部百分比在 Firefox 中不起作用 [重复]

将底部边距添加到 ListView 最后一个元素