⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 static_text.py

📁 用python写的ide开发环境,巨强大,不过需要wxpython的支持
💻 PY
字号:
# static_text.py: wxStaticText objects# $Id: static_text.py,v 1.16 2007/03/27 07:01:52 agriggio Exp $## Copyright (c) 2002-2007 Alberto Griggio <agriggio@users.sourceforge.net># License: MIT (see license.txt)# THIS PROGRAM COMES WITH NO WARRANTYimport wximport common, miscfrom edit_windows import ManagedBasefrom tree import Treefrom widget_properties import *try:    import wx.lib.stattext    StaticText = wx.lib.stattext.GenStaticTextexcept ImportError:    StaticText = wx.StaticTextclass EditStaticText(ManagedBase):    def __init__(self, name, parent, id, label, sizer, pos, property_window,                 show=True):        """\        Class to handle wxStaticText objects        """        import config        ManagedBase.__init__(self, name, 'wxStaticText', parent, id, sizer,                             pos, property_window, show=show)        self.label = label        self.style = 0        self.attribute = True        self.access_functions['label'] = (self.get_label, self.set_label)        self.access_functions['style'] = (self.get_style, self.set_style)        def set_attribute(v): self.attribute = int(v)        self.access_functions['attribute'] = (lambda : self.attribute,                                              set_attribute)        self.properties['label'] = TextProperty(self, 'label', None,                                                multiline=True, label=_('label'))        self.style_pos  = (wx.ALIGN_LEFT, wx.ALIGN_RIGHT, wx.ALIGN_CENTRE,                           wx.ST_NO_AUTORESIZE)        style_labels = ('#section#' + _('Style'), 'wxALIGN_LEFT', 'wxALIGN_RIGHT',                        'wxALIGN_CENTRE', 'wxST_NO_AUTORESIZE')        self.properties['style'] = CheckListProperty(self, 'style', None,                                                     style_labels)        self.properties['attribute'] = CheckBoxProperty(            self, 'attribute', None, _('Store as attribute'), write_always=True)        # 2003-09-04 added default_border        if config.preferences.default_border:            self.border = config.preferences.default_border_size            self.flag = wx.ALL    def create_widget(self):        self.widget = StaticText(self.parent.widget, self.id,                                 self.label.replace('\\n', '\n'))    def create_properties(self):        ManagedBase.create_properties(self)        panel = wx.Panel(self.notebook, -1)        szr = wx.BoxSizer(wx.VERTICAL)        self.properties['label'].display(panel)        self.properties['style'].display(panel)        self.properties['attribute'].display(panel)        szr.Add(self.properties['label'].panel, 0, wx.EXPAND)        szr.Add(self.properties['style'].panel, 0, wx.EXPAND)        szr.Add(self.properties['attribute'].panel, 0, wx.EXPAND)        panel.SetAutoLayout(True)        panel.SetSizer(szr)        szr.Fit(panel)        self.notebook.AddPage(panel, _('Widget'))    def get_label(self): return self.label    def set_label(self, value):        value = misc.wxstr(value)        if not misc.streq(value, self.label):            self.label = value            if self.widget:                self.widget.SetLabel(value.replace('\\n', '\n'))                if not self.properties['size'].is_active():                    self.sizer.set_item(self.pos,                                        size=self.widget.GetBestSize())    def get_style(self):        retval = [0] * len(self.style_pos)        try:            for i in range(len(self.style_pos)):                if self.style & self.style_pos[i]:                    retval[i] = 1        except AttributeError:            pass        return retval    def set_style(self, value):        value = self.properties['style'].prepare_value(value)        self.style = 0        for v in range(len(value)):            if value[v]:                self.style |= self.style_pos[v]        if self.widget: self.widget.SetWindowStyleFlag(self.style)# end of class EditStaticTextdef builder(parent, sizer, pos, number=[1]):    """\    factory function for EditStaticText objects.    """    label = 'label_%d' % number[0]    while common.app_tree.has_name(label):        number[0] += 1        label = 'label_%d' % number[0]    static_text = EditStaticText(label, parent, wx.NewId(),                                 misc._encode(label), sizer, pos,                                 common.property_panel)    node = Tree.Node(static_text)    static_text.node = node    static_text.show_widget(True)    common.app_tree.insert(node, sizer.node, pos-1)def xml_builder(attrs, parent, sizer, sizeritem, pos=None):    """\    factory to build EditStaticText objects from an xml file    """    from xml_parse import XmlParsingError    try: label = attrs['name']    except KeyError: raise XmlParsingError, _("'name' attribute missing")    if sizer is None or sizeritem is None:        raise XmlParsingError, _("sizer or sizeritem object cannot be None")    static_text = EditStaticText(label, parent, wx.NewId(),                                 "", sizer, pos,                                 common.property_panel)    sizer.set_item(static_text.pos, option=sizeritem.option,                   flag=sizeritem.flag, border=sizeritem.border)##                    size=static_text.GetBestSize())    node = Tree.Node(static_text)    static_text.node = node    if pos is None: common.app_tree.add(node, sizer.node)    else: common.app_tree.insert(node, sizer.node, pos-1)    return static_text    def initialize():    """\    initialization function for the module: returns a wxBitmapButton to be    added to the main palette.    """    common.widgets['EditStaticText'] = builder    common.widgets_from_xml['EditStaticText'] = xml_builder        return common.make_object_button('EditStaticText', 'icons/static_text.xpm')

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -