您的位置:首页 > 产品设计 > 产品经理

SharpMap AjaxMapControl 中 Zoomin/Zoomout 操作时冻结问题

2007-06-13 01:18 363 查看
1、现象:
在放大/缩小操作时,当 Map.width = Map.MaximumZoom 时再次执行Zoomout 或者当 Map.width = Map.MinimumZoom 时再次执行Zoomin,浏览器显示的地图处于冻结状态(刷新地图停止);同时,鼠标光标处于长久的等待(wait)状态。

2、原因:
客户端 javascript 脚本在响应鼠标事件处理时发生事件重入。

3、解决方法:
修改AjaxMap.js 中的SharpMap_BeginZoom 函数
function SharpMap_BeginZoom(obj,x,y,zoomval)
{
if(obj.zoomEnded==0) return;
if(obj.zoom/zoomval<obj.minZoom) zoomval = obj.zoom/obj.minZoom;
if(obj.zoom/zoomval>obj.maxZoom) zoomval = obj.zoom/obj.maxZoom;
//当控制动态缩放的zoomval值为1时停止动态缩放并退出
if(Math.abs(1-zoomval)<0.0001) return;
obj.zoomEnded=0;
obj.container.style.cursor = 'wait';
var position = WebForm_GetElementPosition(obj.container);
var imgX = x-position.x;
var imgY = y-position.y;
var center = SharpMap_PixelToMap(imgX+(obj.container.offsetWidth*0.5-imgX)/zoomval,imgY+(obj.container.offsetHeight*0.5-imgY)/zoomval,obj);
obj.zoom = obj.zoom/zoomval;
obj.minX = center.x - obj.zoom*0.5;
obj.maxY = center.y + obj.zoom*obj.container.offsetHeight/obj.container.offsetWidth*0.5;
SharpMap_BeginRefreshMap(obj,1); //Start refreshing the map while we're zooming
SharpMap_DynamicZoom((position.x-x)*(zoomval-1),(position.y-y)*(zoomval-1),zoomval,0.0,obj);
}

4、修改后的测试结果:
a) 解决了鼠标 Click 缩放操作冻结问题;
b) 鼠标滚轮缩放操作仍有冻结(原因猜测中……);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐