Geography : New marker layer with variable marker size.
svn: r19834
This commit is contained in:
@ -9,6 +9,7 @@ pkgpython_PYTHON = \
|
|||||||
geography.py\
|
geography.py\
|
||||||
__init__.py\
|
__init__.py\
|
||||||
lifewaylayer.py\
|
lifewaylayer.py\
|
||||||
|
markerlayer.py\
|
||||||
osmGps.py\
|
osmGps.py\
|
||||||
placeselection.py\
|
placeselection.py\
|
||||||
selectionlayer.py
|
selectionlayer.py
|
||||||
|
@ -144,13 +144,13 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
self.places_found = []
|
self.places_found = []
|
||||||
self.select_fct = None
|
self.select_fct = None
|
||||||
self.geo_mainmap = gtk.gdk.pixbuf_new_from_file_at_size(
|
self.geo_mainmap = gtk.gdk.pixbuf_new_from_file_at_size(
|
||||||
os.path.join(const.ROOT_DIR, "images", "22x22",
|
os.path.join(const.ROOT_DIR, "images", "48x48",
|
||||||
('gramps-geo-mainmap' + '.png' )),
|
('gramps-geo-mainmap' + '.png' )),
|
||||||
22, 22)
|
48, 48)
|
||||||
self.geo_altmap = gtk.gdk.pixbuf_new_from_file_at_size(
|
self.geo_altmap = gtk.gdk.pixbuf_new_from_file_at_size(
|
||||||
os.path.join(const.ROOT_DIR, "images", "22x22",
|
os.path.join(const.ROOT_DIR, "images", "48x48",
|
||||||
('gramps-geo-altmap' + '.png' )),
|
('gramps-geo-altmap' + '.png' )),
|
||||||
22, 22)
|
48, 48)
|
||||||
if ( config.get('geography.map_service') in
|
if ( config.get('geography.map_service') in
|
||||||
( constants.OPENSTREETMAP, constants.OPENSTREETMAP_RENDERER )):
|
( constants.OPENSTREETMAP, constants.OPENSTREETMAP_RENDERER )):
|
||||||
default_image = self.geo_mainmap
|
default_image = self.geo_mainmap
|
||||||
@ -161,9 +161,9 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
gen.lib.EventType.DEATH,
|
gen.lib.EventType.DEATH,
|
||||||
gen.lib.EventType.MARRIAGE ):
|
gen.lib.EventType.MARRIAGE ):
|
||||||
self.geo_othermap[ident] = gtk.gdk.pixbuf_new_from_file_at_size(
|
self.geo_othermap[ident] = gtk.gdk.pixbuf_new_from_file_at_size(
|
||||||
os.path.join(const.ROOT_DIR, "images", "22x22",
|
os.path.join(const.ROOT_DIR, "images", "48x48",
|
||||||
(constants.ICONS.get(int(ident), default_image) + '.png' )),
|
(constants.ICONS.get(int(ident), default_image) + '.png' )),
|
||||||
22, 22)
|
48, 48)
|
||||||
|
|
||||||
def change_page(self):
|
def change_page(self):
|
||||||
"""
|
"""
|
||||||
@ -385,7 +385,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
"""
|
"""
|
||||||
self.osm.remove_layer(layer)
|
self.osm.remove_layer(layer)
|
||||||
|
|
||||||
def add_marker(self, menu, event, lat, lon, event_type, differtype):
|
def add_marker(self, menu, event, lat, lon, event_type, differtype, count):
|
||||||
"""
|
"""
|
||||||
Add a new marker
|
Add a new marker
|
||||||
"""
|
"""
|
||||||
@ -400,8 +400,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
value = self.geo_othermap.get(int(event_type), default_image)
|
value = self.geo_othermap.get(int(event_type), default_image)
|
||||||
if differtype: # in case multiple evts
|
if differtype: # in case multiple evts
|
||||||
value = default_image # we use default icon.
|
value = default_image # we use default icon.
|
||||||
marker = self.osm.image_add_with_alignment(float(lat),
|
self.marker_layer.add_marker((float(lat), float(lon)), value, count)
|
||||||
float(lon), value, 0.2, 1.0)
|
|
||||||
|
|
||||||
def remove_all_gps(self):
|
def remove_all_gps(self):
|
||||||
"""
|
"""
|
||||||
@ -489,6 +488,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
lat = 0.0
|
lat = 0.0
|
||||||
lon = 0.0
|
lon = 0.0
|
||||||
icon = None
|
icon = None
|
||||||
|
count = 0
|
||||||
self.uistate.set_busy_cursor(True)
|
self.uistate.set_busy_cursor(True)
|
||||||
_LOG.debug("%s" % time.strftime("start create_marker : "
|
_LOG.debug("%s" % time.strftime("start create_marker : "
|
||||||
"%a %d %b %Y %H:%M:%S", time.gmtime()))
|
"%a %d %b %Y %H:%M:%S", time.gmtime()))
|
||||||
@ -500,19 +500,22 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
lon = mark[4]
|
lon = mark[4]
|
||||||
icon = mark[7]
|
icon = mark[7]
|
||||||
differtype = False
|
differtype = False
|
||||||
|
count = 1
|
||||||
continue
|
continue
|
||||||
if last != current:
|
if last != current:
|
||||||
self.add_marker(None, None, lat, lon, icon, differtype)
|
self.add_marker(None, None, lat, lon, icon, differtype, count)
|
||||||
differtype = False
|
differtype = False
|
||||||
|
count = 1
|
||||||
last = current
|
last = current
|
||||||
lat = mark[3]
|
lat = mark[3]
|
||||||
lon = mark[4]
|
lon = mark[4]
|
||||||
icon = mark[7]
|
icon = mark[7]
|
||||||
else: # This marker already exists. add info.
|
else: # This marker already exists. add info.
|
||||||
|
count += 1
|
||||||
if icon != mark[7]:
|
if icon != mark[7]:
|
||||||
differtype = True
|
differtype = True
|
||||||
if ( lat != 0.0 and lon != 0.0 ):
|
if ( lat != 0.0 and lon != 0.0 ):
|
||||||
self.add_marker(None, None, lat, lon, icon, differtype)
|
self.add_marker(None, None, lat, lon, icon, differtype, count)
|
||||||
self._set_center_and_zoom()
|
self._set_center_and_zoom()
|
||||||
_LOG.debug("%s" % time.strftime(" stop create_marker : "
|
_LOG.debug("%s" % time.strftime(" stop create_marker : "
|
||||||
"%a %d %b %Y %H:%M:%S", time.gmtime()))
|
"%a %d %b %Y %H:%M:%S", time.gmtime()))
|
||||||
@ -810,7 +813,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
new_place.set_main_location(loc)
|
new_place.set_main_location(loc)
|
||||||
try:
|
try:
|
||||||
EditPlace(self.dbstate, self.uistate, [], new_place)
|
EditPlace(self.dbstate, self.uistate, [], new_place)
|
||||||
self.add_marker(None, None, plat, plon, None, True)
|
self.add_marker(None, None, plat, plon, None, True, 0)
|
||||||
except WindowActiveError:
|
except WindowActiveError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@ -851,7 +854,7 @@ class GeoGraphyView(OsmGps, NavigationView):
|
|||||||
place.set_main_location(loc)
|
place.set_main_location(loc)
|
||||||
try:
|
try:
|
||||||
EditPlace(self.dbstate, self.uistate, [], place)
|
EditPlace(self.dbstate, self.uistate, [], place)
|
||||||
self.add_marker(None, None, plat, plon, None, True)
|
self.add_marker(None, None, plat, plon, None, True, 0)
|
||||||
except WindowActiveError:
|
except WindowActiveError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
162
src/plugins/lib/maps/markerlayer.py
Normal file
162
src/plugins/lib/maps/markerlayer.py
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
# -*- python -*-
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# Gramps - a GTK+/GNOME based genealogy program
|
||||||
|
#
|
||||||
|
# Copyright (C) 2011-2012 Serge Noiraud
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
#
|
||||||
|
|
||||||
|
# $Id: grampsmaps.py 18399 2011-11-02 17:15:20Z noirauds $
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Python modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import os
|
||||||
|
import gobject
|
||||||
|
from math import *
|
||||||
|
|
||||||
|
#------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Set up logging
|
||||||
|
#
|
||||||
|
#------------------------------------------------------------------------
|
||||||
|
import logging
|
||||||
|
_LOG = logging.getLogger("maps.marker")
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# GTK/Gnome modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import gtk
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# Gramps Modules
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
import const
|
||||||
|
import cairo
|
||||||
|
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
#
|
||||||
|
# osmGpsMap
|
||||||
|
#
|
||||||
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
|
try:
|
||||||
|
import osmgpsmap
|
||||||
|
except:
|
||||||
|
raise
|
||||||
|
|
||||||
|
class MarkerLayer(gobject.GObject, osmgpsmap.GpsMapLayer):
|
||||||
|
"""
|
||||||
|
This is the layer used to display the markers.
|
||||||
|
"""
|
||||||
|
def __init__(self):
|
||||||
|
"""
|
||||||
|
Initialize the layer
|
||||||
|
"""
|
||||||
|
gobject.GObject.__init__(self)
|
||||||
|
self.markers = []
|
||||||
|
self.max_references = 0
|
||||||
|
self.max_places = 0
|
||||||
|
self.nb_ref_by_places = 0
|
||||||
|
self.max_value = 0
|
||||||
|
self.min_value = 9999
|
||||||
|
|
||||||
|
def clear_markers(self):
|
||||||
|
"""
|
||||||
|
reset the layer attributes.
|
||||||
|
"""
|
||||||
|
self.markers = []
|
||||||
|
self.max_references = 0
|
||||||
|
self.max_places = 0
|
||||||
|
self.nb_ref_by_places = 0
|
||||||
|
self.max_value = 0
|
||||||
|
self.min_value = 9999
|
||||||
|
|
||||||
|
def add_marker(self, points, image, count):
|
||||||
|
"""
|
||||||
|
Add a track or life marker.
|
||||||
|
"""
|
||||||
|
self.markers.append((points, image, count))
|
||||||
|
self.max_references += count
|
||||||
|
self.max_places += 1
|
||||||
|
if count > self.max_value:
|
||||||
|
self.max_value = count
|
||||||
|
if count < self.min_value:
|
||||||
|
self.min_value = count
|
||||||
|
self.nb_ref_by_places = self.max_references / self.max_places
|
||||||
|
|
||||||
|
def do_draw(self, gpsmap, drawable):
|
||||||
|
"""
|
||||||
|
Draw all tracks or life markers.
|
||||||
|
"""
|
||||||
|
ctx = drawable.cairo_create()
|
||||||
|
max_interval = self.max_value - self.nb_ref_by_places
|
||||||
|
min_interval = self.nb_ref_by_places - self.min_value
|
||||||
|
if min_interval == 0:
|
||||||
|
min_interval = 0.01
|
||||||
|
for marker in self.markers:
|
||||||
|
ctx.save()
|
||||||
|
# the icon size in 48, so the standard icon size is 0.6 * 48 = 28.8
|
||||||
|
size = 0.6
|
||||||
|
if float(marker[2]) > self.nb_ref_by_places:
|
||||||
|
# at maximum, we'll have an icon size = (0.6 + 0.3) * 48 = 43.2
|
||||||
|
size += ( 0.3 * ( ( float(marker[2]) - self.nb_ref_by_places )/ max_interval) )
|
||||||
|
else:
|
||||||
|
# at minimum, we'll have an icon size = (0.6 - 0.3) * 48 = 14.4
|
||||||
|
size -= ( 0.3 * ( ( self.nb_ref_by_places - float(marker[2]) )/ min_interval) )
|
||||||
|
|
||||||
|
conv_pt = osmgpsmap.point_new_degrees(float(marker[0][0]),
|
||||||
|
float(marker[0][1]))
|
||||||
|
coord_x, coord_y = gpsmap.convert_geographic_to_screen(conv_pt)
|
||||||
|
ctx.translate(coord_x, coord_y)
|
||||||
|
ctx.scale( size, size)
|
||||||
|
# below, we must found one solution to place exactly the marker
|
||||||
|
# depending on its size. Normaly, the left top of the image is set to the coordinates
|
||||||
|
# The tip of the pin which should be at the marker position is at 3/18 of the width.
|
||||||
|
# rounding problem ?
|
||||||
|
posY = - (( 48 * size + 5 ) / ( 16.0 / 18.0 )) - 2
|
||||||
|
posX = - (( 48 * size + 5 ) / 6 ) - 2 # 6 <= 3/18 = 1/6
|
||||||
|
ctx.set_source_pixbuf(marker[1], posX, posY)
|
||||||
|
ctx.paint()
|
||||||
|
ctx.restore()
|
||||||
|
|
||||||
|
def do_render(self, gpsmap):
|
||||||
|
"""
|
||||||
|
render the layer
|
||||||
|
"""
|
||||||
|
pass
|
||||||
|
|
||||||
|
def do_busy(self):
|
||||||
|
"""
|
||||||
|
set the layer busy
|
||||||
|
"""
|
||||||
|
return False
|
||||||
|
|
||||||
|
def do_button_press(self, gpsmap, gdkeventbutton):
|
||||||
|
"""
|
||||||
|
When we press a button.
|
||||||
|
"""
|
||||||
|
return False
|
||||||
|
|
||||||
|
gobject.type_register(MarkerLayer)
|
||||||
|
|
@ -56,6 +56,7 @@ from dummylayer import DummyLayer
|
|||||||
from dummynogps import DummyMapNoGpsPoint
|
from dummynogps import DummyMapNoGpsPoint
|
||||||
from selectionlayer import SelectionLayer
|
from selectionlayer import SelectionLayer
|
||||||
from lifewaylayer import LifeWayLayer
|
from lifewaylayer import LifeWayLayer
|
||||||
|
from markerlayer import MarkerLayer
|
||||||
from datelayer import DateLayer
|
from datelayer import DateLayer
|
||||||
from gen.ggettext import sgettext as _
|
from gen.ggettext import sgettext as _
|
||||||
from gen.config import config
|
from gen.config import config
|
||||||
@ -84,6 +85,7 @@ class OsmGps():
|
|||||||
self.zone_selection = False
|
self.zone_selection = False
|
||||||
self.selection_layer = None
|
self.selection_layer = None
|
||||||
self.lifeway_layer = None
|
self.lifeway_layer = None
|
||||||
|
self.marker_layer = None
|
||||||
self.date_layer = None
|
self.date_layer = None
|
||||||
self.context_id = 0
|
self.context_id = 0
|
||||||
self.begin_selection = None
|
self.begin_selection = None
|
||||||
@ -138,6 +140,7 @@ class OsmGps():
|
|||||||
self.osm.layer_add(DummyLayer())
|
self.osm.layer_add(DummyLayer())
|
||||||
self.selection_layer = self.add_selection_layer()
|
self.selection_layer = self.add_selection_layer()
|
||||||
self.lifeway_layer = self.add_lifeway_layer()
|
self.lifeway_layer = self.add_lifeway_layer()
|
||||||
|
self.marker_layer = self.add_marker_layer()
|
||||||
self.date_layer = self.add_date_layer()
|
self.date_layer = self.add_date_layer()
|
||||||
self.cross_map = osmgpsmap.GpsMapOsd( show_crosshair=False)
|
self.cross_map = osmgpsmap.GpsMapOsd( show_crosshair=False)
|
||||||
self.set_crosshair(config.get("geography.show_cross"))
|
self.set_crosshair(config.get("geography.show_cross"))
|
||||||
@ -181,6 +184,20 @@ class OsmGps():
|
|||||||
"""
|
"""
|
||||||
return self.date_layer
|
return self.date_layer
|
||||||
|
|
||||||
|
def add_marker_layer(self):
|
||||||
|
"""
|
||||||
|
add the marker layer
|
||||||
|
"""
|
||||||
|
marker_layer = MarkerLayer()
|
||||||
|
self.osm.layer_add(marker_layer)
|
||||||
|
return marker_layer
|
||||||
|
|
||||||
|
def get_marker_layer(self):
|
||||||
|
"""
|
||||||
|
get the marker layer
|
||||||
|
"""
|
||||||
|
return self.marker_layer
|
||||||
|
|
||||||
def add_lifeway_layer(self):
|
def add_lifeway_layer(self):
|
||||||
"""
|
"""
|
||||||
add the track or life ways layer
|
add the track or life ways layer
|
||||||
|
Reference in New Issue
Block a user