do not load full iconset when we want only one icon
This commit is contained in:
parent
9685ff6258
commit
9659b03732
|
@ -727,11 +727,9 @@ class RosterWindow:
|
||||||
return
|
return
|
||||||
new_chat_menuitem = self.xml.get_widget('new_chat_menuitem')
|
new_chat_menuitem = self.xml.get_widget('new_chat_menuitem')
|
||||||
join_gc_menuitem = self.xml.get_widget('join_gc_menuitem')
|
join_gc_menuitem = self.xml.get_widget('join_gc_menuitem')
|
||||||
iconset = gajim.config.get('iconset')
|
muc_icon = self.load_icon('muc_active')
|
||||||
path = os.path.join(gajim.DATA_DIR, 'iconsets', iconset, '16x16')
|
if muc_icon:
|
||||||
state_images = self.load_iconset(path)
|
join_gc_menuitem.set_image(muc_icon)
|
||||||
if state_images.has_key('muc_active'):
|
|
||||||
join_gc_menuitem.set_image(state_images['muc_active'])
|
|
||||||
add_new_contact_menuitem = self.xml.get_widget('add_new_contact_menuitem')
|
add_new_contact_menuitem = self.xml.get_widget('add_new_contact_menuitem')
|
||||||
service_disco_menuitem = self.xml.get_widget('service_disco_menuitem')
|
service_disco_menuitem = self.xml.get_widget('service_disco_menuitem')
|
||||||
advanced_menuitem = self.xml.get_widget('advanced_menuitem')
|
advanced_menuitem = self.xml.get_widget('advanced_menuitem')
|
||||||
|
@ -1399,11 +1397,9 @@ class RosterWindow:
|
||||||
img.set_from_file(path_to_kbd_input_img)
|
img.set_from_file(path_to_kbd_input_img)
|
||||||
rename_menuitem.set_image(img)
|
rename_menuitem.set_image(img)
|
||||||
|
|
||||||
iconset = gajim.config.get('iconset')
|
muc_icon = self.load_icon('muc_active')
|
||||||
path = os.path.join(gajim.DATA_DIR, 'iconsets', iconset, '16x16')
|
if muc_icon:
|
||||||
state_images = self.load_iconset(path)
|
invite_menuitem.set_image(muc_icon)
|
||||||
if state_images.has_key('muc_active'):
|
|
||||||
invite_menuitem.set_image(state_images['muc_active'])
|
|
||||||
|
|
||||||
above_subscription_separator = xml.get_widget(
|
above_subscription_separator = xml.get_widget(
|
||||||
'above_subscription_separator')
|
'above_subscription_separator')
|
||||||
|
@ -3109,9 +3105,8 @@ _('If "%s" accepts this request you will know his or her status.') % jid)
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def load_iconset(self, path, pixbuf2 = None, transport = False):
|
def load_iconset(self, path, pixbuf2 = None, transport = False):
|
||||||
'''load an iconset from the given path, and add pixbuf2 on top left of
|
'''load full iconset from the given path, and add
|
||||||
each static images'''
|
pixbuf2 on top left of each static images'''
|
||||||
imgs = {}
|
|
||||||
path += '/'
|
path += '/'
|
||||||
if transport:
|
if transport:
|
||||||
list = ('online', 'chat', 'away', 'xa', 'dnd', 'offline',
|
list = ('online', 'chat', 'away', 'xa', 'dnd', 'offline',
|
||||||
|
@ -3123,15 +3118,28 @@ _('If "%s" accepts this request you will know his or her status.') % jid)
|
||||||
if pixbuf2:
|
if pixbuf2:
|
||||||
list = ('connecting', 'online', 'chat', 'away', 'xa', 'dnd',
|
list = ('connecting', 'online', 'chat', 'away', 'xa', 'dnd',
|
||||||
'offline', 'error', 'requested', 'message', 'not in roster')
|
'offline', 'error', 'requested', 'message', 'not in roster')
|
||||||
for state in list:
|
return self._load_icon_list(list, path, pixbuf2)
|
||||||
|
|
||||||
|
def load_icon(self, icon_name):
|
||||||
|
'''load an icon from the iconset in 16x16'''
|
||||||
|
iconset = gajim.config.get('iconset')
|
||||||
|
path = os.path.join(gajim.DATA_DIR, 'iconsets', iconset, '16x16'+ '/')
|
||||||
|
icon_list = self._load_icon_list([icon_name], path)
|
||||||
|
return icon_list[icon_name]
|
||||||
|
|
||||||
|
def _load_icon_list(self, icons_list, path, pixbuf2 = None):
|
||||||
|
'''load icons in icons_list from the given path,
|
||||||
|
and add pixbuf2 on top left of each static images'''
|
||||||
|
imgs = {}
|
||||||
|
for icon in icons_list:
|
||||||
# try to open a pixfile with the correct method
|
# try to open a pixfile with the correct method
|
||||||
state_file = state.replace(' ', '_')
|
icon_file = icon.replace(' ', '_')
|
||||||
files = []
|
files = []
|
||||||
files.append(path + state_file + '.gif')
|
files.append(path + icon_file + '.gif')
|
||||||
files.append(path + state_file + '.png')
|
files.append(path + icon_file + '.png')
|
||||||
image = gtk.Image()
|
image = gtk.Image()
|
||||||
image.show()
|
image.show()
|
||||||
imgs[state] = image
|
imgs[icon] = image
|
||||||
for file in files: # loop seeking for either gif or png
|
for file in files: # loop seeking for either gif or png
|
||||||
if os.path.exists(file):
|
if os.path.exists(file):
|
||||||
image.set_from_file(file)
|
image.set_from_file(file)
|
||||||
|
|
Loading…
Reference in New Issue