- 浏览: 145470 次
- 性别:
- 来自: 大连
文章分类
最新评论
-
houfeng0923:
zensh 写道这种Promise用起来还是复杂了点,需要大量 ...
使用jQuery Deferred 和 Promise 创建响应式应用程序 -
zensh:
这种Promise用起来还是复杂了点,需要大量处理异步任务的同 ...
使用jQuery Deferred 和 Promise 创建响应式应用程序 -
Troland:
houfeng0923 写道Troland 写道
functi ...
JavaScript设计模式摘要(一) -
houfeng0923:
Troland 写道
function extend(subc ...
JavaScript设计模式摘要(一) -
Troland:
function extend(subclass,super ...
JavaScript设计模式摘要(一)
YUI3学习(十)---基于组件框架的Widget实例(GoogleMapWidget)
本文遵循YUI3 Widget组件设计理念,继承YUI Widget类将Google Maps API v3 进行简单的封装,实现GoogleMapWidget组件。
涉及几个知识点:自定义Widget组件、自定义组件的css加载
1、定义MapWidget组件
YUI({ modules: { 'KBox':{//调用其他的组件 fullpath:'lib/custom/kbox.js', requires:['node','event','dump','overlay','dd-plugin','anim','plugin'] } } }).add('mapwidget',function(Y){ Node = Y.Node; Lang = Y.Lang; G = google.maps;//google maps 对象 Y.MapWidget = Y.Base.create("mapwidget", Y.Widget, [Y.WidgetStdMod],{ renderUI:function(){ this._renderHeaderBorder(); this._renderLeftBorder(); this._renderToolbar(); this._renderBodyMap(); this._renderFooter(); }, bindUI:function(){ var me = this; Y.after('resize',function(e){ var h = me.get('boundingBox').getStyle('height'); me.set('height',h); me.refreshSize(); },Y.config.win); }, syncUI:function(){ }, /*renderUI*/ //top修饰样式 _renderHeaderBorder:function(){ var filterWrapper = Node.create('<div class="dsh"></div>'); var filterdiv = '<div class="h1 {opacityClass}"></div>'; for(var i=1;i<6;i++){ var div = Node.create(Y.substitute(filterdiv,{ opacityClass:'o'+i })); filterWrapper.appendChild(div); } this.get('boundingBox').appendChild(filterWrapper); }, //left修饰样式 _renderLeftBorder:function(){ var filterWrapper = Node.create('<div class="dsw"></div>'); var filterdiv = '<div class="w1 {opacityClass}"></div>'; for(var i=5;i>0;i--){ var div = Node.create(Y.substitute(filterdiv,{ opacityClass:'o'+i })); div.setStyles({ 'position':'absolute', 'width':i+'px', 'float':'left' }); filterWrapper.appendChild(div); } this.get('boundingBox').appendChild(filterWrapper); }, _renderToolbar:function(){ //地图工具箱|放大|缩小|量距|测面积|全屏|分析 var toolbarNode = Node.create('<div id="maptoolbar"></div>'); // this._addForwardViewCmd(toolbarNode); // this._addBackViewCmd(toolbarNode); // this._addClearOverlyrCmd(toolbarNode); // this._addFullMapCmd(toolbarNode); // this._addIdentifyTool(toolbarNode); this._addMeasureAreaTool(toolbarNode); this._addMeasureDistanceTool(toolbarNode); // this._addPanTool(toolbarNode); // this._addZoomOutTool(toolbarNode); // this._addZoomInTool(toolbarNode); this._addSearchControl(toolbarNode); this.setStdModContent('header',toolbarNode); }, _renderBodyMap:function(){ var mapNode = this.get('bodyContent'); var mapdiv = Node.getDOMNode(mapNode); if (!G.Map) return; this.mapTypeIds = []; var myOptions = { zoom: 1, disableDoubleClickZoom:true, center: this.get('defaultCenter'), scaleControl: true, scaleControlOptions: { position: G.ControlPosition.BOTTOM_LEFT }, /* mapTypeId: G.MapTypeId.ROADMAP, mapTypeControlOptions:{ mapTypeIds:[ G.MapTypeId.ROADMAP, G.MapTypeId.TERRAIN ], style:G.MapTypeControlStyle.DEFAULT }, */ mapTypeControl:false, mapTypeControlOptions: {mapTypeIds: this.mapTypeIds}, panControl:false } //定义maps相关属性(同时使用了ATTRS, 需要用get('map')获取 ) var map = new G.Map(mapdiv, myOptions); this.map = map; var registedMapTypes = this.get('mapTypes'); if(registedMapTypes){ this._addMapType(registedMapTypes); } this._createCreditControl(); Y.on('unload',function(){ GUnload(); },Y.config.win); //去掉 Google 使用条款 链接 setTimeout(function(){ var a = mapNode.getElementsByTagName('a'); a.each(function(h){ Y.Node.getDOMNode(h).href = ''; //if(h.get('text')=='使用条款') h.set('text',''); //h.remove(); //var temp = Y.Node.create('<span>'); h.prepend(temp); temp.unwrap(); }); },1000); //切换地图类型事件 var me = this; G.event.addListener(this.map, 'maptypeid_changed', function(){ me.removeAllOverLayer(); }); //地图显示范围设定 var bounds = this.getCustomBounds(); G.event.addListener(this.map,'dragend',function(){ if (bounds.contains(me.map.getCenter())) return; var c = me.map.getCenter(), x = c.lng(), y = c.lat(), maxX = bounds.getNorthEast().lng(), maxY = bounds.getNorthEast().lat(), minX = bounds.getSouthWest().lng(), minY = bounds.getSouthWest().lat(); if (x < minX) x = minX; if (x > maxX) x = maxX; if (y < minY) y = minY; if (y > maxY) y = maxY; me.map.setCenter(new G.LatLng(y, x)); }); }, _renderFooter:function(){ //var footerPanel = Node.create('<div>sdfds</div>'); //this.setStdModContent('footer',footerPanel); }, /*end renderUI*/ /*map function*/ refreshSize:function(){ G.event.trigger(this.map, 'resize'); }, /* * 外部调用添加MapType方法,会将添加的MapType同时添加进属性 ‘mapTypes’ */ addMapType:function(typeObj){ var registedMapTypes = this.get('mapTypes'); //检测是否存在,是:从集合中删除。 var me = this; Y.each(typeObj,function(v,k){ if(registedMapTypes[k]) { delete typeObj[k]; } }); this._addMapType(typeObj); }, /* * 内部调用,初始化添加MapType,单个或多个; */ _addMapType:function(typeObj){ var addMapTypes = typeObj; //重投影 var customZone = this.get('customZone'); var start_lat = customZone.startLat; var end_lat = customZone.endLat; var start_lng = customZone.startLng; var end_lng = customZone.endLng; var offset_x = end_lng-start_lng; var offset_y = end_lat-start_lat; Y.each(addMapTypes,function(v,k){ var tilesize_x = v.tileSize.width; var tilesize_y = v.tileSize.height; var maptype = new G.ImageMapType(v); maptype.projection = {//直接设置才生效 fromLatLngToPoint:function(latlng,point){ var x = (latlng.lng()-start_lng)*tilesize_x/offset_x; var y = (end_lat-latlng.lat())*tilesize_y/offset_y; return new G.Point(x,y); }, fromPointToLatLng:function(point,nowrap){ var lat = end_lat-(point.y*offset_y/tilesize_y); var lng = start_lng+(point.x*offset_x/tilesize_x); return new G.LatLng(lat,lng); } }; this.map.mapTypes.set(k, maptype); this.mapTypeIds.push(k); },this); }, _createCreditControl:function(text){ //设置版权信息栏 var creditNode = Y.Node.create('<div>'); creditNode.setStyles({ 'color':'#000', 'fontSize':'12px', 'fontFamily':'Arial, sans-serif', 'margin':'0 2px 2px 0', 'whitespace':'nowrap' }); //添加版权栏 this.map.controls[G.ControlPosition.BOTTOM_RIGHT].push(Y.Node.getDOMNode(creditNode)); this.creditNode = creditNode; this.setCreditContent(text); }, setCreditContent:function(text){ if(text) this.creditNode.set('innerHTML',text); }, setMapType:function(type){ if(Y.Array.indexOf(this.mapTypeIds,type)>=0){ this.map.setMapTypeId(type); var registedMapTypes = this.get('mapTypes'); var defaultZoom = registedMapTypes[type].defaultZoom; if(defaultZoom) this.map.setZoom(defaultZoom); this.map.setCenter(this.get('defaultCenter')); //版权信息 var text = registedMapTypes[type].credit; this.setCreditContent(text); }else{ alert('未注册该图层'); } }, getMapTypeId:function(){ return this.map.getMapTypeId(); }, //获取自定义区域的LatLngBounds getCustomBounds:function(){ var customZone = this.get('customZone'); var sw = new G.LatLng(customZone.startLat,customZone.startLng); var ne = new G.LatLng(customZone.endLat,customZone.endLng); return new G.LatLngBounds(sw,ne); }, /** * 显示信息框 * @param {Object} content * @param {Object} loc {overlayerObj,loc} */ showInfoWindow:function(content,loc){ this._createInfoWindow(); if(Lang.isString(content)){ content = Node.getDOMNode(Node.create('<div>'+content+'</div>')); }else{ content = Node.getDOMNode(content); } this.infoWindow.setContent(content); if(loc.overlayerObj) this.infoWindow.open(this.map,loc.overlayerObj); else if(loc.coord){ this.infoWindow.open(this.map); this.infoWindow.setPosition(loc.coord); } }, _createInfoWindow:function(){ if(!this.infoWindow){ var infoWindow = new G.InfoWindow(); this.infoWindow = infoWindow; } return this.infoWindow; }, _closeInfoWindow:function(){ if(this.infoWindow){ this.infoWindow.close(); } }, /** * 添加marker(icon)并返回; * @param {Object} config * position:{ lat:38.92, lng:121.57 },//或者 [] icon:'images/map/beachflag.png', iconSize:[20,32], iconAnchor:[0,32], shadow:'images/map/beachflag_shadow.png', shadowSize:[37,32], shadowAnchor:[0,32], title:'', zIndex:2 * @param {boolean} [draggable] */ addMarker:function(config,draggable){ if(!this.markerContainer){ this.markerContainer = {}; } var position ; if(config.position.constructor == Array){ position = new G.LatLng(config.position[0],config.position[1]); }else{ position = new G.LatLng(config.position.lat,config.position.lng); } if(config.icon){ var icon = new G.MarkerImage(config.icon); if(config.iconSize) icon.size = new G.Size(config.iconSize[0],config.iconSize[1]); if(config.iconAnchor) icon.anchor = new G.Point(config.iconAnchor[0],config.iconAnchor[1]); config.icon = icon; }else{ //defalut icon var icon = new G.MarkerImage("mapfiles/markers/custom/marker_large_red.png"); icon.size = new G.Size(20,34); icon.anchor = new G.Point(10,34); config.icon = icon; } if(config.shadow){ var shadow = new G.MarkerImage(config.shadow); if(config.shadowSize) shadow.size = new G.Size(config.shadowSize[0],config.shadowSize[1]); if(config.shadowAnchor) shadow.anchor = new G.Point(config.shadowAnchor[0],config.shadowAnchor[1]); config.shadow = shadow; }else{// default shadow var shadow = new G.MarkerImage("mapfiles/markers/custom/shadow.png"); shadow.size = new G.Size(37,34); shadow.anchor = new G.Point(10,34); config.shadow = shadow; } var size = config.icon.size; var gOptions = Y.mix(config,{ map:this.map, draggable:draggable, shape:{ coords:[0,0,size.width,size.height], type:'rect' }, //animation: google.maps.Animation.DROP, position:position },true) ; var id = Y.guid('marker_'); var marker = new G.Marker(gOptions); marker.name = config.title; this.registeOverLayerEvent(config.title,marker); marker.id = id; this.markerContainer[id] = marker; return marker; }, removeMarker:function(marker){ if(marker instanceof G.Marker){ marker.setMap(null); if(marker.id) delete this.markerContainer[marker.id]; } }, /** * 添加线段 * @param {Object} cfg * path:array[{lat,lng}], * ?color * ?opacity * ?weight, * ?title, * ?@param editable {boolean} todo:如果true,增加可编辑的marker点 * */ addPolyline:function(cfg,editable){ if(!this.polylineContainer){ this.polylineContainer = {}; } var path = []; Y.each(cfg.path,function(p){ path.push(new G.LatLng(p.lat,p.lng)); }); var id = Y.guid('polyline_'); var polyline = new G.Polyline({ map: this.map, path:path, strokeColor: cfg.color||'#ff0000', strokeOpacity: cfg.opacity||0.3, strokeWeight: cfg.weight||4 }); polyline.name = cfg.title; this.registeOverLayerEvent(cfg.title,polyline); polyline.id = id; this.polylineContainer[id] = polyline; //dragend event todo return polyline; }, removePolyline:function(polyline){ if(polyline.constructor == G.Polyline){ polyline.setMap(null); if(polyline.id) delete this.polylineContainer[polyline.id]; } }, /** * 添加多边形 * @param {Object} cfg * path:array[{lat,lng}], * ?strokeColor * ?opacity * ?weight * ?fillColor * ?title, * ?@param editable {boolean} todo:如果true,增加可编辑的marker点 * */ addPolygon:function(cfg,editable){ if(!this.polygonContainer){ this.polygonContainer = {}; } var path = []; Y.each(cfg.path,function(p){ path.push(new G.LatLng(p.lat,p.lng)); }); var id = Y.guid('polygon_'); var polygon = new G.Polygon({ map: this.map, path:path, strokeColor: cfg.strokeColor||'#ff0000', strokeOpacity: cfg.opacity||0.8, strokeWeight: cfg.weight||1, fillColor: cfg.fillColor||'#00ff00' }); polygon.name = cfg.title; this.registeOverLayerEvent(cfg.title,polygon); polygon.id = id; this.polygonContainer[id] = polygon; //dragend event todo return polygon; }, removePolygon:function(polygon){ if(polygon.constructor == G.Polygon){ polygon.setMap(null); if(polygon.id) delete this.polygonContainer[polygon.id]; } }, /** * 移除所有点线面叠加对象 */ removeAllOverLayer:function(){ Y.each(this.markerContainer,function(marker,id,container){ marker.setMap(null); delete container[id]; }); Y.each(this.polylineContainer,function(line,id,container){ line.setMap(null); delete container[id]; }); Y.each(this.polygonContainer,function(polygon,id,container){ polygon.setMap(null); delete container[id]; }); this.markerContainer = null; this.polylineContainer = null; this.polygonContainer = null; this._closeInfoWindow(); }, registeOverLayerEvent:function(title,overlayerObj){ var title = title||''; var me = this; var isMarker = false; var isPolyline = false; if (overlayerObj instanceof G.Marker) { isMarker = true; } if (overlayerObj instanceof G.Polyline) { isPolyline = true; } //点线面点击打开信息窗口 G.event.addListener(overlayerObj, 'click', function(){ if(isMarker){ me.showInfoWindow(title,{overlayerObj:overlayerObj}); return; } var center = overlayerObj.getCenterLatLng(); var info = title; if(isPolyline){ info+='<br>长度:'+overlayerObj.getLength().toFixed(2)+'米'; } else { info+='<br>面积:'+overlayerObj.getArea().toFixed(2)+'平方公里'; } me.showInfoWindow(info,{coord:center}); }); if(overlayerObj instanceof G.Polygon){ G.event.addListener(overlayerObj, 'mouseover', function(){ overlayerObj.setOptions({fillOpacity:0.9}); }); G.event.addListener(overlayerObj, 'mouseout', function(){ overlayerObj.setOptions({fillOpacity:0.3}); }); } if(overlayerObj instanceof G.Polyline){ G.event.addListener(overlayerObj, 'mouseover', function(){ overlayerObj.setOptions({strokeOpacity:0.9}); }); G.event.addListener(overlayerObj, 'mouseout', function(){ overlayerObj.setOptions({strokeOpacity:0.3}); }); } }, _getSearchResult:function(keyname){ var resultGeometries = []; if(this.markerContainer){ Y.each(this.markerContainer,function(value,key){ if(value.name&&value.name.indexOf(keyname)>-1){ resultGeometries.push(value); } }); }else if(this.polylineContainer){ Y.each(this.polylineContainer,function(value,key){ if(value.name&&value.name.indexOf(keyname)>-1){ resultGeometries.push(value); } }); }else if(this.polygonContainer){ Y.each(this.polygonContainer,function(value,key){ if(value.name&&value.name.indexOf(keyname)>-1){ resultGeometries.push(value); } }); } Y.each(resultGeometries,function(geo,i){ G.event.trigger(geo, 'click'); }); return resultGeometries; }, /*end map function*/ /*tool functions*/ //属性 this.currentTool\this.tools=['zoomin','zoomout',....] _addZoomInTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/zoomin.png'; var toolImgOver = 'assets/tools/zoomin3.png'; var toolImgClicked = 'assets/tools/zoominX.png'; var overImg = new Image(); overImg.src = toolImgOver; var clickImg = new Image(); clickImg.src = toolImgClicked; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); imgNode.on('mouseover',function(e){ this.setAttribute('src',overImg.src); }); imgNode.on('mouseout',function(e){ this.setAttribute('src',toolImg); }); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>放大</div>')); container.append(toolContainer); }, _addZoomOutTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/zoomout.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>缩小</div>')); container.append(toolContainer); }, _addPanTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/pan.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>平移</div>')); container.append(toolContainer); }, _addMeasureDistanceTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/measure.png'; var toolImgOver = 'assets/tools/measure3.png'; if(Y.UA.ie){ toolImg = 'assets/tools/measure.gif'; toolImgOver = 'assets/tools/measure3.gif'; } var overImg = new Image(); overImg.src = toolImgOver; //var toolImgClicked = 'assets/tools/measureX.png'; //var clickImg = new Image(); clickImg.src = toolImgClicked; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); imgNode.setAttribute('title','点击左键增加测量点,双击左键结束测量。'); imgNode.on('mouseover',function(e){ this.setAttribute('src',overImg.src); }); imgNode.on('mouseout',function(e){ this.setAttribute('src',toolImg); }); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>测距</div>')); container.append(toolContainer); var mapwidget = this; imgNode.on('click',function(e){ var startFlag = false; var moveFlag = false; var measureLatlng = []; mapwidget.currTool = 'measure'; var polyOptions = { clickable:false, strokeColor: 'red', strokeOpacity: 0.6, strokeWeight: 3 } var measurePolyline = new G.Polyline(polyOptions); measurePolyline.setMap(mapwidget.map); var clickListener = G.event.addListener(mapwidget.map, 'click', function(e){ if(!startFlag){ startFlag = true; measureLatlng = []; } moveFlag = false; measureLatlng.push(e.latLng); measurePolyline.setPath(measureLatlng); //measurePolyline.getPath().push(e.latLng); }); var moveListener = G.event.addListener(mapwidget.map,'mousemove',function(e){ if(!startFlag) return; //var pro = mapwidget.map.getProjection(); //var point = pro.fromLatLngToPoint(e.latLng); if(!moveFlag){ measureLatlng.push(e.latLng); moveFlag = true; }else{ measureLatlng.pop(); measureLatlng.push(e.latLng); } measurePolyline.setPath(measureLatlng); }); G.event.addListener(mapwidget.map, 'dblclick', function(e){ startFlag = false; if(mapwidget.currTool == 'measure'){ G.event.removeListener(clickListener); G.event.clearListeners(mapwidget.map,'dblclick'); } if(moveFlag){ measureLatlng.pop(); measurePolyline.setPath(measureLatlng); } Y.later(500,null,function(){ var length = measurePolyline.getLength(); alert('当前测量距离为:'+length+'米'); measurePolyline.setMap(null); measurePolyline = null; }); }); }); }, _addMeasureAreaTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/measure.png'; var toolImgOver = 'assets/tools/measure3.png'; if(Y.UA.ie){ toolImg = 'assets/tools/measure.gif'; toolImgOver = 'assets/tools/measure3.gif'; } var overImg = new Image(); overImg.src = toolImgOver; //var toolImgClicked = 'assets/tools/measureX.png'; //var clickImg = new Image(); clickImg.src = toolImgClicked; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); imgNode.setAttribute('title','点击左键增加测量点,双击左键结束测量。'); imgNode.on('mouseover',function(e){ this.setAttribute('src',overImg.src); }); imgNode.on('mouseout',function(e){ this.setAttribute('src',toolImg); }); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>测面</div>')); container.append(toolContainer); var mapwidget = this; imgNode.on('click',function(e){ var startFlag = false; var moveFlag = false; var measureLatlng = []; mapwidget.currTool = 'measure'; var polyOptions = { clickable:false, strokeColor: 'red', strokeOpacity: 0.6, strokeWeight: 1, fillColor:'#00ff00' } var measurePolygon = new G.Polygon(polyOptions); measurePolygon.setMap(mapwidget.map); var clickListener = G.event.addListener(mapwidget.map, 'click', function(e){ if(!startFlag){ startFlag = true; measureLatlng = []; } moveFlag = false; measureLatlng.push(e.latLng); measurePolygon.setPath(measureLatlng); }); var moveListener = G.event.addListener(mapwidget.map,'mousemove',function(e){ if(!startFlag) return; if(!moveFlag){ measureLatlng.push(e.latLng); moveFlag = true; }else{ measureLatlng.pop(); measureLatlng.push(e.latLng); } measurePolygon.setPath(measureLatlng); }); G.event.addListener(mapwidget.map, 'dblclick', function(e){ startFlag = false; if(mapwidget.currTool == 'measure'){ G.event.removeListener(clickListener); G.event.clearListeners(mapwidget.map,'dblclick'); } if(moveFlag){ measureLatlng.pop(); measurePolygon.setPath(measureLatlng); } Y.later(500,null,function(){ var area = measurePolygon.getArea(); alert('当前测量面积为:'+area.toFixed(4)+'平方公里'); measurePolygon.setMap(null); measurePolygon = null; }); }); }); }, _addFullMapCmd:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/full.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>全图</div>')); container.append(toolContainer); }, _addBackViewCmd:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/back.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>前视图</div>')); container.append(toolContainer); }, _addForwardViewCmd:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/forward.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>后视图</div>')); container.append(toolContainer); }, _addClearOverlyrCmd:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/clear.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>清除</div>')); container.append(toolContainer); }, _addIdentifyTool:function(container){ var toolContainer = Y.Node.create('<div class="tool-outer">'); var toolImg = 'assets/tools/identify.png'; var imgNode = Y.Node.create('<img src="'+toolImg+'">'); toolContainer.append(imgNode); toolContainer.append(Y.Node.create('<div>信息</div>')); container.append(toolContainer); }, _addSearchControl:function(container){ var mapwidget = this; var toolContainer = Y.Node.create('<div class="tool-outer">'); var input = Y.Node.create('<input type="text">'); input.setStyles({ backgroundColor:'#ccc',border:'none',height:'18px',width:'100px' }); toolContainer.append(input); var btn = Y.Node.create('<input type="button" value="查询">'); btn.on('click',function(e){ var v = input.get('value'); if(v){ mapwidget._getSearchResult(v); } }); toolContainer.append(btn); container.append(toolContainer); }, /*end tool functions*/ /*events*/ /*end events*/ empty:function(){} },{ ATTRS:{ map:{ readOnly:true, getter:function(){ return this.map; } }, defaultCenter:{ setter:function(v){ return new G.LatLng(v.lat,v.lng); } }, customZone:{ setter:function(obj){ return obj; //startLat,endLat,startLng,endLng } }, mapTypes:{ setter:function(obj){ return obj;//hashMap key-string;value-{} } } //end } }); }, '3.3.0' ,{requires:['get','widget','substitute', 'widget-stdmod','dump','event-custom']});
2、 Google maps API v3 : MapType相关参数设置
var startC = 1; var startR = 1; var startZoom = 0; var startColumnCount = 1; var startRowsCount = 1; var BaseImagePath = "maptiles/"; //地图根目录 var RegistedMapTypes = null; var MapTypeConfig = { tileSize: new google.maps.Size(256, 256), isPng: false, maxZoom:startZoom+4, minZoom:startZoom, defaultZoom:startZoom+1, //radius: 111 //projection:在这里设置无效。在生成的MapType对象中设置才有效。无解? //name: '混合图',//option //alt: '切换到混合图', credit: '版权信息*****' }; function initMapTypes(Y){ RegistedMapTypes = {}; var mapList = Data.getMapTypeList(); if(mapList){ Y.each(mapList,function(o,i){ var maptypeid = o.maptypeid; RegistedMapTypes[maptypeid] = Y.merge(MapTypeConfig,{ getTileUrl: function(coord, zoom) { var normalizedCoord = getNormalizedCoord(coord, zoom); if (!normalizedCoord) return null; var xy = normalizedCoord; return BaseImagePath + maptypeid+ "/" + (zoom-this.minZoom+1) + "/" +(xy.x )+'/'+ (zoom-this.minZoom+1)+'_'+( xy.x) + "_" + (xy.y )+ '.png'; } }); }); } }
3、程序初始化及加载组件CSS代码
//yui load Y = YUI({ combine: false, groups:{ myCustom:{ base: 'lib/custom/', modules: { 'mapwidget': { path: 'mapwidget/mapwidget.js', requires: ['widget','substitute', 'widget-stdmod','dump'], skinnable: true }, 'KBox':{ path:'kbox/kbox.js', requires:['node','event','dump','overlay','dd-plugin','anim','plugin'], skinnable:true } } } } }).use('node','event','event-delegate','substitute','mapwidget','KBox','transition','dump','get',function(Y){ //初始化 Y.on('domready',function(){ initMapTypes(Y); window.resizeLayout(); initMapWidget(); //resize Y.on('resize',function(e){ window.resizeLayout(Y); },Y.config.win); //initMapLayerList(); }) ; }
4、组件创建代码
//初始化地图控件 function initMapWidget() { window.mapwidget = new Y.MapWidget({ boundingBox:'#mapContainer', bodyContent:Y.one('#map'), width:'100%', height:'100%', defaultCenter:{ lat:38.9515656143285,lng:121.522006790115 }, customZone:{ startLat:38.72673510697981, endLat:39.17639612167719, startLng:121.23290178540148, endLng:121.81111179482852 }, mapTypes:RegistedMapTypes }); mapwidget.render(); mapwidget.setMapType('basic'); //test return; mapwidget.addMarker({position:[39.17639612167719, 121.23290178540148],title:'sdfsfs'}); /// mapwidget.addPolyline({ path:[ {lat:38.72673510697981,lng:121.23290178540148}, {lat:39.17639612167719,lng:121.81111179482852} ], title:'line' }); mapwidget.addPolygon({ path:[ {lat:38.72673510697981,lng:121.23290178540148}, {lat:39.17639612167719,lng:121.23290178540148}, {lat:39.17639612167719,lng:121.61111179482852} ] }); }
对应的页面HTML代码如下:
<div id='mapContainer'> <div id='map'></div> </div>
评论
2 楼
houfeng0923
2012-05-29
Alog_W 写道
感觉LZ!
非常不错的帖子,要仔细研读!
不过我非常想知道LZ怎么布局这些自定义的组件?
是独立在一个文件夹里的吗?
非常不错的帖子,要仔细研读!
不过我非常想知道LZ怎么布局这些自定义的组件?
是独立在一个文件夹里的吗?
组件的物理存放吗?就是单独存放到一个目录里
lib/yui3
lib/custom
在工程lib/custom下面是这样:
kbox
mapwidget
-mapwidget.js
-assets
-skins
-sam
-mapwidget.css
1 楼
Alog_W
2012-05-29
感觉LZ!
非常不错的帖子,要仔细研读!
不过我非常想知道LZ怎么布局这些自定义的组件?
是独立在一个文件夹里的吗?
非常不错的帖子,要仔细研读!
不过我非常想知道LZ怎么布局这些自定义的组件?
是独立在一个文件夹里的吗?
发表评论
-
Twitter Flight 学习小结
2013-08-29 10:57 1916链接:twitter flight 关键字: 基于事件交 ... -
Google Maps API V3 笔记
2013-08-29 10:54 11年前项目需要顺便学习了下Google Maps API ,相比 ... -
使用jQuery Deferred 和 Promise 创建响应式应用程序
2012-11-12 20:41 6188翻译自:Creating Responsive Applica ... -
编写 Sublime Text2 的 nodejs debug 插件
2012-08-27 22:07 4661使用sublime text2 编写 node 代码 ... -
Image beacon
2012-05-06 11:42 1650转帖:http://www.denisdeng.com/?p= ... -
Google Maps API V3 学习摘要
2012-03-03 20:40 3806Google Maps API V3 学习摘要 ... -
大话HTML DOM与XML DOM的区别与联系【转】
2011-10-04 11:21 2317原文链接: http://deve ... -
dojo类机制模拟实现
2011-09-29 11:00 1597偶然在infoq上看到朋友的文章《dojo类机制简 ... -
web前端研发工程师编程能力成长之路 [转]
2011-09-29 10:26 2006【背景】 如果你是刚进入WEB前端研发领域,想试试这 ... -
Web开发乱码分析总结
2011-09-28 17:08 1619今天对前端开发常见的乱码情况进行了汇总测试和分析,并做了 ... -
document.documentElement 与 document.body 的 scrollWidth、offsetWidth、clientWidth
2011-09-28 16:54 1575注:(scrollHeight、o ... -
DOCTYPE, HTML和XHTML, Strict DTD和Transitional DTD, Quirks Mode和Standard Mode
2011-09-26 16:53 1659转自:http://blog.csdn.net/w ... -
YUI3学习(九)---组件框架之 Widget
2011-08-10 21:53 2906Widget部件类是YUI3所 ... -
YUI3学习(八)---组件框架之 Plugin
2011-08-08 17:42 2312插件可以让你无侵入地为衍生自Base类的宿主对象 ... -
YUI3学习(七)---组件框架之 Base
2011-08-05 22:45 2126Base组件 Base被设计为那些衍生自Attribute和 ... -
dfssdfsfsfs
2011-08-05 14:37 0sdf s -
JavaScript链式调用小结
2011-08-03 22:47 4851zYUI3 Node对象实现链式调用的方式如下: Y. ... -
JavaScript设计模式摘要(一)
2011-08-03 22:52 2031---------------------------- ... -
YUI3学习(六)---组件框架之 Attribute
2011-08-01 22:57 25761,YUI3组件框架 组 ... -
YUI3 AOP
2011-07-28 23:10 0YUI3在’event-custom’模块的Y.Do类提 ...
相关推荐
这个插件是基于YUI Compressor,一个由Yahoo开发的开源工具,它能有效地压缩和混淆代码,从而减少文件大小,提升网页加载速度,并降低服务器带宽消耗。 ### 一、Maven插件介绍 Maven是Java领域广泛使用的项目管理...
### 3. eclipse yuicompressor-maven-plugin `yuicompressor-maven-plugin`是Maven的一个插件,它将YUI Compressor集成到Maven的构建流程中。在Eclipse环境中,开发者可以方便地使用此插件在构建项目时自动对.js和....
yuicompressor-maven-plugin, 用于压缩 (Minify/Ofuscate/Aggregate) Javascript文件和使用 YUI 压缩器的CSS文件的Maven 插件 [[Flattr this git repo] ( http://api.flattr.com/button/flattr-badge-large.png)]...
【标题】"yui-yuidoc-yuidoc-50-529-gc631758" 指向的是一个关于 Yahoo User Interface Library (YUI) 和 YUIDoc 的特定版本或修订版。YUI 是一个开源的 JavaScript 库,提供了一系列模块化的工具,用于构建富有交互...
3. **数据绑定(Data Binding)**:YUI-EXT支持数据绑定,允许UI组件与后台数据模型直接关联。当数据模型发生变化时,UI会自动更新,反之亦然。这极大地简化了数据驱动的界面开发。 4. **表单(Forms)**:YUI-EXT...
在"YUI-ajax框架开发文档"中,我们可以深入探讨YUI如何通过其Ajax组件实现异步数据通信。 YUI中的Ajax框架主要由`YAHOO.util.Connect`和`YAHOO.widget.DataSource`两个关键部分组成。`YAHOO.util.Connect`是YUI的...
通常,这样的组件会有一个主JS文件(如`yui-form-validator.js`),可能还有一个CSS文件(如`yui-form-validator.css`)来处理样式,以及一些示例或测试用例文件。 **相关知识点:** 1. **YUI库**:了解YUI的基本...
《深入理解YUI3:基于yui3-master.zip的探讨》 YUI(Yahoo! User Interface Library)是由雅虎公司开发的一套开源JavaScript库,它为Web开发者提供了丰富的功能和工具,以创建交互性强、性能优秀的网页应用。YUI3是...
yuicompressor-2.4.2.jar yuicompressor-2.4.7.jar jsZip.exe yuicompressor yui compressor js压缩工具 javascript压缩工具 css压缩工具 ------------------------------------ //压缩JS java -jar yui...
YUI 库,全称Yahoo! UI Library。是一组工具和控件,用...YUI 基于BSD协议,对所有的使用方式都是免费的。YUI 项目包括YUI 库和两个创建时工具: YUI Compressor (压缩) 和 YUI Doc (JavaScripts代码的文档引擎)。
**YUI3 Dialog组件详解** YUI3是Yahoo!推出的一款强大的JavaScript库,它提供了丰富的UI组件和工具,用于构建高性能、跨平台的Web应用程序。Dialog组件是YUI3中的一个重要部分,它允许开发者创建可交互的弹出窗口,...
3. 运行构建:保存配置后,执行构建操作,Idea会自动调用yuicompressor对指定文件进行压缩。 除了基本的压缩功能,yuicompressor还有其他优势。例如,它支持多种语言的输入,包括JavaScript、CSS以及HTML,并且兼容...
YUI 3包含了一系列核心模块,如Event(事件处理)、Node(DOM操作)、IO(异步数据交互)等,同时还有许多可选的组件,如Grids(表格)、Charts(图表)、Form(表单元素)等,覆盖了前端开发的多个方面。...
标题“YUI 3 Live Messaging-开源”揭示了我们讨论的是一个基于YUI 3框架的开源实时消息传递模块。YUI (Yahoo! User Interface Library) 是由雅虎开发的一个开源JavaScript库,旨在帮助开发者构建高性能、可访问且...
yui compressor 2.4.6 发布日期:2011-04-15 用例: java -jar yuicompressor-2.4.6.jar myfile.js -o myfile-min.js
3. **关联选择组件**:这类组件允许用户从多个相关选项中进行选择,例如国家和城市的选择,其中城市的选择依赖于国家的选定。它通过级联的下拉列表实现,提高了用户体验。 4. **树形列表组件**:树形列表用于展示...
这是集成的关键组件。 2. **配置File Watcher**:在IDE中,选择`File` > `Settings`(Windows/Linux)或`WebStorm` > `Preferences`(Mac),然后导航到`Tools` > `File Watchers`。 3. **添加新的File Watcher**...
压缩JavaScript和CSS文件可以显著减少页面加载时间,"grunt-yui-compressor"就是一个这样的工具,它基于Grunt自动化构建工具,结合Yahoo的YUI Compressor进行代码压缩,帮助开发者高效地处理项目中的前端资源。...