[개발] Programming/Tools

자바스크립트로 퓨전차트 연동 해보기 #1

eatyourKimchi 2020. 2. 24. 18:01

 

FusionChart

 업무를 하다 보면 차트를 사용해야 할 경우가 자주 발생하죠. 특히, 통계나 모니터링 업무를 한다면 더욱더 사용할 수밖에 없는데요. 차트 솔루션 중에서 비교적 연동하기 쉬운 퓨전차트를 한 번 사용해보도록 하겠습니다.

 

* 참고로 퓨전차트는 무료로 사용할 수 있지만, 차트에 워터마크가 남아있습니다. 워터마크를 제거하기 위해서는 라이센스를 구매해야 됩니다.

 

 

 

FusionChart 소스 연동

 퓨전차트의 강점 중 하나는 예제 소스입니다. 사이트에 들어가면 아주 친절하게 개발 언어 별 예제가 있어 연동하기에 좋습니다. 저는 자바 웹 프로젝트를 사용하기 때문에 JS 연동으로 구현해 보겠습니다. 우선 퓨전차트 사이트에 접속합니다.

 

www.fusioncharts.com 

 

 

 

상단에 'Developer' 메뉴를 클릭한 뒤 'FusionCharts'를 선택합니다.

 

 

 

다음 화면에서 Plain JS를 선택합니다.

 

다음으로는 CDN 관련 소스를 헤더에 추가합니다. (직접 라이브러리를 받아도 됨.)

 

1
2
3
4
5
6
<head>
    <!-- Step 1 - Include the fusioncharts core library -->
    <script type="text/javascript" src="https://cdn.fusioncharts.com/fusioncharts/latest/fusioncharts.js"></script>
    <!-- Step 2 - Include the fusion theme -->
    <script type="text/javascript" src="https://cdn.fusioncharts.com/fusioncharts/latest/themes/fusioncharts.theme.fusion.js"></script>
</head>
cs

 

 

이번에는 퓨전차트를 화면단에 출력하는 게 목적이기 때문에 서버단에서 데이터를 호출하는 방법은 다음 포스트에서 소개하겠습니다. 일단 사이트에 나와 있는 데이터로 자바스크립트 객체를 생성합니다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// Preparing the chart data
const chartData = [
  {
    label: "Venezuela",
    value: "290"
  },
  {
    label: "Saudi",
    value: "260"
  },
  {
    label: "Canada",
    value: "180"
  },
  {
    label: "Iran",
    value: "140"
  },
  {
    label: "Russia",
    value: "115"
  },
  {
    label: "UAE",
    value: "100"
  },
  {
    label: "US",
    value: "30"
  },
  {
    label: "China",
    value: "30"
  }
];
cs

 

 

마지막으로 퓨전차트 설정 부분을 추가합니다. 주석이 있어 소스 해석은 어렵지 않습니다.

 

아래 소스는 가장 기본 형태의 컬럼형 차트로 이 외에도 라인, 파이 등 다양한 차트를 무료로 연동할 수 있습니다. 그리고 차트에 옵션도 추가로 설정할 수 있는데, 자세한 건 사이트를 참고하면 됩니다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
// Create a JSON object to store the chart configurations
const chartConfigs = {
  //Specify the chart type
  type: "column2d",
  //Set the container object
  renderAt: "chart-container",
  //Specify the width of the chart
  width: "100%",
  //Specify the height of the chart
  height: "400",
  //Set the type of data
  dataFormat: "json",
  dataSource: {
    chart: {
      //Set the chart caption
      caption: "Countries With Most Oil Reserves [2017-18]",
      //Set the chart subcaption
      subCaption: "In MMbbl = One Million barrels",
      //Set the x-axis name
      xAxisName: "Country",
      //Set the y-axis name
      yAxisName: "Reserves (MMbbl)",
      numberSuffix: "K",
      //Set the theme for your chart
      theme: "fusion"
    },
    // Chart Data from Step 2
    data: chartData
  }
};
cs

 

 

이제 차트를 랜더링하는 소스입니다.

 

위에서 CDN 주소를 추가하고, 객체를 생성한 뒤, 차트 설정 부분을 추가한 걸 모두 포함한 소스입니다. 차트 형태는 컬럼 차트로 다른 형태의 차트는 설정하는 소스가 일부 다르지만 사이트만 참고하면 쉽게 구현 가능합니다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<html>
<head>
<title>My first chart using FusionCharts Suite XT</title>
<!-- Include fusioncharts core library -->
<script type="text/javascript" src="https://cdn.fusioncharts.com/fusioncharts/latest/fusioncharts.js"></script>
<!-- Include fusion theme -->
<script type="text/javascript" src="https://cdn.fusioncharts.com/fusioncharts/latest/themes/fusioncharts.theme.fusion.js"></script>
<script type="text/javascript">
    //STEP 2 - Chart Data
    const chartData = [{
        "label""Venezuela",
        "value""290"
    }, {
        "label""Saudi",
        "value""260"
    }, {
        "label""Canada",
        "value""180"
    }, {
        "label""Iran",
        "value""140"
    }, {
        "label""Russia",
        "value""115"
    }, {
        "label""UAE",
        "value""100"
    }, {
        "label""US",
        "value""30"
    }, {
        "label""China",
        "value""30"
    }];
 
    //STEP 3 - Chart Configurations
    const chartConfig = {
    type: 'column2d',
    renderAt: 'chart-container',
    width: '100%',
    height: '400',
    dataFormat: 'json',
    dataSource: {
        // Chart Configuration
        "chart": {
            "caption""Countries With Most Oil Reserves [2017-18]",
            "subCaption""In MMbbl = One Million barrels",
            "xAxisName""Country",
            "yAxisName""Reserves (MMbbl)",
            "numberSuffix""K",
            "theme""fusion",
            },
        // Chart Data
        "data": chartData
        }
    };
    FusionCharts.ready(function(){
    var fusioncharts = new FusionCharts(chartConfig);
    fusioncharts.render();
    });
 
</script>
</head>
<body>
<div id="chart-container">FusionCharts XT will load here!</div>
</body>
</html>
cs

 

 

 

FusionChart 컬럼형 차트

 위 소스의 결과물은 아래와 같습니다.

 

 

 

 

서버 단에서 호출한 데이터를 차트로 출력하기 위해서는 json 형태로만 잘 담아서 프런트로 넘겨주면 마찬가지로 어렵지 않게 다양한 차트를 구현할 수 있습니다. 이건 다음 포스트에서 다루겠습니다.

 

이렇게 퓨전차트를 사용하는 방법을 다루어봤는데, 연동하기 정말 간단하죠? 차트 종류도 100가지가 넘고 쉬운 예시, 기술 지원도 적극적인 퓨전차트를 추천드리고 이만 글을 마치겠습니다.

 

좋은 하루 되세요.

 

 

- 여러 형태의 퓨전차트 -

 

 

* 다음 포스트: 자바 웹 프로젝트와 퓨전차트 연동 #2 (서버, 프런트)