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

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

?? mapservice.java

?? 轉載 本部分內容的代碼
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
      }
    }
    if(title.lastIndexOf(".")!=-1) title=title.substring(0,title.lastIndexOf(".")+1);
    else title="";
    return title;
  }

  /**
   * 添加 SubFields
   * @param subfields 輸入格式="id,objectid,name"
   * @param lyr FeatureLayer
   * @param filter Filter
   */
  public void addSubFields(String subfields,FeatureLayer lyr,com.esri.aims.mtier.model.map.layer.query.Filter filter){
    if(subfields==null) return;
    String[] fds = subfields.split(",");
    if (fds.length > 0) {
      String title=getFieldTitle(lyr.getRecordset().getTableDesc());
      for (int k = 0; k < fds.length; k++) {
         String fdd=fds[k].trim();
         if(fdd.lastIndexOf(".")==-1) fdd=title+fdd;
         if (checkSubField(lyr,fdd)) {
          filter.addSubField(fdd);
        }
      }
    }
  }

  /**
   * 返回 subFields
   * @param lyr FeatureLayer
   * @return Vector
   */
  protected Vector getSubFields(FeatureLayer lyr) {
    Vector<String> fds = new Vector<String>();
    Recordset rst = lyr.getRecordset();
    String str = null;
    if (lyr.getFilterObject().getSubFieldsCount() != 0) {
      for (int j = 0; j < lyr.getFilterObject().getSubFieldsCount(); j++){
        str = lyr.getFilterObject().getSubField(j);
        fds.add(str.substring(str.lastIndexOf(".")+1,str.length()));
      }
    }else{
      for (int i = 0; i < rst.getTableDesc().getCount(); i++) {
        str = rst.getTableDesc().getFieldName(i);
        fds.add(str.substring(str.lastIndexOf(".")+1,str.length()));
      }
    }
    return fds;
  }

  /**
   * 創建空間查詢的幾何圖形
   * @param ptXY 輸入格式="x1,y1,x2,y2"
   * @param filterType String
   * @return Shape
   */
  public Shape createShape(String ptXY, String filterType) {
    try{
      if (ptXY != null) {
        String[] pts = ptXY.split(",");
        Point pnt = new Point();
        Points pnts = new Points();
        Geometry gy = new Geometry();
        for (int i = 0; i < pts.length; i = i + 2) {
          pnt.setX(DoubleConversion.stringToDouble(pts[i]));
          pnt.setY(DoubleConversion.stringToDouble(pts[i + 1]));
          pnts.addPointObject(pnt);
        }
        Point p1 = pnts.getPointObject(0);
        Point p2 = pnts.getPointObject(pnts.getCount() - 1);
        if (p1.getX() != p2.getX() || p1.getY() != p2.getY()) {
          pnts.addPointObject(p1);
        }
        gy.setPoints(pnts);

        if (filterType.equalsIgnoreCase(ConfigService.FILTER_TYPE_POINT)) {
          Envelope shape = new Envelope();
          shape.setMaxX(DoubleConversion.stringToDouble(pts[0]) + dis);
          shape.setMaxY(DoubleConversion.stringToDouble(pts[1]) + dis);
          shape.setMinX(DoubleConversion.stringToDouble(pts[0]) - dis);
          shape.setMinY(DoubleConversion.stringToDouble(pts[1]) - dis);
          return shape;
        }
        else if (filterType.equalsIgnoreCase(ConfigService.FILTER_TYPE_LINE)) {
          Line ln = gy.createLine(pnts);
          setDisplaySymbol("line");
          ln.setSymbol(lineSymbol);
          return ln;
        }
        else if (filterType.equalsIgnoreCase(ConfigService.FILTER_TYPE_POLY) ||
                 filterType.equalsIgnoreCase(ConfigService.FILTER_TYPE_CIRCLE)) {
          Ring rg = gy.createRing(pnts);
          Hole hole = new Hole();
          hole.setPoints(pnts);
          rg.addHoles(hole);
          Polygon poly = gy.createPolygonObject(rg);
          setDisplaySymbol("polygon");
          poly.setSymbol(polySymbol);
          return poly;
        }
        else if (filterType.equalsIgnoreCase(ConfigService.FILTER_TYPE_RECT)) {
          Envelope env = new Envelope();
          if (DoubleConversion.stringToDouble(pts[0]) >
              DoubleConversion.stringToDouble(pts[2])) {
            env.setMaxX(DoubleConversion.stringToDouble(pts[0]));
            env.setMinX(DoubleConversion.stringToDouble(pts[2]));
          }
          else {
            env.setMaxX(DoubleConversion.stringToDouble(pts[2]));
            env.setMinX(DoubleConversion.stringToDouble(pts[0]));
          }
          if (DoubleConversion.stringToDouble(pts[1]) >
              DoubleConversion.stringToDouble(pts[3])) {
            env.setMaxY(DoubleConversion.stringToDouble(pts[1]));
            env.setMinY(DoubleConversion.stringToDouble(pts[3]));
          }
          else {
            env.setMaxY(DoubleConversion.stringToDouble(pts[3]));
            env.setMinY(DoubleConversion.stringToDouble(pts[1]));
          }
          return env;
        }
        else {
          return null;
        }
      }
      else {
        return null;
      }
    }catch(Exception ex){
      return null;
    }
  }

  /**
   * 是否需要連接其他表
   * @param isJoinTab boolean
   */
  public void isJoinTable(boolean isJoinTab){
    isJoin=isJoinTab;
  }

  /**
   * 設置連接表參數
   * @param orignTabName 當前表名
   * @param joinTabName 連接表名
   * @param colName 連接表字段
   */
  public void setJoinTableParam(String orignTabName,String joinTabName,String colName){
    orignTableName=orignTabName;
    joinTableName=joinTabName;
    joinColName=colName;
  }

  /**
   * 設置連接表
   * @param flyr FeatureLayer
   * @param filter Filter
   */
  public void setFilterJoinTable(FeatureLayer lyr,com.esri.aims.mtier.model.map.layer.query.Filter filter){
    try{
      String str = orignTableName + "." + joinColName + "=" + joinTableName + "." + joinColName;
      filter.setJoinExpression(str);
      filter.setJoinTable(joinTableName);
    }catch(Exception ex){
      System.out.println(ex);
    }
  }

  /**
   * 空間查詢或屬性查詢
   * @param layerId 要查詢的圖層ID
   * @param shape 由createShape函數創建
   * @param subfields 輸入格式="id,objectid,name"
   * @param whereClause 屬性查詢SQL語句,輸入格式="objectid=3"
   * @param isExtent 查詢的要素集是否顯示在視野范圍內
   */
  public void filterShape(String layerId, Shape shape, String subfields, String whereClause, boolean isExtent) {
    setActiveFeatureLayer(layerId);
    if (flyr != null) {
      com.esri.aims.mtier.model.map.layer.query.Filter filter = new com.esri.aims.mtier.model.map.layer.query.Filter();
      addSubFields(subfields,flyr,filter);

      filter.setGlobalEnvelope(true);
      filter.setCheckesc(true);
      filter.setRelation(Filter.ENVELOPE_INTERSECTION);
      if(whereClause!=null) filter.setWhereExpression(whereClause);
      if(shape!=null) filter.setSpatialShape(shape);

      //join table
      if(isJoin){
        setFilterJoinTable(flyr,filter);
      }

      flyr.setFilterObject(filter);
      imsmap.refresh();

      if (filterMap == null) {
        filterMap = new HashMap();
      }
      filterMap.clear();
      filterMap.put(ConfigService.HASHMAP_SUBFIELDS_VECTOR, getSubFields(flyr));
      filterMap.put(ConfigService.HASHMAP_RECORDSET_RS, flyr.getRecordset());

      if (isExtent) {
        setFilterExtent(flyr.getRecordset());
      }

      setDisplaySymbol(flyr.getFeatureClass());
      if (flyr.getFeatureClass().equalsIgnoreCase("point")) {
        imsmap.displayFeatures(flyr, false, markSymbol);
      }
      if (flyr.getFeatureClass().equalsIgnoreCase("line")) {
        imsmap.displayFeatures(flyr, false, lineSymbol);
      }
      if (flyr.getFeatureClass().equalsIgnoreCase("polygon")) {
        imsmap.displayFeatures(flyr, false, polySymbol);
      }

    }
  }

  /**
   * 設置 BufferLayerId
   * @param targetId BufferLayerId
   * @return BufferFeatureLayer
   */
  public FeatureLayer setBufferLayerId(String targetId) {
    FeatureLayer lyr = null;
    for (int i = 0; i < getLayerCount(); i++) {
      if (imsmap.getLayers().item(i).getID().equalsIgnoreCase(targetId)) {
        if (imsmap.getLayers().item(i) instanceof FeatureLayer) {
          lyr = (FeatureLayer) imsmap.getLayers().item(i);
          bufferLayerId = imsmap.getLayers().item(i).getID();
          break;
        }
      }
    }
    return lyr;
  }

  /**
   * 獲取 BufferLayerId
   * @return String
   */
  public String getBufferLayerId() {
    return bufferLayerId;
  }

  /**
   * Buffer 分析
   * @param layerId ActiveFeatureLayerId
   * @param targetId BufferLayerId
   * @param distance Buffer distance
   * @param unit 單位
   * @param targetFields 輸入格式="id,name"
   * @param whereClause 查詢SQL
   * @param isExtent 查詢的要素集是否顯示在視野范圍內
   */
  public void filterBuffer(String layerId, String targetId, double distance,String unit,String targetFields,String whereClause, boolean isExtent) {
 
  }

  /**
   * 返回查詢結果
   * @return HashMap
   */
  public HashMap getFilterMap() {
    return filterMap;
  }

  /**
   * 返回緩沖區分析查詢結果
   * @return HashMap
   */
  public HashMap getBufferMap() {
    return bufferMap;
  }

  /**
   * 專題地圖
   * @param layerId String
   * @param chartFields 數字型字段,輸入格式="jg,yg"
   * @param chartType "bar"或者"pie"
   */
  public void makeChart(String layerId,String chartFields,String chartType) throws
      Exception {
	    try {
	        setActiveFeatureLayer(layerId);
	        imsmap.getSeparators().setCS(",");

	        //join table
	        if(isJoin){
	          com.esri.aims.mtier.model.map.layer.query.Filter filter = new com.esri.aims.mtier.model.map.layer.query.Filter();
	          //filter.setCheckesc(true);
	          //filter.setGlobalEnvelope(true);
	          //filter.setRelation(filter.ENVELOPE_INTERSECTION);

	          setFilterJoinTable(flyr,filter);
	          flyr.setFilterObject(filter);
	          imsmap.refresh();
	        }

	        GroupRenderer gr = new GroupRenderer();
	        SimpleLabelRenderer slr = new SimpleLabelRenderer();
	        String chartfds[] = chartFields.split(",");
	        long size = (chartfds.length) * chartSize;
	        ChartSymbol chartSymbol = new ChartSymbol();
	        chartSymbol.setMode(chartType);
	        chartSymbol.setSize(size);
	        for (int i = 0; i < chartfds.length; i++) {
	          ChartValue chartValue = new ChartValue();
	          chartValue.setColor(chartColors[i % 6]);
	          chartValue.setLookUpField(chartfds[i]);
	          chartSymbol.addChartValue(chartValue);
	        }
	        slr.setSymbol(chartSymbol);
	        slr.setField(chartFields);
	        gr.addRenderer(slr);
	        flyr.setRenderer(gr);

	      }catch(Exception ex){
	        throw new Exception(ex);
	      }
  }


}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
黄色精品一二区| 亚洲国产日韩av| av电影天堂一区二区在线| 中文字幕在线不卡一区| 色婷婷香蕉在线一区二区| 天天色综合天天| 久久蜜桃av一区精品变态类天堂 | 亚洲黄一区二区三区| 欧洲一区二区av| 蜜桃av一区二区三区电影| 国产亚洲欧美一级| 色综合天天综合网国产成人综合天| 亚洲线精品一区二区三区| 日韩欧美国产综合在线一区二区三区| 国产乱码字幕精品高清av| 亚洲欧美综合在线精品| 欧美日韩国产综合久久| 国产美女在线精品| 亚洲永久免费av| 精品欧美一区二区三区精品久久 | 欧美日韩高清一区二区三区| 久久99精品久久久| 中文字幕日本不卡| 日韩欧美国产综合一区| 91亚洲精品乱码久久久久久蜜桃| 奇米777欧美一区二区| 国产精品视频免费| 欧美一级久久久| 97se亚洲国产综合自在线观| 另类小说色综合网站| 亚洲欧洲综合另类在线| 久久久久久毛片| 欧美美女视频在线观看| 不卡一区在线观看| 精品一区二区久久久| 一区二区在线观看免费视频播放| 欧美成人vr18sexvr| 欧美色涩在线第一页| 国产成人免费视频精品含羞草妖精| 亚洲一区二区三区四区中文字幕| 国产亚洲精品资源在线26u| 欧美精品久久久久久久多人混战 | 丝袜美腿亚洲色图| 国产精品国产自产拍高清av王其 | 成人av综合在线| 激情五月激情综合网| 视频精品一区二区| 一区二区三区四区在线播放| 国产欧美精品区一区二区三区| 7777精品伊人久久久大香线蕉超级流畅| 懂色av一区二区三区免费观看 | 国产尤物一区二区在线| 日一区二区三区| 亚洲最大成人网4388xx| 国产精品国产三级国产普通话三级 | 91精品国产色综合久久 | 欧美午夜宅男影院| 91视频一区二区| 成人av先锋影音| 国产福利电影一区二区三区| 美女性感视频久久| 免费成人在线影院| 日韩电影免费在线看| 丝袜亚洲另类欧美| 亚洲6080在线| 丝袜美腿一区二区三区| 午夜免费久久看| 日韩成人免费看| 蜜臀av一区二区在线免费观看 | 国产福利不卡视频| 国产乱码精品一区二区三区五月婷| 美女视频黄 久久| 男人的天堂亚洲一区| 麻豆国产欧美一区二区三区| 久久99精品久久久久婷婷| 蜜乳av一区二区| 激情综合色播激情啊| 国产精品一卡二卡| 成年人国产精品| 色噜噜狠狠成人中文综合| 欧美性极品少妇| 欧美精品粉嫩高潮一区二区| 欧美一二三区精品| 日韩精品中文字幕一区二区三区 | 国产精品午夜电影| 中文字幕一区av| 亚洲精品网站在线观看| 亚洲自拍另类综合| 麻豆久久久久久久| 国产精品一区二区久激情瑜伽| 国产成人aaa| 在线精品视频免费播放| 欧美精品高清视频| 久久综合av免费| 日韩美女久久久| 日韩在线一二三区| 国产精品99久久久久久久vr| 99久久er热在这里只有精品66| 欧美三级电影网站| 日韩精品一区二区三区视频在线观看 | 午夜私人影院久久久久| 另类小说欧美激情| 成人性生交大合| 欧美色涩在线第一页| 久久免费美女视频| 一级女性全黄久久生活片免费| 日本不卡一二三| 成人伦理片在线| 91麻豆精品国产91久久久久久久久 | 国产一区三区三区| 色综合久久久久综合99| 欧美第一区第二区| 亚洲欧美另类图片小说| 麻豆91在线观看| 不卡在线视频中文字幕| 日韩欧美综合一区| 亚洲手机成人高清视频| 久久电影网站中文字幕| 日本高清成人免费播放| 久久色.com| 日韩中文欧美在线| 一本色道久久加勒比精品| 欧美成人aa大片| 天天综合网天天综合色| av成人动漫在线观看| 欧美tickle裸体挠脚心vk| 樱花草国产18久久久久| 懂色av一区二区在线播放| 日韩一级片网站| 亚洲综合色在线| 99国内精品久久| 久久久一区二区三区捆绑**| 日韩中文字幕亚洲一区二区va在线 | 久久毛片高清国产| 日韩一区精品字幕| 91麻豆免费看片| 国产精品美女久久久久aⅴ| 全部av―极品视觉盛宴亚洲| 在线精品视频小说1| 国产精品欧美久久久久一区二区| 久久99蜜桃精品| 欧美人与性动xxxx| 亚洲精品v日韩精品| 成人激情校园春色| 亚洲精品在线观看网站| 免费成人美女在线观看.| 欧美性猛片xxxx免费看久爱| 1000精品久久久久久久久| 成人免费毛片片v| 欧美国产一区在线| 国产精品69久久久久水密桃| 日韩欧美国产系列| 青青草视频一区| 91精品国产综合久久精品app| 亚洲国产中文字幕| 欧美三级午夜理伦三级中视频| 一区二区在线免费观看| 色综合夜色一区| 亚洲综合激情网| 色综合天天在线| 亚洲六月丁香色婷婷综合久久 | 亚洲国产高清在线观看视频| 国产精品系列在线观看| 久久精品亚洲国产奇米99| 国产精品原创巨作av| 欧美经典一区二区三区| 懂色av一区二区三区免费观看| 欧美激情一区二区三区蜜桃视频| 国产盗摄精品一区二区三区在线| 久久久久国产精品人| 国产成人高清视频| 国产精品污www在线观看| 99在线精品观看| 亚洲色图19p| 欧美三级视频在线播放| 热久久久久久久| 26uuu亚洲综合色欧美 | 亚洲日穴在线视频| 在线精品视频一区二区三四| 丝袜美腿亚洲综合| 欧美精品一区二区三区蜜臀 | 一片黄亚洲嫩模| 日韩三级视频在线观看| 国产一区视频网站| **性色生活片久久毛片| 欧美日韩黄视频| 九九热在线视频观看这里只有精品| 久久综合色婷婷| 99re这里都是精品| 丝瓜av网站精品一区二区| 日韩一区二区三区免费看| 国产白丝网站精品污在线入口| 亚洲美腿欧美偷拍| 欧美一级日韩不卡播放免费| 国产成人亚洲精品狼色在线| 亚洲激情综合网| 精品国产1区二区| 色呦呦网站一区| 激情综合色丁香一区二区| 亚洲乱码国产乱码精品精小说|