亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? editableomrect.java

?? openmap java寫的開源數字地圖程序. 用applet實現,可以像google map 那樣放大縮小地圖.
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
                    if (renderType == OMGraphic.RENDERTYPE_LATLON) {                        doStraight = false;                        top = (int) p.getY();                        left = (int) p.getX();                        gpnw.set((int) p.getX(), (int) p.getY());                        p = projection.forward(slat, elon);                        gpse.set((int) p.getX(), (int) p.getY());                        p = projection.forward(nlat, elon);                        gpne.set((int) p.getX(), (int) p.getY());                        p = projection.forward(slat, wlon);                        gpsw.set((int) p.getX(), (int) p.getY());                        p = projection.forward(nlat - (nlat - slat) / 2f, wlon                                + (elon - wlon) / 2f);                        gpc.set((int) p.getX(), (int) p.getY());                    } else {                        latoffset = (int) p.getY();                        lonoffset = (int) p.getX();                        gpo.set(lonoffset, latoffset);                    }                }            }            if (doStraight) {                Debug.message("eomg",                        "EditableOMRect: drawing straight line rectangle");                top = rect.getTop() + latoffset;                bottom = rect.getBottom() + latoffset;                right = rect.getRight() + lonoffset;                left = rect.getLeft() + lonoffset;                // We have to do some fancy point wrangling to keep                // from messing up the next setGrabPoints().                if (movingPoint == gpc || movingPoint == gpo                        || movingPoint == null) {                    gpne.set(right, top);                    gpnw.set(left, top);                    gpse.set(right, bottom);                    gpsw.set(left, bottom);                } else if (movingPoint == gpnw) {                    gpne.set(gpse.getX(), gpnw.getY());                    gpsw.set(gpnw.getX(), gpse.getY());                } else if (movingPoint == gpse) {                    gpne.set(gpse.getX(), gpnw.getY());                    gpsw.set(gpnw.getX(), gpse.getY());                } else if (movingPoint == gpsw) {                    gpnw.set(gpsw.getX(), gpne.getY());                    gpse.set(gpne.getX(), gpsw.getY());                } else if (movingPoint == gpne) {                    gpnw.set(gpsw.getX(), gpne.getY());                    gpse.set(gpne.getX(), gpsw.getY());                }                int middlex = (right - left) / 2;                int middley = (bottom - top) / 2;                gpc.set(left + middlex, top + middley);                gpc.updateOffsets();                //              Debug.output("Center setting x: " + gpc.getX() + ",                // y:" + gpc.getY());            }            if (renderType == OMGraphic.RENDERTYPE_OFFSET) {                gpo.updateOffsets();            }        } else {            Debug.message("eomg",                    "EditableOMRect.setGrabPoints: graphic needs to be regenerated");        }    }    /**     * Take the current location of the GrabPoints, and modify the     * location parameters of the OMRect with them. Called when you     * want the graphic to change according to the grab points.     */    public void setGrabPoints() {        int renderType = rect.getRenderType();        LatLonPoint llp1;        Debug.message("eomg", "EditableOMRect.setGrabPoints()");        // Do center point for lat/lon or offset rects        if (renderType == OMGraphic.RENDERTYPE_LATLON) {            if (projection != null) {                // Need to figure out which point was moved, and then                // set the upper left and lower right points                // accordingly.                if (movingPoint == gpne) {                    llp1 = projection.inverse(gpne.getX(), gpne.getY());                    rect.lat1 = llp1.getLatitude();                    rect.lon2 = llp1.getLongitude();                } else if (movingPoint == gpnw) {                    llp1 = projection.inverse(gpnw.getX(), gpnw.getY());                    rect.lat1 = llp1.getLatitude();                    rect.lon1 = llp1.getLongitude();                } else if (movingPoint == gpsw) {                    llp1 = projection.inverse(gpsw.getX(), gpsw.getY());                    rect.lat2 = llp1.getLatitude();                    rect.lon1 = llp1.getLongitude();                } else if (movingPoint == gpse) {                    llp1 = projection.inverse(gpse.getX(), gpse.getY());                    LatLonPoint llp2 = projection.inverse(gpnw.getX(),                            gpnw.getY());                    rect.lat1 = llp2.getLatitude();                    rect.lon1 = llp2.getLongitude();                    rect.lat2 = llp1.getLatitude();                    rect.lon2 = llp1.getLongitude();                } else {                    //movingPoint == gpc                    llp1 = projection.inverse(gpc.getX(), gpc.getY());                    rect.lat1 = llp1.getLatitude() + diffy;                    rect.lon1 = llp1.getLongitude() - diffx;                    rect.lat2 = llp1.getLatitude() - diffy;                    rect.lon2 = llp1.getLongitude() + diffx;                }                rect.setNeedToRegenerate(true);            }        }        boolean settingOffset = getStateMachine().getState() instanceof GraphicSetOffsetState                && movingPoint == gpo;        // If the center point is moving, the offset distance changes        if (renderType == OMGraphic.RENDERTYPE_OFFSET) {            llp1 = projection.inverse(gpo.getX(), gpo.getY());            rect.lat1 = llp1.getLatitude();            rect.lon1 = llp1.getLongitude();            if (settingOffset || movingPoint == gpc) {                int halfheight = (gpse.getY() - gpnw.getY()) / 2;                int halfwidth = (gpse.getX() - gpnw.getX()) / 2;                // Don't call rect.setLocation because we only want to                // setNeedToRegenerate if !settingOffset.                rect.x1 = gpc.getX() - halfwidth - gpo.getX();                rect.y1 = gpc.getY() - halfheight - gpo.getY();                rect.x2 = gpc.getX() + halfwidth - gpo.getX();                rect.y2 = gpc.getY() + halfheight - gpo.getY();            }            if (!settingOffset) {                Debug.message("eomg", "EditableOMRect: updating offset rect");                if (movingPoint == gpnw || movingPoint == gpse) {                    rect.setLocation(gpnw.getX() - gpo.getX(), gpnw.getY()                            - gpo.getY(), gpse.getX() - gpo.getX(), gpse.getY()                            - gpo.getY());                } else if (movingPoint == gpne || movingPoint == gpsw) {                    rect.setLocation(rect.x1 = gpsw.getX() - gpo.getX(),                            gpne.getY() - gpo.getY(),                            gpne.getX() - gpo.getX(),                            gpsw.getY() - gpo.getY());                }                rect.setNeedToRegenerate(true);            }            // Set Location has reset the rendertype, but provides            // the convenience of setting the max and min values            // for us.            rect.setRenderType(OMGraphic.RENDERTYPE_OFFSET);        }        // Do the rect height and width for XY and OFFSET render        // types.        if (renderType == OMGraphic.RENDERTYPE_XY) {            Debug.message("eomg", "EditableOMRect: updating x/y rect");            if (movingPoint == gpc) {                int halfheight = (gpse.getY() - gpnw.getY()) / 2;                int halfwidth = (gpse.getX() - gpnw.getX()) / 2;                rect.setLocation(gpc.getX() - halfwidth, gpc.getY()                        - halfheight, gpc.getX() + halfwidth, gpc.getY()                        + halfheight);            } else if (movingPoint == gpnw || movingPoint == gpse) {                rect.setLocation(gpnw.getX(),                        gpnw.getY(),                        gpse.getX(),                        gpse.getY());            } else if (movingPoint == gpne || movingPoint == gpsw) {                rect.setLocation(gpsw.getX(),                        gpne.getY(),                        gpne.getX(),                        gpsw.getY());            }        }        if (projection != null) {            regenerate(projection);        }    }    /**     * Called to set the OffsetGrabPoint to the current mouse     * location, and update the OffsetGrabPoint with all the other     * GrabPoint locations, so everything can shift smoothly. Should     * also set the OffsetGrabPoint to the movingPoint. Should be     * called only once at the beginning of the general movement, in     * order to set the movingPoint. After that, redraw(e) should just     * be called, and the movingPoint will make the adjustments to the     * graphic that are needed.     */    public void move(java.awt.event.MouseEvent e) {}    /**     * Use the current projection to place the graphics on the screen.     * Has to be called to at least assure the graphics that they are     * ready for rendering. Called when the graphic position changes.     *      * @param proj com.bbn.openmap.proj.Projection     * @return true     */    public boolean generate(Projection proj) {        Debug.message("eomgdetail", "EditableOMRect.generate()");        if (rect != null)            rect.generate(proj);        for (int i = 0; i < gPoints.length; i++) {            GrabPoint gp = gPoints[i];            if (gp != null) {                gp.generate(proj);            }        }        return true;    }    /**     * Given a new projection, the grab points may need to be     * repositioned off the current position of the graphic. Called     * when the projection changes.     */    public void regenerate(Projection proj) {        Debug.message("eomg", "EditableOMRect.regenerate()");        if (rect != null)            rect.regenerate(proj);        setGrabPoints(rect);        generate(proj);    }    /**     * Draw the EditableOMRect parts into the java.awt.Graphics     * object. The grab points are only rendered if the rect machine     * state is RectSelectedState.RECT_SELECTED.     *      * @param graphics java.awt.Graphics.     */    public void render(java.awt.Graphics graphics) {        Debug.message("eomgdetail", "EditableOMRect.render()");        State state = getStateMachine().getState();        if (rect != null) {            rect.setVisible(true);            rect.render(graphics);            rect.setVisible(false);        } else {            Debug.message("eomg", "EditableOMRect.render: null rect.");        }        int renderType = rect.getRenderType();        if (state instanceof GraphicSelectedState                || state instanceof GraphicEditState) {            for (int i = 0; i < gPoints.length; i++) {                GrabPoint gp = gPoints[i];                if (gp != null) {                    if ((i == OFFSET_POINT_INDEX                            && renderType == OMGraphic.RENDERTYPE_OFFSET && movingPoint == gpo)                            ||                            (state instanceof GraphicSelectedState && ((i != OFFSET_POINT_INDEX && renderType != OMGraphic.RENDERTYPE_OFFSET) || (renderType == OMGraphic.RENDERTYPE_OFFSET)))                    ) {                        gp.setVisible(true);                        gp.render(graphics);                        gp.setVisible(false);                    }                }            }        }    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩亚洲综合在线 | 亚洲一区二区免费视频| 亚洲精品中文在线观看| 奇米888四色在线精品| 成人免费毛片片v| 日韩一区二区三| 亚洲女厕所小便bbb| 精油按摩中文字幕久久| 欧美自拍偷拍一区| 久久久久亚洲蜜桃| 亚洲国产岛国毛片在线| 久久99精品国产麻豆婷婷洗澡| 97se亚洲国产综合在线| 久久蜜桃av一区二区天堂| 亚洲香蕉伊在人在线观| 99久久99精品久久久久久| 国产午夜亚洲精品羞羞网站| 久久精品免费观看| 欧美日韩国产乱码电影| 一区二区三区四区在线播放| 国产99久久精品| 久久午夜国产精品| 国内精品在线播放| 日韩三区在线观看| 午夜精品久久久久久久蜜桃app| 91丝袜美女网| 一区二区三区日韩欧美精品| 91首页免费视频| 成人免费在线观看入口| 国产一区欧美二区| 精品日韩99亚洲| 久久成人免费网| 日韩免费成人网| 久久国产剧场电影| 精品少妇一区二区三区日产乱码 | 亚洲影视资源网| 一本色道久久加勒比精品| 中文字幕乱码日本亚洲一区二区 | 91久久精品午夜一区二区| 中文字幕一区二区三| gogo大胆日本视频一区| 亚洲天堂网中文字| 91久久精品日日躁夜夜躁欧美| 亚洲黄色免费网站| 欧美蜜桃一区二区三区| 轻轻草成人在线| 欧美videossexotv100| 国产成a人亚洲精品| 亚洲欧美电影一区二区| 欧美日韩一区不卡| 韩日欧美一区二区三区| 中文字幕精品一区| 在线观看视频一区| 奇米色777欧美一区二区| 久久老女人爱爱| 97se狠狠狠综合亚洲狠狠| 亚洲一区二区视频在线观看| 日韩一区二区三区免费看| 国产成人8x视频一区二区 | 97精品国产露脸对白| 亚洲成人免费看| 久久精品夜色噜噜亚洲a∨| 99热这里都是精品| 懂色一区二区三区免费观看| 亚洲一区二区免费视频| 欧美成人vps| 99国产欧美另类久久久精品 | 亚洲欧美偷拍另类a∨色屁股| 欧美无砖砖区免费| 久久99国产精品麻豆| 国产精品视频yy9299一区| 欧美日韩国产综合一区二区三区| 狠狠色丁香婷综合久久| 亚洲欧美综合色| 精品国产网站在线观看| 在线视频你懂得一区二区三区| 麻豆视频观看网址久久| 136国产福利精品导航| 欧美一区二区三区视频在线观看| 丰满少妇久久久久久久| 蜜臀久久99精品久久久画质超高清| 国产精品青草久久| 精品免费99久久| 欧美日韩二区三区| 91免费版在线| 国产黄色精品网站| 青青青伊人色综合久久| 亚洲综合免费观看高清完整版在线 | 婷婷中文字幕一区三区| 亚洲国产精华液网站w| 日韩免费看的电影| 91麻豆精品国产91久久久久| 色综合久久99| av不卡一区二区三区| 久久99国产精品尤物| 日韩在线一区二区三区| 亚洲精品视频一区| 亚洲视频一二三区| 国产精品第一页第二页第三页| 久久亚洲二区三区| 精品奇米国产一区二区三区| 欧美日韩激情一区二区| 欧美日韩亚洲不卡| 欧美亚洲图片小说| 欧美综合欧美视频| 欧美色视频一区| 欧美男同性恋视频网站| 欧美日韩在线播放| 欧美日韩成人一区二区| 欧美精品日韩精品| 欧美日韩国产美女| 91精品国产综合久久精品性色| 欧美精品色一区二区三区| 欧美日韩国产影片| 制服丝袜亚洲色图| 91精品在线麻豆| 日韩欧美www| 久久久91精品国产一区二区精品| 久久精品综合网| 国产精品美女久久久久久2018| 国产精品妹子av| 亚洲色图在线看| 亚洲成精国产精品女| 天天av天天翘天天综合网| 三级在线观看一区二区| 老司机精品视频线观看86| 国产精品一品视频| 成人黄动漫网站免费app| 97精品久久久午夜一区二区三区| 一本久道中文字幕精品亚洲嫩| 欧美三级三级三级爽爽爽| 欧美久久久久久久久中文字幕| 日韩一区二区精品| 久久精品一区蜜桃臀影院| 亚洲日本电影在线| 亚洲自拍欧美精品| 蜜臀av一区二区| 成人视屏免费看| 欧美一a一片一级一片| 欧美一区二区三区不卡| 久久影院视频免费| 亚洲欧美国产高清| 美国三级日本三级久久99| 国产福利精品一区二区| 91久久人澡人人添人人爽欧美| 欧美男男青年gay1069videost| 26uuu色噜噜精品一区二区| 中文字幕亚洲在| 免费观看日韩电影| 一本久道中文字幕精品亚洲嫩 | 免费高清在线视频一区·| 粉嫩久久99精品久久久久久夜| 欧美色视频在线观看| 久久一区二区三区四区| 一级日本不卡的影视| 国产真实乱子伦精品视频| 97se狠狠狠综合亚洲狠狠| 日韩欧美激情一区| 一区二区三区不卡视频| 狠狠色2019综合网| 一本大道久久a久久综合婷婷| 日韩欧美国产成人一区二区| 一区二区三区不卡视频| 国产69精品久久久久毛片| 制服丝袜国产精品| 亚洲精品欧美专区| 高清不卡在线观看av| 日韩欧美一级二级| 亚洲电影视频在线| 91欧美激情一区二区三区成人| 精品乱人伦小说| 日韩av中文在线观看| 91久久精品一区二区三| 国产精品美女久久久久久久久| 美美哒免费高清在线观看视频一区二区 | 欧美日韩亚洲综合一区| 中文字幕一区二区在线观看| 国产一区二区网址| 日韩欧美亚洲一区二区| 亚洲午夜电影网| 91老师片黄在线观看| 欧美成人国产一区二区| 爽爽淫人综合网网站| 欧美网站一区二区| 亚洲美女免费视频| 91麻豆免费看| 国产精品成人免费| 成人深夜视频在线观看| 中文字幕欧美激情一区| 国产一区二区三区免费| 精品国产乱码久久久久久夜甘婷婷| 日韩制服丝袜av| 欧美一三区三区四区免费在线看| 亚洲一区成人在线| 欧美日韩在线三级| 日韩电影在线免费看| 91精品国产色综合久久| 蜜桃视频在线观看一区| 精品国产1区二区| 日本美女视频一区二区|