Echarts-echart和springMVC實現堆棧圖(讀取JSON檔案資料)

來源:互聯網
上載者:User

Echarts-echart和springMVC實現堆棧圖(讀取JSON檔案資料)

這篇echarts的堆棧圖主要是根據這篇D3.js堆棧圖(http://blog.csdn.net/u013147600/article/details/46770415 )實現的。

1.JSON檔案資料:

 

{name:某市2005-1010年利潤情況,product:[{ name: PC ,   sales: [{ year:2005, profit: 3000 },{ year:2006, profit: 1300 },{ year:2007, profit: 3700 },{ year:2008, profit: 4900 },{ year:2009, profit: 700 },{ year:2010, profit: 700 }] },{ name: SmartPhone ,   sales: [{ year:2005, profit: 2000 },{ year:2006, profit: 4000 },{ year:2007, profit: 1810 },{ year:2008, profit: 6540 },{ year:2009, profit: 2820 },{ year:2010, profit: 1000 }] },{ name: Software ,   sales: [{ year:2005, profit: 1100 },{ year:2006, profit: 1700 },{ year:2007, profit: 1680 },{ year:2008, profit: 4000 },{ year:2009, profit: 4900 },{ year:2010, profit: 700 }] }]}

 

 

2.根據JSON檔案建立的執行個體類

Domain.java

 

package com.entity;/** * @author lyx * * 2015-7-7上午11:09:19 * *springechart.com.entity.Product */public class Domain {private String name;private Product product;public String getName() {return name;}public void setName(String name) {this.name = name;}public Product getProduct() {return product;}public void setProduct(Product product) {this.product = product;}}

Product.java
package com.entity;/** * @author lyx * * 2015-7-7上午11:10:11 * *springechart.com.entity.Sales */public class Product {private String name;private Sales sale;public String getName() {return name;}public void setName(String name) {this.name = name;}public Sales getSale() {return sale;}public void setSale(Sales sale) {this.sale = sale;}}
Sales.java

 

 

package com.entity;/** * @author lyx * * 2015-7-7下午2:10:54 * *springechart.com.entity.Profit */public class Sales {private String year;private int profit;public String getYear() {return year;}public void setYear(String year) {this.year = year;}public int getProfit() {return profit;}public void setProfit(int profit) {this.profit = profit;}}

 

2.服務層代碼:

 

EchartsT.java

 

package com.service;import java.io.File;import java.io.FileNotFoundException;import java.lang.reflect.Array;import java.util.ArrayList;import java.util.List;import java.util.Scanner;import com.alibaba.fastjson.JSON;import com.alibaba.fastjson.JSONArray;import com.alibaba.fastjson.JSONObject;import com.entity.China;import com.entity.Domain;import com.entity.Sales;import com.entity.Provinces;import com.entity.Product;import com.github.abel533.echarts.Label;import com.github.abel533.echarts.Option;import com.github.abel533.echarts.Title;import com.github.abel533.echarts.axis.CategoryAxis;import com.github.abel533.echarts.axis.ValueAxis;import com.github.abel533.echarts.code.LineType;import com.github.abel533.echarts.code.Magic;import com.github.abel533.echarts.code.MarkType;import com.github.abel533.echarts.code.Orient;import com.github.abel533.echarts.code.PointerType;import com.github.abel533.echarts.code.SelectedMode;import com.github.abel533.echarts.code.Tool;import com.github.abel533.echarts.code.Trigger;import com.github.abel533.echarts.code.X;import com.github.abel533.echarts.code.Y;import com.github.abel533.echarts.data.Data;import com.github.abel533.echarts.data.PointData;import com.github.abel533.echarts.feature.MagicType;import com.github.abel533.echarts.series.Bar;import com.github.abel533.echarts.series.Funnel;import com.github.abel533.echarts.series.Line;import com.github.abel533.echarts.series.Map;import com.github.abel533.echarts.series.MapLocation;import com.github.abel533.echarts.series.Pie;import com.github.abel533.echarts.style.ItemStyle;import com.github.abel533.echarts.style.LineStyle;import com.google.gson.JsonArray;/** * @author lyx * * 2015-6-12下午1,34,50 * *springechart.com.service.EchartsT */public class EchartsT {       /**     * 讀取json檔案     */    public String jsonRead(String fullFileName)    {            File file = new File(fullFileName);        Scanner scanner = null;        StringBuilder buffer = new StringBuilder();        try {            scanner = new Scanner(file, utf-8);            while (scanner.hasNextLine()) {                buffer.append(scanner.nextLine());            }         } catch (FileNotFoundException e) {            // TODO Auto-generated catch block          System.out.println(e);        } finally {            if (scanner != null) {                scanner.close();            }        }         //返回字串        return buffer.toString();    }            /**     * @return     * 堆棧圖     */    public Option stackYear()    {    //Json檔案所在的路徑    String fullFileName=E:/java/java code/Project/springechart/WebRoot/year.json;        //調用讀取檔案函數    String data = jsonRead(fullFileName);        //把字串轉換成Json對象    JSONObject obj =JSON.parseObject(data);    //提取json檔案裡面product對應的數組並儲存為Json數組    JSONArray proArr = obj.getJSONArray(product);        //擷取用例說明名稱    String legendName[] = new String[proArr.size()];    for (int i = 0; i < proArr.size(); i++) {    //根據name獲得JOSN數組中的名稱    legendName[i]=proArr.getJSONObject(i).getString(name);}        //PC資料    //根據sales獲得JOSN數組    JSONArray pcArr =JSON.parseArray(proArr.getJSONObject(0).getString(sales).toString());    //把JSON數組儲存為List列表    List pcList = JSON.parseArray(pcArr.toString(), Sales.class);    //計算資料行表大小    int length =pcList.size();    //儲存 年份數組    String[] pcYear =new String[length];    //儲存 利潤數組    int[] pcProfit = new int[length];    //獲得資料 儲存在數組中    for (int i = 0; i  spList =JSON.parseArray(spArr.toString(), Sales.class);        String[] spYear =new String[length];    int[] spProfit = new int[length];        for (int i = 0; i  swList =JSON.parseArray(swArr.toString(), Sales.class);        String[] swYear =new String[length];    int[] swProfit = new int[length];        for (int i = 0; i 

 

 

3.控制層代碼:

 

echartsContr.java

 

package com.controller;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import com.alibaba.fastjson.JSON;import com.github.abel533.echarts.Option;import com.service.EchartsT;/** * @author lyx * * 2015-6-12下午1:36:51 * *springechart.com.controller.echartsContr */@Controller@RequestMapping(/echarts)public class echartsContr {EchartsT ech = new EchartsT();/** * @param res * @return * 堆棧圖 */@RequestMapping(stackYear)public String stackYear(HttpServletRequest res){//調用服務層的函數並儲存傳回值Option option=ech.stackYear();//通過json裝換成字串String opt =JSON.toJSONString(option);//將對象傳入到jsp頁面res.setAttribute(option, opt);return /ec;}}

 

4.jsp頁面代碼:

 

ec.jsp

 

<%@ page language=java import=java.util.* pageEncoding=UTF-8%><%String path = request.getContextPath();String basePath = request.getScheme()+://+request.getServerName()+:+request.getServerPort()+path+/;%>
<script type=text/javascript src=../js/jquery-1.11.3.min.js></script> 
<script type=text/javascript src=../js/jquery-1.11.3.min.js></script> 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.