質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.47%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

1回答

2056閲覧

軸ラベルに値を対応させたい(普通は勝手に対応してくれるんですが...)。

P5_USER

総合スコア73

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

0クリップ

投稿2017/12/31 06:08

###現状
画像
それぞれのデータ(赤線や青線)は構造体のdouble[]に格納されています。
赤線は第1Y軸,青線は第2Y軸に対応しています。

設定はコードで書かず,GUI?みたいなもので設定しています。

###実現したいこと
第2Y軸:青色を上にシフトさせたい
(今,-30のラベルのところに0の値がある状態です。)

###発生している問題
プロパティでChartArea→Axis→Secondary Y(Value)axis→Minimumを-30にしたのですが,
何故か,第1Y軸の最小値(0)にピタッとくっついて離れてくれません。

###試したこと
ネットで解決法を検索してもWPSなる記述だったり,全く違う結果が出てきたりで
解決の糸口になりそうな情報がありませんでした。(単に探し方が下手なだけ?)

###補足情報(言語/FW/ツール等のバージョンなど)
言語はC#
開発環境はVisualStudio2017
.NET Framework Version 4.7.02556
です。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

何が原因かわかりませんが以下のようにコードから設定したらどうでしょうか。

csharp:"C#"

1using System.Drawing; 2using System.Windows.Forms; 3using System.Windows.Forms.DataVisualization.Charting; 4 5namespace ChartSecondAxisSample 6{ 7 public partial class Form1 : Form 8 { 9 // 第1系列のデータ 10 private double[] _firstDatas = new double[]{10, 8, 6, 8, 10, 12, 14, 16, 18, 20, 18}; 11 // 第2系列のデータ 12 private double[] _secondDatas = new double[] { -10, -8, -6, -4, -2, 0, 2, 4, 6, 8, 10 }; 13 14 public Form1() 15 { 16 InitializeComponent(); 17 18 // ※ 系列はあらかじめGUIから追加しています 19 20 // 各系列の軸タイプを設定 21 chart.Series[0].YAxisType = AxisType.Primary; 22 chart.Series[1].YAxisType = AxisType.Secondary; 23 //第1軸の最大最小 24 chart.ChartAreas[0].AxisY.Maximum = 30; 25 chart.ChartAreas[0].AxisY.Minimum = 0; 26 //第2軸の最大最小 27 chart.ChartAreas[0].AxisY2.Maximum = 20; 28 chart.ChartAreas[0].AxisY2.Minimum = -20; 29 // 色設定 30 chart.Series[0].Color = Color.Red; 31 chart.Series[1].Color = Color.Blue; 32 33 34 // データセット 35 for (var i = 0; i < _firstDatas.Length; i++) 36 { 37 // 系列1 38 chart.Series[0].Points.Add(new DataPoint(i, _firstDatas[i])); 39 // 系列2 40 chart.Series[1].Points.Add(new DataPoint(i, _secondDatas[i])); 41 } 42 } 43 } 44}

これにより以下の表示になります。

第2軸ありのChartControl

YAxisTypeプロパティが適切に設定できていないことが原因なような気がしております。
ご確認ください。

投稿2018/01/05 08:00

編集2018/01/05 08:09
g_uo

総合スコア212

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

P5_USER

2018/01/05 08:19

g_uoさん ありがとうございます! ご指摘の通りYAxisTypeプロパティがprimaryに設定されて(変更しないで)いました。 階層に分けてくれているのは有難いのですが, 深層に行くにつれて説明の意味が分からなくなっていました。
g_uo

2018/01/05 09:00

コメントありがとうございます。 無事解決してなによりです。確かにChartは扱いづらいですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.47%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問