추가 데이터를 높은 차트 시리즈로 설정
차트 '도구 설명'에 표시하는 데 사용할 추가 데이터를 영상 시리즈 개체에 전달할 수 있는 방법이 있습니까?
예를들면
tooltip: {
formatter: function() {
return '<b>'+ this.series.name +'</b><br/>'+
Highcharts.dateFormat('%b %e', this.x) +': '+ this.y;
}
여기서 우리는 series.name , this.x 및 this.y를 시리즈에만 사용할 수 있습니다.예를 들어 데이터 세트와 함께 다른 동적 값을 단독으로 전달해야 하며 영상 시리즈 개체를 통해 액세스할 수 있습니다.이것이 가능합니까?
여러분들께 미리 감사드립니다.
예, 다음과 같이 각 데이터 포인트가 해시인 영상 시리즈 개체를 설정하면 추가 값을 전달할 수 있습니다.
new Highcharts.Chart( {
...,
series: [ {
name: 'Foo',
data: [
{
y : 3,
myData : 'firstPoint'
},
{
y : 7,
myData : 'secondPoint'
},
{
y : 1,
myData : 'thirdPoint'
}
]
} ]
} );
도구 설명에서 전달된 개체의 "point" 속성을 통해 액세스할 수 있습니다.
tooltip: {
formatter: function() {
return 'Extra data: <b>' + this.point.myData + '</b>';
}
}
전체 예: https://jsfiddle.net/burwelldesigns/jeoL5y7s/
또한 이 솔루션을 사용하면 원하는 만큼 여러 데이터를 저장할 수 있습니다.
tooltip: {
formatter: function () {
return 'Extra data: <b>' + this.point.myData + '</b><br> Another Data: <b>' + this.point.myOtherData + '</b>';
}
},
series: [{
name: 'Foo',
data: [{
y: 3,
myData: 'firstPoint',
myOtherData: 'Other first data'
}, {
y: 7,
myData: 'secondPoint',
myOtherData: 'Other second data'
}, {
y: 1,
myData: 'thirdPoint',
myOtherData: 'Other third data'
}]
}]
감사합니다 닉.
특히 터보 임계값을 활성화하기에 충분한 데이터 포인트가 있는 시계열 데이터의 경우 위에서 제안한 솔루션이 작동하지 않습니다.터보 임계값의 경우 Highcarts는 데이터 포인트가 다음과 같은 배열이 될 것으로 예상하기 때문입니다.
series: [{
name: 'Numbers over the course of time',
data: [
[1515059819853, 1],
[1515059838069, 2],
[1515059838080, 3],
// you get the idea
]
}]
터보 임계값(많은 데이터 포인트를 처리할 때 중요)의 이점을 잃지 않기 위해 차트 외부에 데이터를 저장하고 툴팁에서 데이터 포인트를 검색합니다.formatter
기능.다음은 예입니다.
const chartData = [
{ timestamp: 1515059819853, value: 1, somethingElse: 'foo'},
{ timestamp: 1515059838069, value: 2, somethingElse: 'bar'},
{ timestamp: 1515059838080, value: 3, somethingElse: 'baz'},
// you get the idea
]
const Chart = Highcharts.stockChart(myChart, {
// ...options
tooltip: {
formatter () {
// this.point.x is the timestamp in my original chartData array
const pointData = chartData.find(row => row.timestamp === this.point.x)
console.log(pointData.somethingElse)
}
},
series: [{
name: 'Numbers over the course of time',
// restructure the data as an array as Highcharts expects it
// array index 0 is the x value, index 1 is the y value in the chart
data: chartData.map(row => [row.timestamp, row.value])
}]
})
이 접근 방식은 모든 차트 유형에 적용됩니다.
AJAX를 사용하여 SQL Server에서 데이터를 가져온 다음 차트의 데이터로 사용할 js 배열을 준비합니다.AJAX가 성공하면 JavaScript 코드:
...,
success: function (data) {
var fseries = [];
var series = [];
for (var arr in data) {
for (var i in data[arr]['data'] ){
var d = data[arr]['data'][i];
//if (i < 5) alert("d.method = " + d.method);
var serie = {x:Date.parse(d.Value), y:d.Item, method:d.method };
series.push(serie);
}
fseries.push({name: data[arr]['name'], data: series, location: data[arr]['location']});
series = [];
};
DrawChart(fseries);
},
이제 추가 메타데이터를 툴팁에 표시합니다.
...
tooltip: {
xDateFormat: '%m/%d/%y',
headerFormat: '<b>{series.name}</b><br>',
pointFormat: 'Method: {point.method}<br>Date: {point.x:%m/%d/%y } <br>Reading: {point.y:,.2f}',
shared: false,
},
DataRow를 사용하여 결과 집합을 반복한 다음 클래스를 사용하여 Json 형식으로 반환하기 전에 값을 할당합니다.Ajax에서 호출한 컨트롤러 동작의 C# 코드입니다.
public JsonResult ChartData(string dataSource, string locationType, string[] locations, string[] methods, string fromDate, string toDate, string[] lstParams)
{
List<Dictionary<string, object>> dataResult = new List<Dictionary<string, object>>();
Dictionary<string, object> aSeries = new Dictionary<string, object>();
string currParam = string.Empty;
lstParams = (lstParams == null) ? new string[1] : lstParams;
foreach (DataRow dr in GetChartData(dataSource, locationType, locations, methods, fromDate, toDate, lstParams).Rows)
{
if (currParam != dr[1].ToString())
{
if (!String.IsNullOrEmpty(currParam)) //A new Standard Parameter is read and add to dataResult. Skips first record.
{
Dictionary<string, object> bSeries = new Dictionary<string, object>(aSeries); //Required else when clearing out aSeries, dataResult values are also cleared
dataResult.Add(bSeries);
aSeries.Clear();
}
currParam = dr[1].ToString();
aSeries["name"] = cParam;
aSeries["data"] = new List<ChartDataModel>();
aSeries["location"] = dr[0].ToString();
}
ChartDataModel lst = new ChartDataModel();
lst.Value = Convert.ToDateTime(dr[3]).ToShortDateString();
lst.Item = Convert.ToDouble(dr[2]);
lst.method = dr[4].ToString();
((List<ChartDataModel>)aSeries["data"]).Add(lst);
}
dataResult.Add(aSeries);
var result = Json(dataResult.ToList(), JsonRequestBehavior.AllowGet); //used to debug final dataResult before returning to AJAX call.
return result;
}
저는 C#에서 코드화하는 더 효율적이고 허용 가능한 방법이 있다는 것을 알고 있지만, 저는 프로젝트를 이어받았습니다.
일종의 역동성을 추가하기 위해:
범주가 10개인 쌓인 세로막대형 차트의 데이터를 생성하기 위해 이 작업을 수행했습니다.
각 범주 4 데이터 시리즈에 대해 보유하고 각 데이터 시리즈에 대한 추가 정보(이미지, 질문, 방해 요소 및 예상 답변)를 표시하고자 했습니다.
<?php
while($n<=10)
{
$data1[]=array(
"y"=>$nber1,
"img"=>$image1,
"ques"=>$ques,
"distractor"=>$distractor1,
"answer"=>$ans
);
$data2[]=array(
"y"=>$nber2,
"img"=>$image2,
"ques"=>$ques,
"distractor"=>$distractor2,
"answer"=>$ans
);
$data3[]=array(
"y"=>$nber3,
"img"=>$image3,
"ques"=>$ques,
"distractor"=>$distractor3,
"answer"=>$ans
);
$data4[]=array(
"y"=>$nber4,
"img"=>$image4,
"ques"=>$ques,
"distractor"=>$distractor4,
"answer"=>$ans
);
}
// Then convert the data into data series:
$mydata[]=array(
"name"=>"Distractor #1",
"data"=>$data1,
"stack"=>"Distractor #1"
);
$mydata[]=array(
"name"=>"Distractor #2",
"data"=>$data2,
"stack"=>"Distractor #2"
);
$mydata[]=array(
"name"=>"Distractor #3",
"data"=>$data3,
"stack"=>"Distractor #3"
);
$mydata[]=array(
"name"=>"Distractor #4",
"data"=>$data4,
"stack"=>"Distractor #4"
);
?>
높은 차트 섹션에서:
var mydata=<? echo json_encode($mydata)?>;
// Tooltip section
tooltip: {
useHTML: true,
formatter: function() {
return 'Question ID: <b>'+ this.x +'</b><br/>'+
'Question: <b>'+ this.point.ques +'</b><br/>'+
this.series.name+'<br> Total attempts: '+ this.y +'<br/>'+
"<img src=\"images/"+ this.point.img +"\" width=\"100px\" height=\"50px\"/><br>"+
'Distractor: <b>'+ this.point.distractor +'</b><br/>'+
'Expected answer: <b>'+ this.point.answer +'</b><br/>';
}
},
// Series section of the highcharts
series: mydata
// For the category section, just prepare an array of elements and assign to the category variable as the way I did it on series.
누군가에게 도움이 되길 바랍니다.
언급URL : https://stackoverflow.com/questions/8514457/set-additional-data-to-highcharts-series
'source' 카테고리의 다른 글
배경색의 불투명도(텍스트는 아님) (0) | 2023.08.18 |
---|---|
Powershell에서 두 날짜 간의 일 수 차이를 가져오는 중 (0) | 2023.08.13 |
SQL Server 작업이 이미 실행 중인 경우 예약된 실행을 건너뜁니까? (0) | 2023.08.13 |
SVG 요소에 클릭 시 이벤트 추가 (0) | 2023.08.13 |
도커에서 컨테이너와 이미지의 차이점은 무엇입니까? (0) | 2023.08.13 |