Foros del Web » Programando para Internet » Javascript »

openlayer mover marker AYUDA !

Estas en el tema de openlayer mover marker AYUDA ! en el foro de Javascript en Foros del Web. Alguien me puede ayudar a mover este MARKER en openlayer.. <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>Mapa</title> <script type="text/javascript"> var estado; </script> <href="http://www.openlayers.org/api/theme/default/style.css" rel="stylesheet" type="text/css"> <script type="text/javascript"> </script> ...
  #1 (permalink)  
Antiguo 29/03/2010, 17:12
Avatar de jhonnybmx  
Fecha de Ingreso: abril-2007
Ubicación: Bogotá, colombia
Mensajes: 22
Antigüedad: 17 años, 8 meses
Puntos: 0
openlayer mover marker AYUDA !

Alguien me puede ayudar a mover este MARKER en openlayer..




<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Mapa</title>


<script type="text/javascript">
var estado;
</script>


<href="http://www.openlayers.org/api/theme/default/style.css" rel="stylesheet" type="text/css">


<script type="text/javascript">

</script>
<style type="text/css">
#map {
width: 1024px;
height: 600px;

}

</style>




<script src="http://maps.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAAKFodoFaBZaU8 L0Mhu_fIzRSrxPxopuoSrb5BI6peR2a09rRn8RRnu6DuAoT0ns Xlprymp7eddPoJtg"></script>

<script src="http://www.openlayers.org/api/OpenLayers.js"></script>



<script type="text/javascript">
var ZoomLevels = 18;
var bounds = new OpenLayers.Bounds(-81.7358169555665, -4.23687362670895, -66.8704528808595, 12.5947074890135);
var boundsToExtent = new OpenLayers.Bounds(-180, -90, 180, 90);
var format = 'image/png';
var zoom = 1;
var map, controls, texto_capa;

var layer;



var MapOptions = {
controls: [],
maxResolution: 0.17578125,
numZoomLevels: ZoomLevels,
projection: new OpenLayers.Projection('EPSG:4326'),
maxExtent: boundsToExtent



};

var OvOptions = {
maxExtent: bounds,
projection: new OpenLayers.Projection('EPSG:4326'),
resolutions:[
0.17578125,
0.087890625,
0.0439453125,
0.02197265625,
0.010986328125,
0.0054931640625,
0.00274658203125,
0.001373291015625,
0.0006866455078125,
0.00034332275390625,
0.000171661376953125,
0.0000858306884765625,
0.00004291534423828125,
0.000021457672119140625,
0.0000107288360595703125,
0.00000536441802978515625,
0.000002682209014892578125,
0.0000013411045074462890625
]
};





function init() {

map = new OpenLayers.Map(document.getElementById('map'), MapOptions)


width = map.clientWidth;
MapOptions.maxResolution = (MapOptions.maxExtent.right-MapOptions.maxExtent.left)/width;

ntb = new OpenLayers.Control.Navigation();
map.addControl(ntb);

pzb = new OpenLayers.Control.PanZoomBar({position: new OpenLayers.Pixel(1, 5)});
map.addControl(pzb);

atr = new OpenLayers.Control.Attribution();
map.addControl(atr);

lsw = new OpenLayers.Control.LayerSwitcher();
lsw.activeColor = "#99B3CC";
map.addControl(lsw);
lsw.maximizeControl();


nav = new OpenLayers.Control.NavigationHistory();
map.addControl(nav);

var controlOptions = {
mapOptions: OvOptions,
autoPan: true
}


loadControlOpenLayer();


var overview = new OpenLayers.Control.OverviewMap(controlOptions);


var gphy = new OpenLayers.Layer.Google(
"Google Physical",
{type: G_PHYSICAL_MAP}
);
var gmap = new OpenLayers.Layer.Google(
"Google Streets", // the default
{numZoomLevels: 20}
);
var ghyb = new OpenLayers.Layer.Google(
"Google Hybrid",
{type: G_HYBRID_MAP, numZoomLevels: 20}
);
var gsat = new OpenLayers.Layer.Google(
"Google Satellite",
{type: G_SATELLITE_MAP, numZoomLevels: 20}
);


map.addLayers([gphy, gmap, ghyb, gsat]);


map.setCenter(new OpenLayers.LonLat(-70.2, 6.9), 6);


loadControlOpenLayer();



pintar();




}//end in




function loadControlOpenLayer()
{
OpenLayers.Control.Click = OpenLayers.Class(OpenLayers.Control,
{
'handleRightClicks': true, defaultHandlerOptions:
{
'single': true,
'double': false,
'pixelTolerance': 0,
'stopSingle': false,
'stopDouble': false
},

initialize: function(options)
{
this.handlerOptions = OpenLayers.Util.extend
(
{}, this.defaultHandlerOptions
);
OpenLayers.Control.prototype.initialize.apply
(
this, arguments
);
this.handler = new OpenLayers.Handler.Click(
this, {
'click': this.onClick,
'dblclick': this.onDblclick,
'rightclick':this.onRightClick
}, this.handlerOptions
);
},
onClick: function(evt) {

if(estado!=2){
pintar(evt);

if(estado==2){

}else{
estado=1;
}
}
//addPoint(lonlat.lon, lonlat.lat);

},
onRightClick: function(evt) {
/*
funcion para controlar el click derecho
*/
},
onDblclick: function(evt) {

},
trigger: function(e) {}
});


controls =
{
"single": new OpenLayers.Control.Click(
{
handlerOptions: {
"single": true,
"double": false
}

}),

"double": new OpenLayers.Control.Click({
handlerOptions: {
"single": false,
"double": true
}
}),

"both": new OpenLayers.Control.Click({
handlerOptions: {
"single": true,
"double": true
}
}),

"drag": new OpenLayers.Control.Click({
handlerOptions: {
"single": true,
"pixelTolerance": null
}
}),

"stopsingle": new OpenLayers.Control.Click({
handlerOptions: {
"single": true,
"stopSingle": true
}
}),

"stopdouble": new OpenLayers.Control.Click({
handlerOptions: {
"single": false,
"double": true,
"stopDouble": true
}
})
};

vectors = new OpenLayers.Layer.Vector("Vector Layer");
controls2 = {
point: new OpenLayers.Control.DrawFeature(vectors, OpenLayers.Handler.Point),

drag: new OpenLayers.Control.DragFeature(vectors)
};


for(var key2 in controls2) {
map.addControl(controls2[key2]);
}

for(var key in controls) {
controle = controls[key];
controle.key = key;
map.addControl(controle);
}

}
function pintar()
{

var markers = new OpenLayers.Layer.Markers( "Markers" );
map.addLayer(markers);

var size = new OpenLayers.Size(32,32);
var offset = new OpenLayers.Pixel(-(size.w/2)+7, -size.h-2);
var icon = new OpenLayers.Icon('http://conap.gob.gt:7777/Conap/Members/ecancinos/plonelocalfolderng.2006-05-16.0529378581/InstalarProgs/Maps/skins/Maps/marker-blue.png',size,offset);

markers.addMarker(new OpenLayers.Marker(new OpenLayers.LonLat(-70,9),icon));

estado=2;


}




</script>



</head>
<Body onLoad="init()" >

<div id="map" class="smallmap" style="border:solid"></div>


</body>
</html>
  #2 (permalink)  
Antiguo 31/05/2010, 13:59
 
Fecha de Ingreso: mayo-2010
Mensajes: 23
Antigüedad: 14 años, 7 meses
Puntos: 1
Respuesta: openlayer mover marker AYUDA !

Creo que llegue un poco tarde, ya solucionaste tu problema??

si aun no lo has echo es necesario que tengas como funcion todos los eventos click de los botones, porque tendrias que desactivar todos los controles sobre la capa vector para activar el controls2.drag

ademas, no veo que actives ese control en alguna parte, tienes referencia a alguna archivo con funciones apartes de ese?

Etiquetas: mover
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 02:59.