618 |
self.last_selected_layer = layer |
self.last_selected_layer = layer |
619 |
self.last_selected_shape = shape |
self.last_selected_shape = shape |
620 |
|
|
621 |
def unprojected_rect_around_point(self, x, y): |
def unprojected_rect_around_point(self, x, y, dist): |
622 |
"""return a rect a few pixels around (x, y) in unprojected corrdinates |
"""return a rect dist pixels around (x, y) in unprojected corrdinates |
623 |
|
|
624 |
The return value is a tuple (minx, miny, maxx, maxy) suitable a |
The return value is a tuple (minx, miny, maxx, maxy) suitable a |
625 |
parameter to a layer's ShapesInRegion method. |
parameter to a layer's ShapesInRegion method. |
633 |
xs = [] |
xs = [] |
634 |
ys = [] |
ys = [] |
635 |
for dx, dy in ((-1, -1), (1, -1), (1, 1), (-1, 1)): |
for dx, dy in ((-1, -1), (1, -1), (1, 1), (-1, 1)): |
636 |
px, py = self.win_to_proj(x + dx, y + dy) |
px, py = self.win_to_proj(x + dist * dx, y + dist * dy) |
637 |
if inverse: |
if inverse: |
638 |
px, py = inverse(px, py) |
px, py = inverse(px, py) |
639 |
xs.append(px) |
xs.append(px) |
662 |
scale = self.scale |
scale = self.scale |
663 |
offx, offy = self.offset |
offx, offy = self.offset |
664 |
|
|
|
box = self.unprojected_rect_around_point(px, py) |
|
|
|
|
665 |
if select_labels: |
if select_labels: |
666 |
labels = self.map.LabelLayer().Labels() |
labels = self.map.LabelLayer().Labels() |
667 |
|
|
721 |
|
|
722 |
select_shape = -1 |
select_shape = -1 |
723 |
|
|
724 |
|
# Determine the ids of the shapes that overlap a tiny area |
725 |
|
# around the point. For layers containing points we have to |
726 |
|
# choose a larger size of the box we're testing agains so |
727 |
|
# that we take the size of the markers into account |
728 |
|
# FIXME: Once the markers are more flexible this part has to |
729 |
|
# become more flexible too, of course |
730 |
|
if shapetype == SHAPETYPE_POINT: |
731 |
|
box = self.unprojected_rect_around_point(px, py, 5) |
732 |
|
else: |
733 |
|
box = self.unprojected_rect_around_point(px, py, 1) |
734 |
shape_ids = layer.ShapesInRegion(box) |
shape_ids = layer.ShapesInRegion(box) |
735 |
shape_ids.reverse() |
shape_ids.reverse() |
736 |
|
|