পরিসীমা এবং নেভিগেটর ফাংশনগুলি ব্যবহার করে হাইচার্টগুলিতে কীভাবে একটি কলাম রেঞ্জ চার্ট তৈরি করবেন?


90

হাইচার্টে কোনও টাস্কের ইতিহাস চালানোর জন্য আমার প্রয়োজন have এটি কাজগুলির একটি অনুভূমিক বার হিসাবে চালানোর ইতিহাস দেখানো দরকার। অতিরিক্ত প্রয়োজনীয়তা রয়েছে যা আমি নীচে আপডেট হিসাবে যুক্ত করেছি। সম্প্রতি আমি জানতে পেরেছি যে স্টকচার্টে বিকল্পটি সমর্থিত নয় এবং স্টকচার্টে কেবল ন্যাভিগেটর এবং রেঞ্জসিলিটর উপলব্ধ। সুতরাং আমি এই ফাংশন ব্যবহার করছি।inverted

তাই যাতে প্রয়োজন আমি অনুরূপ কিছু সৃষ্টি অর্জন করার জন্য এই jsfiddle উদাহরণ (পাওয়া কোথাও যখন ব্রাউজিং উৎস মনে করতে পারছি না) এবং সঙ্গে শেষ পর্যন্ত এই plunker লিংক আমার আগের সহায়তায় প্রশ্ন , ধন্যবাদ Pawel Fus

বিভ্রান্তি এড়াতে প্রশ্ন আপডেট করা

অতিরিক্ত আবশ্যক:

দেখান কেবলমাত্র সেই কর্ম যা দৌড়ে একটি বিশেষ তারিখ এবং সময় সীমার । যদি খুব বেশি রান হয় যেমন 10 টিরও বেশি রান, তবে কেবলমাত্র 10 টি কার্যকে y-axis সহ দৃশ্যমানভাবে প্রদর্শন করার একটি উপায় থাকা দরকার যা অন্যান্য কাজগুলি দেখানোর জন্য স্ক্রোলযোগ্য। সমস্যার প্লাঙ্কার লিঙ্ক

উপরের প্লাঙ্কারের সমস্যা ব্যাখ্যা।

যদি আপনি উপরের প্লঙ্কার থেকে নীচে স্ক্রিনশটটি পরীক্ষা করে থাকেন তবে সময়সীমাটি এর থেকে 12/12/2014 09:32:26আসে 12/12/2014 10:32:26এবং সেখানে কেবলমাত্র 2 টি কাজ চলে যা m_ARRAYV_SALES_ZIG1_CALL2_VOD__C_OB& হয়েছে 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
রাষ্ট্রের হোভারে লাইনপথটি নির্ধারণ করুন, উদাহরণস্বরূপ: jsfiddle.net/bx2000cb/8
সেবাস্তিয়ান বোচান

4
আপনি Highcharts error #15যেমন জানেন যে আপনার ডেটা বাছাইয়ের ক্ষেত্রে ত্রুটি রয়েছে। আপনি আপনার ডেটা বরাদ্দ করছেন তবে আরোহী ক্রমে নয়। দয়া করে চেক করুন, সম্ভবত দ্বিগুণ চেক কারণ আমি এই প্রচুর সমস্যা দেখতে পাচ্ছি কারণ বিকাশকারী তাদের কোনওভাবে বাছাই করা ডেটাতে সমস্যাটি খুঁজে পেতে ব্যর্থ হয়।
রাইন হাশেমী

4
যদি আপনি চেষ্টা না করেন, তবে আপনি জানতে পারবেন না ..
পাউয়ে ফাস

4
আমার ধারণা নেই আপনি ছেলেরা কী সম্পর্কে কথা বলছেন, সে কি প্রকৃতপক্ষে? এই প্রশ্নগুলি একটি বড় জগাখিচুড়ি। চার্ট উত্পন্ন করার জন্য আপনার কাছে পড়া এবং বোঝার কোডটি দিয়ে শুরু করার পরামর্শ দিচ্ছি। এছাড়াও, আমি হাইচার্টগুলির কয়েকটি টিউটোরিয়াল পড়ার পরামর্শ দিচ্ছি, কেবল এটি কীভাবে কাজ করে তা বুঝতে।
পাওয়ে ফাস

4
আমি এই ব্যাপ্তিটি চালাচ্ছি এবং দুটি কাজ দেখতে পাচ্ছি, আপনার বিবরণ ছাড়া কোনও অতিরিক্ত ঝাঁকুনি নেই।
সেবাস্তিয়ান বোচান

উত্তর:


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) অনুযায়ী লেবেল প্রদর্শন করা উচিত কিনা তা আপনি আসলে যাচাই করেন না । ফর্ম্যাটারটির একটি সাধারণ আপডেট ( প্লাঙ্কার ) কাজ করছে বলে মনে হচ্ছে:

  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) {

আপনি ফিট দেখতে।

দাবি অস্বীকার : আমি হাইচার্ট ব্যবহার করি না, সুতরাং এই উত্তরটি সমস্যাটি ব্যাখ্যা করার চেষ্টা করে এবং সমস্যাটি সমাধানের কোনও হাইচার্টস-উপায় প্রস্তাব না করার চেষ্টা করে।


পাঠ শিখেছি:

  • yaxis-plugin.js সমস্যাটি অপ্রাসঙ্গিক।
  • হাইস্টকস্ট.জেএস একটি ওপেন-সোর্স লাইব্রেরি ( হাইস্টকস্ট.এসআরসি.জেএস )। আপনি যদি আসল উত্স কোডটি ডিবাগ করেন তবে কোনও ডিবাগিং অনেক সহজ। Minified কোড অপ্রয়োজনীয় জটিলতা এবং অনুমান যোগ করে। আমি লাইব্রেরিটি ডাউনলোড করেছি এবং console.log()কী চলছে তা খুঁজে পেতে কিছু যুক্ত করেছি ।
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.