3

Google Charts API を使用してダッシュボードを作成しようとしています。

ダッシュボードには、ChartRangeFilter タイプの ControlWrapper と 2 つの ChartWrapper (LineChart および Table) が含まれています。このセットアップは問題なく機能していますが、もう 1 つ追加したいと思います。

LineChart はデータセット全体を表示し、Table はその一部のみを表示します。たとえば、10 行あり、テーブルには最初の 8 行のみを表示する必要があります。

これは私の現在の ControlWrapper です:

control = new google.visualization.ControlWrapper({
 'controlType': 'ChartRangeFilter',
 'containerId': 'control',
 'options': {
   'filterColumnIndex': 0,
   'ui': {
     'chartType': 'LineChart',
     'chartOptions': {
       'chartArea': {'width': '95%'},
       'hAxis': {'baselineColor': 'none'}
     },
     'chartView': {
       'columns': [0,1]
     },
     'minRangeSize': 86400000
   }
 }
});

そして、これはテーブルです:

chart = new google.visualization.ChartWrapper({
 'chartType': 'Table',
 'containerId': 'table',
 'options': {
        width: 470, 
        height: 340, 
        sortColumn: 0,
        sortAscending: false
 },
 'view': {
   'columns': [0, 1]
   //,'rows': [0,1,2,3,4,5,6]
 }
});

テーブル定義の行 "//,'rows': [0,1,2,3,4,5,6]" のコメントを外すと、ControlWrapper のスライダーを動かすとエラーが発生します。

Invalid row index 6. Should be in the range [0-5]

これを機能させる方法はありますか?

その理由は、(この例では) 最後の 2 行は列 3 のデータのみであり、これは LineChart にのみ表示され、テーブルには表示されないためです。

前もって感謝します!

//編集:

以下はページの例です: http://circlecount.com/test.chart.range.php

コードは次のとおりです。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.1//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-2.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" version="XHTML+RDFa 1.1" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.w3.org/1999/xhtml http://www.w3.org/MarkUp/SCHEMA/xhtml-rdfa-2.xsd" lang="de" xml:lang="de" dir="ltr" xmlns:og="http://ogp.me/ns#" >
<head>
  <script src="http://www.google.com/jsapi?key=" type="text/javascript"></script> 
  <script type="text/javascript">google.load("jquery", "1.7.1");</script>
 </head>
<body>
<script type="text/javascript">

// Load the Visualization API and the piechart package.
google.load('visualization', '1.0', {'packages':['corechart', 'table', 'controls']});

// Set a callback to run when the Google Visualization API is loaded.
google.setOnLoadCallback(fctDrawChart);

var control, chart;

function fctDrawChart() {
  //follower
  var data = new google.visualization.DataTable();
  var myTempDate = new Date();
  data.addColumn('date', 'Day');
  data.addColumn('number', 'Followers');


data.addRows(10);
data.setCell(0, 0, new Date('11/07/2011'));
data.setCell(0, 1, 11);
data.setCell(1, 0, new Date('11/08/2011'));
data.setCell(1, 1, 222);
data.setCell(2, 0, new Date('11/09/2011'));
data.setCell(2, 1, 1242);
data.setCell(3, 0, new Date('11/10/2011'));
data.setCell(3, 1, 1420);
data.setCell(4, 0, new Date('11/11/2011'));
data.setCell(4, 1, 1609);
data.setCell(5, 0, new Date('11/12/2011'));
data.setCell(5, 1, 1676);
data.setCell(6, 0, new Date('11/13/2011'));
data.setCell(6, 1, 1734);
data.setCell(7, 0, new Date('11/14/2011'));
data.setCell(7, 1, 1773);
data.setCell(8, 0, new Date('11/15/2011'));
data.setCell(8, 1, 1857);
data.setCell(9, 0, new Date('11/16/2011'));
data.setCell(9, 1, 1874);


var dataView = new google.visualization.DataView(data);
dataView.setColumns([0, 1]);



    var dashboard = new google.visualization.Dashboard(document.getElementById('dashboard'));

    control = new google.visualization.ControlWrapper({
     'controlType': 'ChartRangeFilter',
     'containerId': 'control',
     'options': {
       'filterColumnIndex': 0,
       'ui': {
         'chartType': 'LineChart',
         'chartOptions': {
           'chartArea': {'width': '95%'},
           'hAxis': {'baselineColor': 'none'}
         },
         'chartView': {
           'columns': [0,1]
         },
         'minRangeSize': 86400000
       }
     }
    });

    google.visualization.events.addListener(control, 'statechange', function() {
      $("#periodSelector").val("custom");
    });



    chart = new google.visualization.ChartWrapper({
     'chartType': 'Table',
     'containerId': 'table',
     'options': {
            width: 470, 
            height: 340, 
            sortColumn: 0,
            sortAscending: false
     },
     'view': {
       'columns': [0, 1]
       ,'rows': [0,1,2,3,4,5,6]
     }
    });

    chart2 = new google.visualization.ChartWrapper({
     'chartType': 'LineChart',
     'containerId': 'chart',
     'options': {
            width: 470, 
            height: 340, 
            sortColumn: 0,
            sortAscending: false
     },
     'view': {
       'columns': [0, 1]
     }
    });

    dashboard.bind(control, chart);
    dashboard.bind(control, chart2);
    dashboard.draw(data);

  }


</script>
  <div id='dashboard' >
    <div id='table' style='width:240px;height:400px;'></div>
    <div id='chart' style='width:240px;height:400px;'></div>
    <div id='control' style='width:840px;height:40px;'></div>
  </div>
</div>


</body>
</html>

私が取得したいもの: - 全期間 (10 日間) にわたるチャート - 最初の 7 日間のみのテーブル - 全期間 (10 日間) にわたる ControlWrapper、チャートとテーブルを制御する

それが私の問題をより明確にすることを願っています。そうでない場合は、メモをください。

前もって感謝します!

更新: jmac のアイデアにより、次の関数で動作するようになりました。

google.visualization.events.addListener(control, 'statechange',
  function(event) {
    if (control.getState()["range"]["end"] > myLastRealDate) {
      var myRowsArr = new Array();
      var myTempDate = control.getState()["range"]["start"];
      for (var i=0;i<myLastRealRow-(myDateArr[(myTempDate.getMonth()+1)+"/"+myTempDate.getDate()+"/"+myTempDate.getFullYear()]);i++) {
        myRowsArr.push(i);
      }
      chart.setView({'rows': myRowsArr});
    }
    else {
      chart.setView({'rows': null});
    }
  });

ここで実際の例を見つけることができます: http://circlecount.com/test.chart.range.php

4

2 に答える 2

1

この問題は、次の関数で解決できます。

google.visualization.events.addListener(control, 'statechange',
  function(event) {
    if (control.getState()["range"]["end"] > myLastRealDate) {
      var myRowsArr = new Array();
      var myTempDate = control.getState()["range"]["start"];
      for (var i=0;i<myLastRealRow-(myDateArr[(myTempDate.getMonth()+1)+"/"+myTempDate.getDate()+"/"+myTempDate.getFullYear()]);i++) {
        myRowsArr.push(i);
      }
      chart.setView({'rows': myRowsArr});
    }
    else {
      chart.setView({'rows': null});
    }
  }
);

行の数は、日付ごとに配列に保存する必要があります。次に例を示します。

myDateArr['11/7/2011'] = 0;

「休憩」の行と日付も変数に保存する必要があります。

myLastRealDate = new Date('11/14/2011');
myLastRealRow = 7;

これが実際の例です: http://circlecount.com/test.chart.range.php

于 2013-05-14T14:40:50.287 に答える