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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? simplecolorgenerator.java

?? openmap java寫的開源數(shù)字地圖程序. 用applet實現(xiàn),可以像google map 那樣放大縮小地圖.
?? JAVA
字號:
// **********************************************************************// // <copyright>// //  BBN Technologies//  10 Moulton Street//  Cambridge, MA 02138//  (617) 873-8000// //  Copyright (C) BBNT Solutions LLC. All rights reserved.// // </copyright>// **********************************************************************// // $Source: /cvs/distapps/openmap/src/openmap/com/bbn/openmap/omGraphics/grid/SimpleColorGenerator.java,v $// $RCSfile: SimpleColorGenerator.java,v $// $Revision: 1.3.2.2 $// $Date: 2005/12/22 18:42:48 $// $Author: dietrick $// // **********************************************************************package com.bbn.openmap.omGraphics.grid;import com.bbn.openmap.omGraphics.OMGraphic;import com.bbn.openmap.omGraphics.OMGrid;import com.bbn.openmap.omGraphics.OMRaster;import com.bbn.openmap.omGraphics.SinkGraphic;import com.bbn.openmap.proj.Projection;import com.bbn.openmap.util.Debug;/** * The SimpleColorGenerator is an OMGridGenerator that creates an OMRaster out * of OMGrid data. The OMgrid data is assumed to be color ARGB integer values. * Each pixel is colored according to the closest grid data point value. */public class SimpleColorGenerator implements OMGridGenerator {    /**     * Going to return an OMRaster, sized to the current projection, and colored     * according to the colortable. The grid values are indexes into the     * colortable. The grid should already be generated when it gets here -     * meaning that the bounds and parameters of the grid, as they apply to the     * projection, are figured out.     *      * @param grid the grid to create a raster for.     * @param proj description of the map.     */    public OMGraphic generate(OMGrid grid, Projection proj) {        Debug.message("grid",                "SimpleColorGenerator: generating OMRaster from grid");        if (grid.height <= 0 || grid.width <= 0) {            Debug.message("grid",                    "SimpleColorGenerator: grid height/width ZERO!");            return SinkGraphic.getSharedInstance();        }        OMRaster raster = new OMRaster(grid.point1.x, grid.point1.y, grid.width, grid.height, new int[grid.width                * grid.height]);        int rows = grid.getRows();        int columns = grid.getColumns();        RasterHelper rasterHelper = getRasterHelper(grid.getData());        boolean major = grid.getMajor();        /** lat and lon_intervals are grid point/pixel.. */        double y_interval = (double) rows / (double) grid.height;        double x_interval = (double) columns / (double) grid.width;        Debug.message("grid", "SimpleColorGenerator: y_point_interval = "                + y_interval + ", x_point_interval = " + x_interval);        /**         * Right now, if the rendertype of the grid is RENDERTYPE_LATLON, we         * limit sensible rendering to the CADRG/LLXY projections. No warping         * done.         */        int post_x, post_y, value;        /** Do this pixel by pixel. */        for (int x = 0; x < grid.width; x++) {            for (int y = 0; y < grid.height; y++) {                post_x = (int) Math.round(x_interval * (double) x);                if (grid.getRenderType() == OMGraphic.RENDERTYPE_LATLON) {                    post_y = (int) Math.round(y_interval                            * (grid.height - 1 - (double) y));                } else {                    post_y = (int) Math.round(y_interval * (double) y);                }                if (major == OMGrid.COLUMN_MAJOR) {                    if (post_x >= columns)                        post_x = columns - 1;                    if (post_y >= rows)                        post_y = rows - 1;                    value = calibratePointValue(rasterHelper.get(post_x, post_y));                } else {                    if (post_y >= columns)                        post_y = columns - 1;                    if (post_x >= rows)                        post_x = rows - 1;                    value = calibratePointValue(rasterHelper.get(post_y, post_x));                }                raster.setPixel(x, y, value);            }        }        raster.generate(proj);        return raster;    }    /**     * Takes the value assigned to a pixel, as determined by it's location in     * the grid, and gives a color to paint the pixel. In this case, the grid     * point value IS the color value.     *      * @param source a grid point value assigned to the raster pixel.     * @return the ARGB to color the pixel.     */    public int calibratePointValue(int source) {        return source;    }    /**     * We at least need one generate for XY and OFFSET grids. We will need a     * generate every time the projection changes for LATLON rendertype grids.     * So return true for everything.     */    public boolean needGenerateToRender() {        return true;    }    /**     * This method creates a set of greyscale colors. It isn't used in this     * class (SimpleColorGenerator), but it probably will be used in extended     * classes.     *      * @param num_colors the number of greys needed.     * @param opaqueness how clear the color should be (0-255, where 0 is     *        clear).     * @return an array of color ARGB integers.     */    public int[] createGreyscaleColors(int num_colors, int opaqueness) {        int[] tempColors = new int[num_colors];        if (num_colors == 0) {            num_colors = 216;        }        int grey_interval = 256 / num_colors;        for (int i = 0; i < num_colors; i++) {            if (i == 0) {                tempColors[i] = ((opaqueness & 0xFF) << 24)                        | ((191 & 0xFF) << 16) | ((239 & 0xFF) << 8)                        | ((255 & 0xFF));            }            else {                int color = (i * grey_interval) + (grey_interval / 2);                tempColors[i] = ((opaqueness & 0xFF) << 24)                        | ((color & 0xFF) << 16) | ((color & 0xFF) << 8)                        | ((color & 0xFF));            }        }        return tempColors;    }    protected RasterHelper getRasterHelper(GridData gd) {        if (gd instanceof GridData.Short) {            return new ShortRasterHelper(((GridData.Short) gd).getData());        } else if (gd instanceof GridData.Int) {            return new IntRasterHelper(((GridData.Int) gd).getData());        } else if (gd instanceof GridData.Float) {            return new FloatRasterHelper(((GridData.Float) gd).getData());        } else if (gd instanceof GridData.Byte) {            return new ByteRasterHelper(((GridData.Byte) gd).getData());        } else if (gd instanceof GridData.Char) {            return new CharRasterHelper(((GridData.Char) gd).getData());        }        return new DoubleRasterHelper(((GridData.Double) gd).getData());    }    protected interface RasterHelper {        public int get(int x, int y);    }    protected class IntRasterHelper implements RasterHelper {        int[][] data;        public IntRasterHelper(int[][] intData) {            data = intData;        }        public int get(int x, int y) {            return data[x][y];        }    }    protected class ShortRasterHelper implements RasterHelper {        short[][] data;        public ShortRasterHelper(short[][] intData) {            data = intData;        }        public int get(int x, int y) {            return data[x][y];        }    }    protected class ByteRasterHelper implements RasterHelper {        byte[][] data;        public ByteRasterHelper(byte[][] intData) {            data = intData;        }        public int get(int x, int y) {            return data[x][y];        }    }    protected class FloatRasterHelper implements RasterHelper {        float[][] data;        public FloatRasterHelper(float[][] intData) {            data = intData;        }        public int get(int x, int y) {            return (int) data[x][y];        }    }    protected class DoubleRasterHelper implements RasterHelper {        double[][] data;        public DoubleRasterHelper(double[][] intData) {            data = intData;        }        public int get(int x, int y) {            return (int) data[x][y];        }    }    protected class CharRasterHelper implements RasterHelper {        char[][] data;        public CharRasterHelper(char[][] intData) {            data = intData;        }        public int get(int x, int y) {            return data[x][y];        }    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩一区二区在线观看视频| 日韩精品一区二| 91香蕉视频污在线| 99热在这里有精品免费| 国产成人av福利| 国产一区二区看久久| 久久国产精品72免费观看| 久久国产精品无码网站| 免费美女久久99| 欧美精品成人一区二区三区四区| 色婷婷av一区二区三区之一色屋| 99热这里都是精品| 在线亚洲一区二区| 欧美体内she精高潮| 欧美在线免费播放| 欧美麻豆精品久久久久久| 欧美日韩高清不卡| 欧美一区二区福利视频| 精品国产免费视频| 中文字幕不卡在线播放| 国产精品理论片在线观看| 亚洲天堂精品视频| 亚洲777理论| 日本不卡在线视频| 国产成人av电影在线| 91丨九色丨蝌蚪丨老版| 在线免费亚洲电影| 日韩一区二区免费在线电影| 欧美成人一区二区| 中文字幕精品一区| 国产精品久久久久aaaa| 一区二区在线观看免费| 天堂在线一区二区| 国产最新精品精品你懂的| 粉嫩aⅴ一区二区三区四区 | 色哟哟精品一区| 欧洲视频一区二区| 3d动漫精品啪啪一区二区竹菊| 欧美一级免费观看| 久久精品一区八戒影视| 综合自拍亚洲综合图不卡区| 亚洲bt欧美bt精品| 国产成人福利片| 精品视频999| 久久亚洲影视婷婷| 亚洲私人黄色宅男| 偷拍与自拍一区| 国产精品正在播放| 色综合久久天天| 日韩一区二区三区精品视频| 国产精品国产馆在线真实露脸| 亚洲一区二区3| 国产做a爰片久久毛片| 色婷婷久久综合| 2023国产精品自拍| 亚洲制服丝袜av| 国产91精品免费| 欧美日韩国产经典色站一区二区三区| 久久久精品蜜桃| 香蕉成人伊视频在线观看| 国产精品一色哟哟哟| 91国内精品野花午夜精品| 日韩精品一区二区在线| 亚洲欧洲另类国产综合| 性久久久久久久久久久久| 国内不卡的二区三区中文字幕| 色一情一伦一子一伦一区| 精品久久久三级丝袜| 亚洲影视在线播放| 粉嫩在线一区二区三区视频| 欧美日韩夫妻久久| 国产精品久久毛片a| 美腿丝袜亚洲色图| 欧美日韩精品欧美日韩精品一综合 | 欧美日韩中文字幕一区二区| 国产人久久人人人人爽| 久久精品噜噜噜成人av农村| 欧美在线色视频| 1000精品久久久久久久久| 国产精品99久久久久久久vr| 国产精品一线二线三线精华| 日本不卡免费在线视频| 色噜噜久久综合| 国产女同互慰高潮91漫画| 麻豆91精品视频| 91老司机福利 在线| 国产亚洲欧美在线| 久久精品二区亚洲w码| 欧美日韩亚洲综合| 中文字幕在线一区二区三区| 激情六月婷婷综合| 欧美xxxxxxxxx| 免费观看一级特黄欧美大片| 在线观看一区日韩| 中文字幕一区三区| 成人理论电影网| 久久久蜜桃精品| 麻豆精品在线看| 欧美精品在线视频| 午夜精品一区在线观看| 一区二区三区91| 日韩三区在线观看| 欧美猛男超大videosgay| 97se亚洲国产综合自在线不卡 | 激情文学综合网| 欧美大白屁股肥臀xxxxxx| 五月婷婷综合在线| 欧美日韩免费一区二区三区| 一区二区激情小说| 日本丶国产丶欧美色综合| 亚洲精品成人精品456| 91丨porny丨在线| 一二三四区精品视频| 在线观看视频欧美| 五月天激情综合网| 欧美一区二区啪啪| 免费在线观看视频一区| 欧美一区二区视频观看视频| 秋霞午夜av一区二区三区| 欧美一级理论性理论a| 蜜桃视频一区二区三区 | 一区二区三区在线不卡| 在线视频国内一区二区| 亚洲成av人在线观看| 在线播放欧美女士性生活| 美女高潮久久久| 欧美精品一区二区三区蜜臀| 国产精品18久久久久| 日韩美女久久久| 欧美亚洲一区二区在线观看| 香蕉久久一区二区不卡无毒影院| 91精品国产aⅴ一区二区| 国产精品一区二区在线观看不卡| 国产精品青草综合久久久久99| 色哟哟精品一区| 老司机精品视频在线| 国产欧美日韩久久| 在线亚洲一区二区| 久久99久国产精品黄毛片色诱| 欧美国产精品一区二区三区| 日本精品一区二区三区高清| 天堂精品中文字幕在线| 国产亚洲1区2区3区| 在线免费观看视频一区| 免费欧美在线视频| 亚洲私人黄色宅男| 日韩美一区二区三区| 成人av免费在线| 日韩va亚洲va欧美va久久| 国产亚洲综合av| 欧美色综合久久| 国产一区二区毛片| 亚洲午夜电影网| 精品成人私密视频| 在线一区二区视频| 欧美xingq一区二区| 成人国产精品免费观看| 亚洲电影在线播放| 欧美国产日韩a欧美在线观看| 欧美日韩在线免费视频| 国产在线观看免费一区| 亚洲综合一区在线| 久久久久久97三级| 欧美日韩一区二区三区在线看| 国产精华液一区二区三区| 日韩国产欧美在线视频| 亚洲欧美日韩国产一区二区三区| 日韩欧美国产综合| 在线免费观看日本欧美| 国产91精品免费| 亚洲成人av在线电影| 精品久久久久99| 91欧美一区二区| 裸体一区二区三区| 中文字幕在线不卡一区二区三区 | 久久影音资源网| 91免费观看在线| 久久99精品久久久| 亚洲精品中文字幕在线观看| 精品国产乱码久久久久久图片 | 国产午夜精品福利| 欧美日免费三级在线| 高清国产一区二区三区| 美女视频黄频大全不卡视频在线播放| 亚洲欧美日韩一区| 国产精品传媒在线| 国产网红主播福利一区二区| 亚洲国产婷婷综合在线精品| 国产精品视频免费看| 欧美日韩精品电影| 欧美亚洲另类激情小说| 99综合电影在线视频| 国产成人亚洲综合a∨婷婷图片| 美日韩一级片在线观看| 日本午夜一区二区| 日韩精品久久理论片| 色婷婷狠狠综合| 日本久久电影网| 欧美无砖专区一中文字| 91官网在线免费观看|