zoukankan      html  css  js  c++  java
  • Echarts markPoint 动态数据添加,选择性查询

    效果图:






    function
    GetData() { var placeList = [ // {name:'海门', geoCoord:[121.15, 31.89]} ] var year =document.getElementById("year").value; var provinceid =document.getElementById("sheng").value; var quota_1 =document.getElementById("quota_1").value; var quota_2 =document.getElementById("quota_2").value; var quota_3 =document.getElementById("quota_3").value; var quota_4 =document.getElementById("quota_4").value; var index = ""; if(quota_1 != ""){index = quota_1}; if(quota_2 != ""){index = quota_2}; if(quota_3 != ""){index = quota_3}; if(quota_4 != ""){index = quota_4}; $.ajax({ url:"./EnterpriseAnalysisFetcher.do?action=envmapdata", type:"POST", dataType:"JSON", async:false, data:{"year":year,"provinceid":provinceid, "index":index}, success: function(json){ placeList = json; } });
    /**麻点图数据
         * @param request
         * @param response
         * @throws Exception
         */
        private void getEnvMapblackData(HttpServletRequest request,
                HttpServletResponse response) throws Exception {
            
            EnvDataMiniManager envDataMiniManager = (EnvDataMiniManager)Context.getBean(EnvDataMiniManager.class);
            
            int provinceid = getInt(request, "provinceid", 0);
            int year = getInt(request, "year", 0);
            String index = get(request, "index", "");
            
            MarkPoint[] dataMinis = envDataMiniManager.getMarkPointEnvData(year, provinceid, index, null);
            
            output(JSONArray.toJSONString(dataMinis), response);
            //System.out.println(dataMinis);
        }
    
    
    
    
    
    public MarkPoint[] getMarkPointEnvData(int year, int provinceid,
                String index,DBSession session) throws JException {
            
            List<MarkPoint> list = new ArrayList<MarkPoint>();
            if (session == null) {
                session = Context.getDBSession();
            }
            IResultSet rs = null;
            try {
                Object[] paramObjects = new Object[]{};
                int[] paramTypes = new int[]{};
                String sql = "select b.cp_region, b.cp_lng,b.cp_lat from env_pollutiondata a,env_company b  where a.pd_company_ID=b.ID and "+index+">0 ";
                if(year>0){
                    sql = sql + " and a.pd_year =?";
                }
                if(provinceid>0){
                    sql = sql + " and a.pd_Province_ID =?";
                }
                if(year>0&&provinceid>0){
                    paramObjects = new Object[]{year,provinceid};
                    paramTypes = new int[]{year,provinceid};
                }else if(year>0){
                    paramObjects = new Object[]{year};
                    paramTypes = new int[]{year};
                }else if(provinceid>0){
                    paramObjects = new Object[]{provinceid};
                    paramTypes = new int[]{provinceid};
                }
                sql = sql+" GROUP BY a.pd_company_ID ";
                System.out.println(sql);
                //sql = "SELECT * FROM env_pollutiondata WHERE ID = 1";
                
                //rs = session.executeQuery(sql, new Object[]{paramObjects}, new int[]{Types.DECIMAL});
                rs = session.executeQuery(sql, paramObjects, paramTypes);
                System.out.println(sql);
                while (rs.next()) {
                    MarkPoint mark = new MarkPoint();
                    mark.setName(rs.getString("cp_region"));
                    mark.setGeoCoord(new float[]{rs.getFloat("cp_lng"),rs.getFloat("cp_lat")});
                    list.add(mark);
                }
            } catch (Exception e) {
                Logger.getProjLogger().error(e.getMessage(), e);
                return null;
            } finally {
                ResourceMgr.closeQuietly(rs);
                ResourceMgr.closeQuietly(session);
            }
            return list.toArray(new MarkPoint[0]);
        }
    
    
    
    
             require(
                        [
                            'echarts',
                            'echarts/chart/bar' ,// 使用柱状图就加载bar模块,按需加载
                            'echarts/chart/map'
                        ],
                        function (ec) {
                            
                            // 基于准备好的dom,初始化echarts图表
                            var myChart = ec.init(document.getElementById('container1')); 
                            var option = {
                                 backgroundColor: '#1b1b1b',
                                  color: [
                                                'rgba(255, 255, 255, 0.8)',
                                                'rgba(14, 241, 242, 0.8)',
                                                'rgba(37, 140, 249, 0.8)'
                                          ],
                
                              title : {
                                text: '大规模MarkPoint特效',
                               /*  subtext: '纯属虚构', */
                                x:'center',
                                textStyle : { color: '#fff'  }  },
                              legend: {
                                    orient: 'vertical',
                                    x:'left',
                                    data:['强','中','弱'],
                                    textStyle : {color: '#fff'} },
                series : [
                    { name: '弱',type: 'map', mapType: 'china',
                        itemStyle:{
                            normal:{  borderColor:'rgba(100,149,237,1)', borderWidth:1.5, areaStyle:{color: '#1b1b1b' }
                                      }
                     },
                       data : [],
                       markPoint : { symbolSize: 2, large: true,
                       effect: { show: true },
                       data : (function(){
                                var data = [];
                                var len = 3000;
                                var geoCoord
                                
                                while(len--) {
                                    geoCoord = placeList[len % placeList.length].geoCoord;
                                    data.push({
                                        name : placeList[len % placeList.length].name + len,
                                        value : 10,
                                        geoCoord : [
                                            geoCoord[0] + Math.random() * 5 - 2.5,
                                            geoCoord[1] + Math.random() * 3 - 1.5
                                                        ] })
                                            }
                                return data;
                            })()//data
                            
                        }//markPoint
                    },
                    {
                        name: '中',
                        type: 'map',
                        mapType: 'china',
                        data : [],
                        markPoint : {
                            symbolSize: 3,
                            large: true,
                            effect : {
                                show: true
                            },
                            data : (function(){
                                var data = [];
                                var len = 1000;
                                var geoCoord
                                while(len--) {
                                    geoCoord = placeList[len % placeList.length].geoCoord;
                                    data.push({
                                        name : placeList[len % placeList.length].name + len,
                                        value : 50,
                                        geoCoord : [
                                            geoCoord[0] + Math.random() * 5 - 2.5,
                                            geoCoord[1] + Math.random() * 3 - 1.5
                                        ]
                                    })
                                }
                                return data;
                            })()
                        }
                    },
                    {
                        name: '强',
                        type: 'map',
                        mapType: 'china',
                        hoverable: false,
                        roam:true,
                        data : [],
                        markPoint : {
                            symbol : 'diamond',
                            symbolSize: 6,
                            large: true,
                            effect : {
                                show: true
                            },
                            data : (function(){
                                var data = [];
                                var len = placeList.length;
                                while(len--) {
                                    data.push({
                                        name : placeList[len].name,
                                        value : 90,
                                        geoCoord : placeList[len].geoCoord
                                    })
                                }
                                return data;
                            })()
                        }
                    }
                    ]//series
                
                  };
                            
                            // 为echarts对象加载数据 
                            myChart.setOption(option); 
                        }
                    );         
  • 相关阅读:
    【洛谷 P4166】 [SCOI2007]最大土地面积(凸包,旋转卡壳)
    专题
    【洛谷 P3299】 [SDOI2013]保护出题人 (凸包,三分,斜率优化)
    【洛谷 P3628】 [APIO2010]特别行动队 (斜率优化)
    $POJ1995$ $Raising$ $Modulo$ $Numbers$
    快速运算模板(未完待续)
    $Luogu$ $P1879$ $[USACO06NOV]$ 玉米田 $Corn Fields$
    [转载] $AT2444$ 题解
    [转载] $CF117B$ 题解
    [转载] $CF543B$ 题解
  • 原文地址:https://www.cnblogs.com/xiaoxiao5ya/p/4770353.html
Copyright © 2011-2022 走看看