I've got this error: map.js:33 Uncaught TypeError: event.target.getPosition is not a function at yn.<anonymous> (map.js:33) - heremaps

It doesn't display me the infobubble popup and I tried to change the code, on line 33, but it still doesn't work.
var ui = H.ui.UI.createDefault(map, defaultLayers);
var marker1 = new H.map.Marker({ lat: 47.045299, lng: 21.919435 });
marker1.setData
(
"<p> Universitatea din Oradea, Facultatea de Geografie,
Turism și Sport <br> Adresa: <br> Nume Masterat:<br> Număr de
Studenți:
</p > "
);
marker1.addEventListener("tap", event => {
var bubble = new H.ui.InfoBubble(
***event.target.getPosition(),***
{
content: event.target.getData()
}
);
ui.addBubble(bubble);
}, false);

Instead of:
event.target.getPosition()
Use:
event.target.getGeometry();

Related

how to create a list <> in flutter from Firestore?

I am new to flutter.
How can I retrieve data from Firestore and form a new profile with every child in my collection? Second question is how can I use this list in another dart file? thank you
Thank you.
final List<Profile> demoProfiles = [
Profile (
photos: [
"https://",
],
name: "abc",
),
Profile (
photos: [
"https://",
],
name: "abc",
)
];
Assuming you have a firestore strucuture like this:
Profile
photos: []
name: ""
age: ""
distance: ""
education: ""
You can fetch data and build it into your object with this code snippet:
fetchData() async{
final db = await Firestore.instance;
List<Profile> demoProfiles = []
db.collection("Profile").get().then(function(snapshot){
snapshot.forEach((document) {
demoProfiles.add(Profile(
photos: document.data.photos,
name: document.data.name,
age: document.data.age,
distance: document.data.distance,
education: document.data.education
))
})
})
}
Edit:
1) Remove the mockedup list of profiles from your profiles class, it should not be there
2) Edit your mainController to the following:
class _MainControllerState extends State<MainController> {
List<Profile> demoProfiles = [];
demoProfiles = fetchData();
Final MatchEngine match Engine = MatchEngine (
matches:demoProfiles.map((Profile profile) => Match(profile: profile)).toList();
);
fetchData() async{
final db = await Firestore.instance;
List<Profile> list = [];
db.collection("Profile").get().then(function(snapshot){
snapshot.forEach((document) {
list.add(Profile(
photos: document.data.photos,
name: document.data.name,
age: document.data.age,
distance: document.data.distance,
education: document.data.education
))
})
});
return list;
}
}

Search Marker Leaflet Map

I am working on an application with Django. There in this application, I am first using Django to create a database with points and extract a JSON file (It is called "markers.json"). Then, using this JSON file, I am creating markers on a map with Leaflet. When I finished entering all the points to the database they will be around 5000 thousand. So, I decided that it is a good idea to be able to search this markers with an input tag and a search button. I enter the "site_name" as input and when I click the "search" button the related marker should popup. However, always the same marker pops up and I don't know where I am doing wrong.
Could you please help me on that?
HTML PART
<input type="text" id="mast_find" name="mastName" placeholder="Search or masts...">
<button type="submit" id="mast_button">Search</button>
JAVASCRIPT PART
var streets = L.tileLayer( 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© OpenStreetMap',
subdomains: ['a', 'b', 'c']
}),
esri = L.tileLayer('https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}', {
attribution: 'Tiles © Esri — Source: Esri, i-cubed, USDA, USGS, AEX, GeoEye, Getmapping, Aerogrid, IGN, IGP, UPR-EGP, and the GIS User Community'
}),
topo = L.tileLayer('https://{s}.tile.opentopomap.org/{z}/{x}/{y}.png', {
maxZoom: 17,
attribution: 'Map data: © OpenStreetMap, SRTM | Map style: © OpenTopoMap (CC-BY-SA)'
});
var map = L.map( 'map', {
center: [20.0, 5.0],
minZoom: 2,
zoom: 2,
layers: [streets, esri, topo]
})
var baseMaps = {
"Streets": streets,
"Esri": esri,
"Topo": topo
};
$('.leaflet-control-attribution').hide()
L.control.scale().addTo(map);
L.control.layers(baseMaps).addTo(map);
var myURL = jQuery( 'script[src$="leaf.js"]' ).attr( 'src' ).replace( 'leaf.js', '' )
var myIcon = L.icon({
iconUrl: myURL + '/images/pin24.png',
iconRetinaUrl: myURL + '/images/pin48.png',
iconSize: [29, 24],
iconAnchor: [9, 21],
popupAnchor: [0, -14]
})
for ( var i=0; i < markers.length; ++i )
{
var deneme = [];
var meleme = L.marker( [markers[i].fields.latitude, markers[i].fields.longitude], {icon: myIcon} )
.bindPopup( "<b>" + "Mast name: " + "</b>" + markers[i].fields.site_name + "<b>" + "<br>" + "A: " + "</b>" + markers[i].fields.a_measured_height_lt + "<br>" + "<b>" + "k: " + "</b>" + markers[i].fields.k_measured_height_lt )
.addTo( map );
deneme.push(meleme);
document.getElementById("mast_button").onclick = mastFunct;
function mastFunct(){
var data = document.getElementById("mast_find");
for (var i=0; i < markers.length; ++i ){
var markerID = markers[i].fields.site_name;
if (markerID = data.value){
deneme[i].openPopup()
}
}
};
if (markerID = data.value){
should be
if (markerID == data.value){
the only issue that i see is this with the if (markerID = data.value){.
But you can try this alternative:
instead your for-loop:
map.eachLayer(function(marker){
if(marker.options){
var markerID = marker.options.site_name;
if (markerID == data.value){
marker.openPopup();
}
}
});
and add this to your marker creation:
L.marker([51.493782, -0.089951],{icon: myIcon, site_name: 'test'}).addTo(map)

Plotting Dashed Vertical and Horizontal lines on line graph for single point

I am using angular-chart.js and need help in drawing dashed lines vertically and horizontally on the original graph to denote the current value.
Need something like this:
var data = {
labels: ["1.0", "2.0", "3.0","2.4"],
datasets: [{
data: [12, 9, 8, 6]
}]
};
var ctx = document.getElementById("LineWithLine").getContext("2d");
Chart.types.Line.extend({
name: "LineWithLine",
draw: function () {
Chart.types.Line.prototype.draw.apply(this, arguments);
var point = this.datasets[0].points[this.options.lineAtIndex]
var Origpoint = this.datasets[0].points[0];
//var currentpoint = this.datasets[0].points[2.7];
var scale = this.scale
this.chart.ctx.setLineDash([10, 10]);
// draw line
this.chart.ctx.beginPath();
this.chart.ctx.moveTo(point.x, point.y);
this.chart.ctx.strokeStyle = '#ff0000';
this.chart.ctx.lineWidth=2.5;
this.chart.ctx.lineTo(point.x, scale.endPoint);
this.chart.ctx.stroke();
// draw line
this.chart.ctx.beginPath();
this.chart.ctx.moveTo(point.x, point.y);
this.chart.ctx.strokeStyle = '#ff0000';
this.chart.ctx.lineWidth=2.5;
this.chart.ctx.lineTo(Origpoint.x, point.y);
this.chart.ctx.stroke();
this.chart.ctx.setLineDash([0]);
var imageObj = new Image();
imageObj.src = '';
this.chart.ctx.drawImage(imageObj, point.x-6, scale.endPoint-7);
var imageObj = new Image();
imageObj.src = '';
this.chart.ctx.drawImage(imageObj, Origpoint.x-2, point.y-6);
}
});
new Chart(ctx).LineWithLine(data, {
datasetFill : false,
lineAtIndex: 1
});
http://jsfiddle.net/dbyze2ga/257/

Raphael JS Dynamic path update not working in IE 11

When I try to have a path follow the mouse pointer in IE 11 it wont work, but it works fine in Chrome.
Please see the code here http://jsfiddle.net/3xy3oba2/1/
<body>
<div id="container" onmousemove="move(event)"></div>
<script src="http://cdnjs.cloudflare.com/ajax/libs/raphael/2.1.0/raphael-min.js"></script>
<script>
var paper = Raphael("container", 500, 500);
console.log("Path redraw test");
var arrow = paper.path("M 250, 250, L 0, 0");
arrow.attr('stroke-width', 2);
arrow.attr('stroke', "#0000FF");
arrow.attr('arrow-end', "classic-wide-long");
function move(event)
{
var x = event.layerX;
var y = event.layerY;
var path = "M 250, 250, L " + x + ", " + y;
arrow.attr('path', path);
}
</script>
</body>
Anyone got a idea about what goes wrong?
The work around mentioned above is this. Remove the arrow head, change the path, add the arrow head back.
Update code here: http://jsfiddle.net/7fz5qb7e/2/
Also found the same solution here, https://groups.google.com/forum/#!topic/raphaeljs/m-H63bb7Nsw
Full JS code here:
<body>
<div id="container" onmousemove="move(event)"></div>
<script src="http://cdnjs.cloudflare.com/ajax/libs/raphael/2.1.0/raphael-min.js"></script>
<script>
var paper = Raphael("container", 500, 500);
console.log("Path redraw test");
var arrow = paper.path("M 250, 250, L 0, 0");
arrow.attr('stroke-width', 2);
arrow.attr('stroke', "#0000FF");
arrow.attr('arrow-end', "classic-wide-long");
function move(event)
{
var x = event.offsetX;
var y = event.offsetY;
var path = "M 250, 250, L " + x + ", " + y;
arrow.attr('arrow-end', "");
arrow.attr("path", path);
arrow.attr('arrow-end', "classic-wide-long");
}
</script>
</body>

Passing the lat, lng information to the google map script

I've have an index.html file that includes a gogglemap.js file to display a map of users location. Currently I am attempting to add the proper code to the index.html to pass the lat, lng info to the js file.
Here is filler content for the index file to show what I am attempting to do:
<h3><display user city></h3> <---- this needs to display users city and has filler text to show what I am trying to accomplish.
<div id="map"></div>
<script>var lat=12.356;var lng=-19.31;var country="User Country";var city="User City";</script> <----- seems like it is getting the lat/lng somehow before the index page loads and inserting this script into the index file?
Here is the js file code:
var styles = [{yourcustomstyle}]
var myLatlng = { lat: lat, lng: lng };
function initialize() {
var mapOptions = {
zoom: 12,
center: myLatlng,
styles: styles,
panControl: false,
zoomControl: false,
mapTypeControl: false,
scaleControl: false,
streetViewControl: false,
overviewMapControl: false
};
var map = new google.maps.Map( document.getElementById('map'), mapOptions );
for (var a = 0; a < 6; a++) {
c = Math.random();
c = c * (0 == 1E6 * c % 2 ? 1 : -1);
d = Math.random()
d = d * (0 == 1E6 * d % 2 ? 1 : -1);
c = new google.maps.LatLng( lat + 0.08 * c + 0.052, lng + 0.2 * d + 0.08),
marker = new google.maps.Marker({
map: map,
position: c,
icon: 'marker.png'
});
}
}
function loadScript() {
var script = document.createElement('script');
script.type = 'text/javascript';
script.src = 'https://maps.googleapis.com/maps/api/js?v=3.exp&callback=initialize';
document.body.appendChild( script );
}
window.onload = loadScript;