首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Swing JxMapViewer:聚焦于对象并设置相应的缩放级别

Swing JxMapViewer:聚焦于对象并设置相应的缩放级别
EN

Stack Overflow用户
提问于 2012-06-09 09:01:39
回答 2查看 1.6K关注 0票数 0

我试图将JxMapViewer集成到我的swing应用程序中。

我在地图上划了两个方向点之间的线。现在,我希望实现如下功能:

无论我在地图上的哪里,无论是什么缩放级别,每当我点击一个按钮(或某个外部事件)时,焦点都应该移到我画的线上(即间接在两个方向点上)。

其次,应该设置缩放级别,以便地图中包含这两个路径点的部分是可见的。

我看到在getViewportBounds类中有JxMApViewer方法。同样,我们没有setViewportBounds。在这种情况下,我们可以计算出包含这两个路径点的矩形并设置它。

任何提示都将不胜感激。

我已经将现有的calculateZoomFrom方法修改为:

代码语言:javascript
复制
int zoom = mainMap.getZoom();
Rectangle2D inner = generateBoundedRectangleForLine(positionSet, mainMap.getZoom());

int count = 0;
Rectangle outer = mainMap.getViewportBounds();
while(!outer.contains(inner) || (outer.contains(inner) && !(inner.getHeight() >= mainMap.getHeight() - 50))) {
    Point2D center = new Point2D.Double(
            inner.getX() + inner.getWidth()/2,
            inner.getY() + inner.getHeight()/2);
    GeoPosition px = mainMap.getTileFactory().pixelToGeo(center,zoom);
    mainMap.setCenterPosition(px);
    count++;
    if(count > 30) break;
    if(outer.contains(inner)) {
        if (!(inner.getHeight() >= mainMap.getHeight() - 50)) {
            zoom = zoom - 1;
            if(zoom < 1) {
                break;
            }
        } else {
            break;
        }

    } else {
        zoom = zoom + 1;
        if(zoom > 15) {
            break;
        }
    }

    mainMap.setZoom(zoom);
    inner = generateBoundedRectangleForLine(positionSet, zoom);
}

但这是行不通的。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-06-13 06:07:57

我找到了解决办法。解决方案是将缩放级别设置为最低级别,然后调用calculateZoomFrom方法。

票数 2
EN

Stack Overflow用户

发布于 2012-06-09 12:44:29

为此,您可以从您的ActionListener中调用ActionListener

您必须自己计算适当的缩放级别(据我所知,JXMapViewer没有为此提供任何内容)。由于您知道路线点的坐标,计算包围框和设置适当的缩放级别不应该是一个问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10959703

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档