[gnome-maps/wip/turnPointMarker: 2/2] Use icon only for route instructions
- From: Jonas Danielsson <jonasdn src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/turnPointMarker: 2/2] Use icon only for route instructions
- Date: Sat, 31 Jan 2015 15:54:20 +0000 (UTC)
commit 2bce71e4bfc9eccec1390f2916645094b0418dd1
Author: Jonas Danielsson <jonas threetimestwo org>
Date: Sat Jan 31 16:48:41 2015 +0100
Use icon only for route instructions
src/mapView.js | 8 ++--
src/org.gnome.Maps.src.gresource.xml | 1 -
src/turnPointBubble.js | 41 ----------------
src/turnPointMarker.js | 86 +++++++++++++--------------------
4 files changed, 38 insertions(+), 98 deletions(-)
---
diff --git a/src/mapView.js b/src/mapView.js
index 39b201d..3808868 100644
--- a/src/mapView.js
+++ b/src/mapView.js
@@ -200,7 +200,7 @@ const MapView = new Lang.Class({
this._turnPointMarker = new TurnPointMarker.TurnPointMarker({ turnPoint: turnPoint,
mapView: this });
this._instructionMarkerLayer.add_marker(this._turnPointMarker);
- this._turnPointMarker.goToAndSelect(true);
+ this._turnPointMarker.goTo();
},
showSearchResult: function(place) {
@@ -243,9 +243,9 @@ const MapView = new Lang.Class({
route.turnPoints.forEach(function(turnPoint) {
if (turnPoint.isStop()) {
let queryPoint = query.filledPoints[pointIndex];
- let destinationMarker = new TurnPointMarker.DestinationMarker({ turnPoint: turnPoint,
- queryPoint: queryPoint,
- mapView: this });
+ let destinationMarker = new TurnPointMarker.TurnPointMarker({ turnPoint: turnPoint,
+ queryPoint: queryPoint,
+ mapView: this });
this._instructionMarkerLayer.add_marker(destinationMarker);
pointIndex++;
}
diff --git a/src/org.gnome.Maps.src.gresource.xml b/src/org.gnome.Maps.src.gresource.xml
index 38faa17..6783131 100644
--- a/src/org.gnome.Maps.src.gresource.xml
+++ b/src/org.gnome.Maps.src.gresource.xml
@@ -45,7 +45,6 @@
<file>socialPlaceListBox.js</file>
<file>socialPlaceMatcher.js</file>
<file>translations.js</file>
- <file>turnPointBubble.js</file>
<file>turnPointMarker.js</file>
<file>userLocationBubble.js</file>
<file>userLocationMarker.js</file>
diff --git a/src/turnPointMarker.js b/src/turnPointMarker.js
index 24ea6d7..efa8b00 100644
--- a/src/turnPointMarker.js
+++ b/src/turnPointMarker.js
@@ -21,6 +21,7 @@
*/
const Clutter = imports.gi.Clutter;
+const Gdk = imports.gi.Gdk;
const Geocode = imports.gi.GeocodeGlib;
const Lang = imports.lang;
const Mainloop = imports.mainloop;
@@ -28,22 +29,16 @@ const Mainloop = imports.mainloop;
const Application = imports.application;
const MapMarker = imports.mapMarker;
const Place = imports.place;
-const TurnPointBubble = imports.turnPointBubble;
const Utils = imports.utils;
const TurnPointMarker = new Lang.Class({
Name: 'TurnPointMarker',
Extends: MapMarker.MapMarker,
- get turnPoint() {
- return this._turnPoint;
- },
-
- get iconName() {
- return this._turnPoint.iconName;
- },
-
_init: function(params) {
+ this._queryPoint = params.queryPoint;
+ delete params.queryPoint;
+
this._turnPoint = params.turnPoint;
delete params.turnPoint;
@@ -53,8 +48,26 @@ const TurnPointMarker = new Lang.Class({
longitude: this._turnPoint.coordinate.get_longitude()
})
});
-
this.parent(params);
+
+ let actor;
+ if (this._queryPoint) {
+ this.draggable = true;
+ this.connect('drag-finish', (function() {
+ this._onMarkerDrag();
+ }).bind(this));
+ actor = Utils.CreateActorFromIconName(this._turnPoint.iconName, 0);
+ } else {
+ // A GNOMEish blue color
+ let color = new Gdk.RGBA({ red: 33 / 255,
+ green: 93 / 255,
+ blue: 156 / 255,
+ alpha: 255 });
+ actor = Utils.CreateActorFromIconName('maps-point-end-symbolic',
+ 0,
+ color);
+ }
+ this.add_actor(actor);
},
get anchor() {
@@ -62,57 +75,26 @@ const TurnPointMarker = new Lang.Class({
y: Math.floor(this.height / 2) - 1 };
},
- goToAndSelect: function(animate) {
- if (!animate) {
- this.parent(animate);
- } else {
- let view = this._mapView.view;
- let turnPointZoomLevel = 16;
-
- view.goto_animation_mode = Clutter.AnimationMode.LINEAR;
- view.goto_duration = 0;
-
- Utils.once(view, 'animation-completed::go-to', (function() {
- view.zoom_level = turnPointZoomLevel;
- view.center_on(this.place.location.latitude,
- this.place.location.longitude);
- this.selected = true;
- }).bind(this));
- view.go_to(this.place.location.latitude,
- this.place.location.longitude);
- }
- },
-
- _createBubble: function() {
- return new TurnPointBubble.TurnPointBubble({ turnPoint: this.turnPoint,
- place: this.place,
- mapView: this._mapView });
- }
-});
-
-const DestinationMarker = new Lang.Class({
- Name: 'DestinationMarker',
- Extends: TurnPointMarker,
-
- _init: function(params) {
- this._queryPoint = params.queryPoint;
- delete params.queryPoint;
-
- this.parent(params);
+ goTo: function() {
+ let view = this._mapView.view;
+ let turnPointZoomLevel = 15;
- this.draggable = true;
+ view.goto_animation_mode = Clutter.AnimationMode.LINEAR;
+ view.goto_duration = 0;
- this.connect('drag-finish', (function() {
- this._onMarkerDrag();
+ Utils.once(view, 'animation-completed', (function() {
+ view.zoom_level = turnPointZoomLevel;
+ view.center_on(this.latitude,
+ this.longitude);
}).bind(this));
- this.add_actor(Utils.CreateActorFromIconName(this.iconName, 0));
+ view.go_to(this.latitude, this.longitude);
},
_onMarkerDrag: function() {
let query = Application.routeService.query;
let place = new Place.Place({
- location: new Geocode.Location({ latitude: this.latitude.toFixed(5),
+ location: new Geocode.Location({ latitude: this.latitude.toFixed(5),
longitude: this.longitude.toFixed(5) }) });
this._queryPoint.place = place;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]