[gnome-maps/wip/turnPointMarker: 2/2] Use icon only for route instructions



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]