ローソク足チャートの作成
注: これはCharts with Widgets Galleryの例の一部です。
ローソク足チャートを表示するには、まず日足データを扱うためにQCandlestickSeries 。また、カスタム増減ボディ・カラーを指定しています。
auto acmeSeries = new QCandlestickSeries; acmeSeries->setName("Acme Ltd"); acmeSeries->setIncreasingColor(QColor(Qt::green)); acmeSeries->setDecreasingColor(QColor(Qt::red));
QFile は、非連続データが保存されているテキスト・ファイルにアクセスするために使用されます。 は、テキスト・ファイルを読み込んで、データから始値、高値、安値、終値、タイムスタンプ値を見つけるための補助クラスです。 については後で詳しく説明する。メソッド は値を読み取り、メソッドが呼び出し元に返す アイテムに設定します。返された アイテムがシリーズに追加されます。また、後で使用するためにカスタム・カテゴリー・リストも保存しています。CandlestickDataReader
CandlestickDataReader
readCandlestickSet()
QCandlestickSet QCandlestickSet
QFile acmeData(":candlestick"); if (!acmeData.open(QIODevice::ReadOnly | QIODevice::Text)) { m_loadError = QStringLiteral("Failed to load '%1' file.").arg(acmeData.fileName()); return false; } QStringList categories; CandlestickDataReader dataReader(&acmeData); while (!dataReader.atEnd()) { QCandlestickSet *set = dataReader.readCandlestickSet(); if (set) { acmeSeries->append(set); categories << QDateTime::fromMSecsSinceEpoch(set->timestamp()).toString("dd"); } }
以下では、新しいQChart インスタンスが作成され、以前に作成されたシリーズオブジェクトがそれに追加されます。また、タイトルを定義し、アニメーションをQChart::SeriesAnimation に設定します。
auto chart = new QChart; chart->addSeries(acmeSeries); chart->setTitle("Acme Ltd. Historical Data (July 2015)"); chart->setAnimationOptions(QChart::SeriesAnimations);
ここでは、プレゼンテーション用のデフォルトの軸を作成するようにチャートに依頼します。そして、チャートから軸のポインタをクエリし、以前に保存したカスタム・カテゴリ・リストからカテゴリを設定することにより、横軸にカスタム・カテゴリを設定します。また、チャートから軸のポインタをクエリして、その軸の最小値と最大値を設定して、縦軸の範囲を設定します。
chart->createDefaultAxes(); auto axisX = qobject_cast<QBarCategoryAxis *>(chart->axes(Qt::Horizontal).at(0)); axisX->setCategories(categories); auto axisY = qobject_cast<QValueAxis *>(chart->axes(Qt::Vertical).at(0)); axisY->setMax(axisY->max() * 1.01); axisY->setMin(axisY->min() * 0.99);
以下では、凡例を表示するように設定し、それをチャートの一番下に配置します。
chart->legend()->setVisible(true); chart->legend()->setAlignment(Qt::AlignBottom);
最後に、チャートをビューに追加します。
createDefaultChartView(chart);
これで、チャートを表示する準備ができました。
ここでは、readCandlestickSet()
メソッドについて詳しく説明します。まず、ファイルから行を読み込むが、#で始まる行はコメント行とみなされるので除外する。
QString line = m_textStream.readLine(); if (line.startsWith("#") || line.isEmpty()) return nullptr;
ファイルでは、データはスペースで区切られた数字列として配置されている。このスニペットでは、行が1つの数値文字列に分割され、QStringList に格納される。
QStringList strList = line.split(QLatin1Char(' '), Qt::SkipEmptyParts); if (strList.count() != 5) return nullptr;
連続データから値を選択するには、以下のコードを使用する。strList
の値は、タイムスタンプ、オープン、ハイ、ロー、クローズの順に格納される。
const qreal timestamp = strList.at(0).toDouble(); const qreal open = strList.at(1).toDouble(); const qreal high = strList.at(2).toDouble(); const qreal low = strList.at(3).toDouble(); const qreal close = strList.at(4).toDouble();
最後に、次のスニペットは、新しいQCandlestickSet を作成し、必要なすべての値を提供する方法を示しています。
auto candlestickSet = new QCandlestickSet(timestamp); candlestickSet->setOpen(open); candlestickSet->setHigh(high); candlestickSet->setLow(low); candlestickSet->setClose(close);
©2024 The Qt Company Ltd. 本書に含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。