rou*_*rld 3 charts qt qml lineseries
我的目标是在运行时添加ChartView数量可变的QML LineSeries。LineSeries在用户选择并加载其中包含数据的文件之前,未知需要添加多少个。
我试图创建所有的LineSeries内部Repeater,没有运气。我怀疑这是因为ChartView不知道该怎么办Item。由于不适用于,因此无法直接进行Repeater创建:LineSeriesRepeaterQObject
Repeater {
model: numberOfColumnsInModel / 2
delegate: Item {
LineSeries {
id: lineSeries
axisX: xAxis
axisY: yAxis
VXYModelMapper {
id: modelMapper
model: lineChart.model //Reimplemented QAbstractTableModel
xColumn: index * 2
yColumn: index * 2 + 1
}
onHovered: {
console.log("Do something...");
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
在我在线上看到的示例中,每个示例LineSeries都是硬编码的(对于其中的每一行一次),ChartView对我没有用。
使用强制文档,卢克。在下面的示例中,在启动时创建了具有随机点数的线的随机数:
import QtQuick 2.7
import QtQuick.Window 2.2
import QtQuick.Controls 2.0
import QtCharts 2.1
Window {
id: window1
title: "Chart test"
visible: true
width: 600
height: 400
ChartView {
id: chart
anchors.fill: parent
axes: [
ValueAxis{
id: xAxis
min: 1.0
max: 10.0
},
ValueAxis{
id: yAxis
min: 0.0
max: 10.0
}
]
Component.onCompleted: {
var seriesCount = Math.round(Math.random()* 10);
for(var i = 0;i < seriesCount;i ++)
{
var series = chart.createSeries(ChartView.SeriesTypeLine, "line"+ i, xAxis, yAxis);
series.pointsVisible = true;
series.color = Qt.rgba(Math.random(),Math.random(),Math.random(),1);
series.hovered.connect(function(point, state){ console.log(point); }); // connect onHovered signal to a function
var pointsCount = Math.round(Math.random()* 20);
var x = 0.0;
for(var j = 0;j < pointsCount;j ++)
{
x += (Math.random() * 2.0);
var y = (Math.random() * 10.0);
series.append(x, y);
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)