範囲関数とナビゲーター関数を使用してHighchartsで列範囲グラフを作成する方法は?


90

私は、プロットに要求してい実行履歴タスク Highchartsでは。タスクの実行履歴を水平バーとして表示する必要があります。以下にアップデートとして追加した追加の要件があります。最近、このinvertedオプションがStockChartでサポートされておらず、navigatorrangeSelectorしかStockChartで使用できないことがわかりました。したがって、私はそれらの関数を使用しています。

したがって、要件を達成するために、このjsfiddleの例に似たものを作成し(参照中にどこかにソースが記憶されていないことがわかります)、Pawel Fusのおかげで、前の質問の助けを借りてこのプランカーリンクになりました

混乱を避けるために質問を更新しています

追加要件:

特定の日時範囲実行されたタスクのみを表示します。実行が10回を超えるなど、実行が多すぎる場合は、他のタスクを表示するためにスクロール可能なy軸を使用して、10個のタスクのみを表示する方法が必要です。 問題へのプランカーリンク

上記のプランカーの問題の説明。

上記のプランカーから以下のスクリーンショットを確認すると、時間範囲は12/12/2014 09:32:2612/12/2014 10:32:26であり、m_ARRAYV_SALES_ZIG1_CALL2_VOD__C_OB&を実行したタスクは2つしかありませんm_ZIG2_HCP_MERGE_IB_CN。ただしLILLY_C、この日付範囲内で実行されなかった別のタスクを確認できます。(実際のデータでは、この日付範囲に該当しないこのグラフを乱雑にする10を超えるタスクがあります)

また、右下隅で時間がから09:38にシフトしたことに気づいた場合19:20。タスク19:20の終了時間ですm_ZIG2_HCP_MERGE_IB_CNここに画像の説明を入力してください 以下は私のチャートオプションです

    var chart_options = {
            chart: {
                renderTo: 'container',
                height: 600
            },
            title: {
            },
            credits: {
                enabled: false
            },
            xAxis: {
                type: 'datetime',
                gridLineWidth: 1,
                tickInterval: 1 * 3600 * 1000,
                dateTimeLabelFormats: {
                    month: '%b %e, %Y'
                }
            },
            yAxis: {                    
                tickInterval: 1,
                gridLineWidth: 1,
                labels: {
                    formatter: function() {
                        if (tasks[this.value]) {
                            return tasks[this.value].name;
                        }
                    }
                },
                startOnTick: false,
                endOnTick: false,
                title: {
                    text: 'Task'
                }
            },
            rangeSelector: {
                selected: 0,
                buttons: [ {
                    type: "minute",
                    count: 60,
                    text: "1h"
                }, {
                    type: "minute",
                    count: 180,
                    text: "3h"
                }, {
                    type: "minute",
                    count: 300,
                    text: "5h"
                }],
                inputDateFormat: '%m/%d/%Y %H:%M:%S',
                inputEditDateFormat: '%m/%d/%Y %H:%M:%S',
                inputBoxWidth: 120
            },
            navigator: {
                enabled: false
            },
            legend: {
                enabled: false
            },
            tooltip: {
                shared: false,
                formatter: function() {
                    var str = '';
                    str += 'Task: ' + this.series.name + '<br>';
                    str += 'From: ' + Highcharts.dateFormat('%m/%d/%y %H:%M', this.point.from) + '<br>';
                    str += 'To: ' + Highcharts.dateFormat('%m/%d/%y %H:%M', this.point.to) + '<br>';
                    return str;
                }
            },
            plotOptions: {
                line: {
                    lineWidth: 10,
                    marker: {
                        enabled: true
                    },
                    dataLabels: {
                        enabled: true,
                        align: 'left',
                        formatter: function() {
                            return this.point.options && this.point.options.label;
                        }
                    },
                    states:{
                        hover:{
                            lineWidth:10
                        }
                    }
                },
                series: {
                    cursor: 'pointer',
                    point: {
                        events: {
                            click: function () {
                                var query = '{ "task_id": "'+this.task_id+'","start_time": '+this.from+',"exclude_interval": '+opExcludeMinutes+',"size": 10 }';
                                $scope.taskName = this.series.name;
                                $scope.isTaskSelected = false;
                                $scope.operationalReportAgentTaskHistoryServiceRequest(query);
                            }
                        }
                    }
                }
            },
            series: seriesData
        };

6
状態のホバーでlineWidthを設定します(例:jsfiddle.net/bx2000cb/8
Sebastian Bochan

5
ご存じのとおりHighcharts error #15、データの並べ替えのエラーが原因です。データを割り当てていますが、昇順ではありません。確認してください。多分ダブルチェックが原因です。開発者が何らかの方法でソートされたデータで問題を見つけられないため、これらの問題がたくさん見られます。
Raein Hashemi 2015

4
あなたがしようとしていない場合、あなたは...知らないだろう
パヴェルFuを

4
何の話をしているのかわかりませんが、あのプランカーは本当ですか?この質問は1つの大きな混乱です。まず、グラフを生成するためのコードを読んで理解することをお勧めします。また、私はHighchartsのチュートリアルを読んで、その仕組みを理解することをお勧めします。
パヴェルFuを

1
この範囲を実行すると、2つのタスクが表示されます。
Sebastian Bochan 2015年

回答:


6

だから、数時間掘り下げた後、私は犯人を見つけたばかりです(または私は本当にそう思っています)。問題は、yAxisラベルフォーマッターの定義です。

yAxis: {
  tickInterval: 1,
    gridLineWidth: 1,
    labels: {
    formatter: function() { // THIS IS THE PROBLEM
      if (tasks[this.value]) {
        return tasks[this.value].name;
      }
    }
  },
  startOnTick: false,
    endOnTick: false,
    title: {
    text: 'Task'
  }
},

に従ってラベルを表示する必要があるかどうかは実際には確認しませんtask.intervals(を参照json.js)。フォーマッタの簡単な更新(Plunker)が機能するようです:

  yAxis: {
    tickInterval: 1,
    gridLineWidth: 1,
    labels: {
      formatter: function () {
        console.log("scripts.js - yAxis.labels.formatter", this.value);
        if (tasks[this.value]) {

          //if (tasks[this.value].name === 'LILLY_C') {
            var _xAxis = this.chart.axes[0];
            var _task = tasks[this.value];
            var _show = false;

            // Not optimized for large collections
            for (var _i = 0; _i < _task.intervals.length; _i++) {
              var _int = _task.intervals[_i];
              if (_xAxis.min <= _int.to) {
                _show = true;
              }
            }

            console.log("scripts.js - yAxis.labels.formatter",
              tasks[this.value].name,
              _show,
              _xAxis.min,
              _xAxis.max,
              _task.intervals
            );

            if (_show) {
              return tasks[this.value].name;
            } else {
              return;
            }
          //}

          //return tasks[this.value].name;
        }
      }
    },
    startOnTick: false,
    endOnTick: false,
    title: {
      text: 'Task'
    }
  },

デモはPlunkerを参照してください。

yAxisラベルの意味は次のとおりです。 グラフにランが表示される場合、またはグラフの右側にランがある場合は、ラベルを表示します。条件を変更してください

if (_xAxis.min <= _int.to) {

あなたが合うと思うように。

免責事項:私はHighchartsを使用しないので、この回答は問題を説明するためのものであり、Highchartsによる問題解決の方法を提案するものではありません。


学んだ教訓:

  • yaxis-plugin.js 問題とは無関係です。
  • Highstock.jsはオープンソースライブラリhighstock.src.js)です。元のソースコードをデバッグすると、デバッグがはるかに簡単になります。コードを縮小すると、不必要な複雑さと推測が追加されます。ライブラリをダウンロードし、console.log()何が起こっているのかを確認するためにいくつか追加しました。
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.