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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值