Handle changes to the EditPerson main image

svn: r518
This commit is contained in:
Don Allingham 2001-10-30 02:14:23 +00:00
parent 912db40dc4
commit 39f1b0893e
3 changed files with 72 additions and 35 deletions

View File

@ -74,6 +74,7 @@ class EditPerson:
self.lists_changed = 0
pid = "i%s" % person.getId()
self.load_obj = None
self.top = libglade.GladeXML(const.editPersonFile, "editPerson")
self.gallery_widget = self.top.get_widget("photolist")
self.gallery = ImageSelect.Gallery(person, self.path, pid, self.gallery_widget, self.db)
@ -239,15 +240,9 @@ class EditPerson:
self.nick.set_text(person.getNickName())
self.title.set_text(self.pname.getTitle())
self.update_birth_death()
self.load_person_image()
# load photos into the photo window
photo_list = person.getPhotoList()
if len(photo_list) != 0:
ph = photo_list[0]
object = ph.getReference()
if object.getMimeType()[0:5] == "image":
self.load_photo(object.getPath())
# set notes data
self.notes_field.set_point(0)
self.notes_field.insert_defaults(person.getNote())
@ -570,12 +565,16 @@ class EditPerson:
def load_photo(self,photo):
"""loads, scales, and displays the person's main photo"""
i = GdkImlib.Image(photo)
scale = float(const.picWidth)/float(max(i.rgb_height,i.rgb_width))
x = int(scale*(i.rgb_width))
y = int(scale*(i.rgb_height))
i = i.clone_scaled_image(x,y)
self.get_widget("personPix").load_imlib(i)
self.load_obj = photo
if photo == None:
self.get_widget("personPix").load_imlib(const.empty_image)
else:
i = GdkImlib.Image(photo)
scale = float(const.picWidth)/float(max(i.rgb_height,i.rgb_width))
x = int(scale*(i.rgb_width))
y = int(scale*(i.rgb_height))
i = i.clone_scaled_image(x,y)
self.get_widget("personPix").load_imlib(i)
def update_lists(self):
"""Updates the person's lists if anything has changed"""
@ -732,8 +731,23 @@ class EditPerson:
import NoteEdit
NoteEdit.NoteEditor(self.pname)
def load_person_image(self):
photo_list = self.person.getPhotoList()
if len(photo_list) != 0:
ph = photo_list[0]
object = ph.getReference()
if self.load_obj != object.getPath():
if object.getMimeType()[0:5] == "image":
self.load_photo(object.getPath())
else:
self.load_photo(None)
else:
self.load_photo(None)
def on_switch_page(self,obj,a,page):
if page == 6 and self.not_loaded:
if page == 0:
self.load_person_image()
elif page == 6 and self.not_loaded:
self.not_loaded = 0
self.gallery.load_images()

View File

@ -20,6 +20,7 @@
import os
import intl
import GdkImlib
_ = intl.gettext
@ -504,3 +505,12 @@ familyAttributes = initialize_family_attribute_list()
familyRelations = initialize_family_relation_list()
places = []
surnames = []
xpm_data = [
'/* XPM */',
'static char * foo_xpm[] = {',
'"1 1 1 1"',
'" c None"',
'" "};']
empty_image = GdkImlib.create_image_from_xpm(xpm_data)

View File

@ -232,7 +232,7 @@ def on_writing_extensions_activate(obj):
#
#-------------------------------------------------------------------------
def on_remove_child_clicked(obj):
if not active_family or not active_child:
if not active_family or not active_child or not active_person:
return
active_family.removeChild(active_child)
@ -265,16 +265,20 @@ def delete_family_from(person):
def on_add_sp_clicked(obj):
"""Add a new spouse to the current person"""
import AddSpouse
AddSpouse.AddSpouse(database,active_person,load_family,redisplay_person_list)
if active_person:
AddSpouse.AddSpouse(database,active_person,load_family,redisplay_person_list)
def on_edit_sp_clicked(obj):
"""Edit the marriage information for the current family"""
Marriage.Marriage(active_family,database)
if active_person:
Marriage.Marriage(active_family,database)
def on_delete_sp_clicked(obj):
"""Delete the currently selected spouse from the family"""
if active_person == active_family.getFather():
if active_person == None:
return
elif active_person == active_family.getFather():
person = active_family.getMother()
active_family.setMother(None)
else:
@ -340,12 +344,14 @@ def on_fv_prev_clicked(obj):
def on_add_child_clicked(obj):
"""Select an existing child to add to the active family"""
import SelectChild
SelectChild.SelectChild(database,active_family,active_person,load_family)
if active_person:
SelectChild.SelectChild(database,active_family,active_person,load_family)
def on_add_new_child_clicked(obj):
"""Create a new child to add to the existing family"""
import SelectChild
SelectChild.NewChild(database,active_family,active_person,update_after_newchild)
if active_person:
SelectChild.NewChild(database,active_family,active_person,update_after_newchild)
#-------------------------------------------------------------------------
@ -355,7 +361,8 @@ def on_add_new_child_clicked(obj):
#-------------------------------------------------------------------------
def on_choose_parents_clicked(obj):
import ChooseParents
ChooseParents.ChooseParents(database,active_person,active_parents,load_family)
if active_person:
ChooseParents.ChooseParents(database,active_person,active_parents,load_family)
#-------------------------------------------------------------------------
#
@ -371,7 +378,7 @@ def new_database_response(val):
"""Clear out the database if permission was granted"""
global active_person, active_father
global active_family, active_mother
global active_child
global active_child, active_spouse
global id2col,alt2col,person_list
if val == 1:
@ -390,6 +397,7 @@ def new_database_response(val):
active_family = None
active_mother = None
active_child = None
active_spouse = None
id2col = {}
alt2col = {}
@ -1291,32 +1299,26 @@ def display_comment_box(filename):
def on_person_list1_activate(obj):
"""Switches to the person list view"""
notebook.set_page(0)
merge_button.show()
def on_family1_activate(obj):
"""Switches to the family view"""
notebook.set_page(1)
merge_button.hide()
def on_pedegree1_activate(obj):
"""Switches to the pedigree view"""
notebook.set_page(2)
merge_button.hide()
def on_sources_activate(obj):
"""Switches to the sources view"""
notebook.set_page(3)
merge_button.hide()
def on_places_activate(obj):
"""Switches to the places view"""
notebook.set_page(4)
merge_button.show()
def on_media_activate(obj):
"""Switches to the media view"""
notebook.set_page(5)
merge_button.hide()
#-------------------------------------------------------------------------
#
@ -1324,19 +1326,23 @@ def on_media_activate(obj):
#
#-------------------------------------------------------------------------
def on_notebook1_switch_page(obj,junk,page):
if not active_person:
return
if page == 0:
goto_active_person()
merge_button.show()
elif page == 1:
merge_button.hide()
load_family()
elif page == 2:
merge_button.hide()
load_canvas()
elif page == 3:
merge_button.hide()
load_sources()
elif page == 4:
merge_button.show()
load_places()
elif page == 5:
merge_button.hide()
load_media()
#-------------------------------------------------------------------------
@ -1435,6 +1441,13 @@ def load_media():
if index > 0:
media_list.select_row(current_row,0)
media_list.moveto(current_row)
else:
mid.set_text("")
mtype.set_text("")
mdesc.set_text("")
mpath.set_text("")
mdetails.set_text("")
preview.load_imlib(const.empty_image)
media_list.thaw()
@ -2236,6 +2249,10 @@ canvas_items = []
def load_canvas():
global canvas_items
root = canvas.root()
for i in canvas_items:
i.destroy()
if active_person == None:
return
@ -2244,10 +2261,6 @@ def load_canvas():
cx1,cy1,cx2,cy2 = canvas.get_allocation()
canvas.set_scroll_region(cx1,cy1,cx2,cy2)
root = canvas.root()
for i in canvas_items:
i.destroy()
style = canvas['style']
font = style.font