关闭

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

标签: webformjavascriptfunction浏览器脚本测试
882人阅读 评论(0) 收藏 举报
分类:

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) 鼠标滚轮缩放操作仍有冻结(原因猜测中……);
 

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:387910次
    • 积分:4711
    • 等级:
    • 排名:第6147名
    • 原创:37篇
    • 转载:226篇
    • 译文:25篇
    • 评论:45条
    最新评论