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

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

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

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

Q&A

解決済

2回答

8883閲覧

C#でTabPageにDataGridViewを表示させ、DataGridViewのサイズがClientSizeを超える場合に、スクロールバーを表示したいのですが表示されません.

lainnpc

総合スコア7

C#

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

0グッド

0クリップ

投稿2016/06/13 15:20

C#でTabPageにDataGridViewを表示させ、DataGridViewのサイズがClientSizeを超える場合に、スクロールバーを表示したいのですが表示されません.

//tabControlSumple.cs
using System;
using System.Drawing;
using System.Windows.Forms;
using System.Data;

class Program {
[STAThread]
static void Main() {
var t = new Program();
DataSet ds = new DataSet();
DataTable wdt = t.MakeWDataTable();
DataTable mdt = t.MakeMDataTable();
Application.Run(new Form1(wdt,mdt));
}
///************************************************
///Work DataTable作成処理
///************************************************
public DataTable MakeWDataTable(){
var wdt = new DataTable("work");
wdt.Columns.Add("WorkID",typeof(String));
wdt.Columns.Add("Workname",typeof(String));
wdt.Columns.Add("fixedFlag",typeof(bool));
wdt.Columns.Add("duplicatioFlag",typeof(bool));
wdt.Columns.Add("category",typeof(String));
wdt.Columns.Add("biginnig day",typeof(String));
wdt.Columns.Add("end day",typeof(String));
wdt.Columns.Add("biginnig time",typeof(String));
wdt.Columns.Add("end time",typeof(String));
wdt.Columns.Add("cycle",typeof(int));
wdt.Columns.Add("The need of leadership Flag",typeof(bool));
wdt.Columns.Add("group work Flag",typeof(bool));
wdt.Columns.Add("Priority",typeof(int));
wdt.Columns.Add("genderFlag",typeof(int));
wdt.Columns.Add("remarks",typeof(String));
return wdt;
}
///************************************************
///メンバーDataTable作成処理
///************************************************
public DataTable MakeMDataTable() {
var mdt = new DataTable("member");
mdt.Columns.Add("MemberID",typeof(String));
mdt.Columns.Add("Name",typeof(String));
mdt.Columns.Add("Gender",typeof(String));
mdt.Columns.Add("WorkingLimit",typeof(int));
mdt.Columns.Add("WeeklyTimesAverage",typeof(int));
return mdt;
}
}

class Form1 : Form {

public Form1(DataTable dt,DataTable mdt) { Text = "tabControlSumple"; BackColor = Color.White; ClientSize = new Size(800, 600); this.AutoScroll = true; this.AutoSize = true;

//Work DataGridView 作成追加
DataGridView wdgv = new DataGridView();
wdgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
wdgv.Location = new Point(10, 10);
wdgv.Size = new Size(620, 420);
wdgv.Anchor = (AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Bottom | AnchorStyles.Right);
wdgv.ReadOnly = false;
wdgv.Enabled = true;
wdgv.DataSource = dt;
TabControl tabControl = new TabControl(){ Dock = DockStyle.Fill };
TabPage wtabPage = new TabPage("Work Table");
wtabPage.AutoScroll = true;
wtabPage.Controls.Add(wdgv);
tabControl.Controls.Add(wtabPage);
//Member DataGridView 作成追加
DataGridView mdgv = new DataGridView();
mdgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
mdgv.Location = new Point(10, 10);
mdgv.Size = new Size(620, 420);
mdgv.Anchor = (AnchorStyles.Top | AnchorStyles.Left | AnchorStyles.Bottom | AnchorStyles.Right);
mdgv.ReadOnly = false;
mdgv.DataSource = mdt;
this.Controls.Add(tabControl);
TabPage mtabPage = new TabPage("Member Table");
mtabPage.AutoScroll = true;
mdgv.Enabled = true;
mtabPage.Controls.Add(mdgv);
tabControl.Controls.Add(mtabPage);
this.Controls.Add(tabControl);
}
}

タブページのAutoScroll を trueにしてみたのですが、スクロールバーが表示されません。

実行環境は
Microsoft (R) Visual C# Compiler version 4.6.1038.0
for C# 5 です。

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

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

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

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

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

guest

回答2

0

DataGridViewのAutoSizeをtrueにすることで解決しました。
説明が下手で失礼しました。
フォームを大きくした時にもDataGridViewの表示領域を合わせて大きくするという意味でした。
Zuishinさんありがとうございました。

修正後のソースがこちらです。

//tabControlSumple.cs
using System;
using System.Drawing;
using System.Windows.Forms;
using System.Data;

class Program {
[STAThread]
static void Main() {
var t = new Program();
DataSet ds = new DataSet();
DataTable wdt = t.MakeWDataTable();
DataTable mdt = t.MakeMDataTable();
Application.Run(new Form1(wdt,mdt));
}
///************************************************
///Work DataTable作成処理
///************************************************
public DataTable MakeWDataTable(){
var wdt = new DataTable("work");
wdt.Columns.Add("WorkID",typeof(String));
wdt.Columns.Add("Workname",typeof(String));
wdt.Columns.Add("fixedFlag",typeof(bool));
wdt.Columns.Add("duplicatioFlag",typeof(bool));
wdt.Columns.Add("category",typeof(String));
wdt.Columns.Add("biginnig day",typeof(String));
wdt.Columns.Add("end day",typeof(String));
wdt.Columns.Add("biginnig time",typeof(String));
wdt.Columns.Add("end time",typeof(String));
wdt.Columns.Add("cycle",typeof(int));
wdt.Columns.Add("The need of leadership Flag",typeof(bool));
wdt.Columns.Add("group work Flag",typeof(bool));
wdt.Columns.Add("Priority",typeof(int));
wdt.Columns.Add("genderFlag",typeof(int));
wdt.Columns.Add("remarks",typeof(String));
return wdt;
}
///************************************************
///メンバーDataTable作成処理
///************************************************
public DataTable MakeMDataTable() {
var mdt = new DataTable("member");
mdt.Columns.Add("MemberID",typeof(String));
mdt.Columns.Add("Name",typeof(String));
mdt.Columns.Add("Gender",typeof(String));
mdt.Columns.Add("WorkingLimit",typeof(int));
mdt.Columns.Add("WeeklyTimesAverage",typeof(int));
return mdt;
}
}

class Form1 : Form {

public Form1(DataTable dt,DataTable mdt) { Text = "tabControlSumple"; BackColor = Color.White; ClientSize = new Size(800, 600); this.AutoScroll = true; this.AutoSize = true;

//Work DataGridView 作成追加
DataGridView wdgv = new DataGridView();
wdgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
wdgv.Location = new Point(10, 10);
wdgv.AutoSize = true;
wdgv.Anchor = (AnchorStyles.Top | AnchorStyles.Left );
wdgv.ReadOnly = false;
wdgv.Enabled = true;
wdgv.DataSource = dt;
TabControl tabControl = new TabControl(){ Dock = DockStyle.Fill };
TabPage wtabPage = new TabPage("Work Table");
wtabPage.AutoScroll = true;
wtabPage.Controls.Add(wdgv);

tabControl.Controls.Add(wtabPage);

//Member DataGridView 作成追加
DataGridView mdgv = new DataGridView();
mdgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
mdgv.Location = new Point(10, 10);
mdgv.Anchor = (AnchorStyles.Top | AnchorStyles.Left );
mdgv.AutoSize = true;
mdgv.ReadOnly = false;
mdgv.DataSource = mdt;
this.Controls.Add(tabControl);
TabPage mtabPage = new TabPage("Member Table");
mtabPage.AutoScroll = true;
mdgv.Enabled = true;
mtabPage.Controls.Add(mdgv);
tabControl.Controls.Add(mtabPage);
this.Controls.Add(tabControl);
}
}

投稿2016/06/14 12:26

編集2016/06/14 13:07
lainnpc

総合スコア7

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

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

0

ベストアンサー

DataGridView の Anchor に Right と Bottom が入ってるからでしょう。

投稿2016/06/13 15:35

Zuishin

総合スコア28656

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

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

lainnpc

2016/06/13 16:12

早い回答をいただき、ありがとうございます。 おっしゃる通り、DataGridView の Anchor に Right と Bottomを削除するとスクロールバーが表示されました。 ただ、今度はフォームのサイズを変更した場合に、DataGridView の表示サイズが固定されたままになります。意図しているのは、フォームのサイズに連動して、DataGridViewの表示サイズも大きくしたいということです。何か方法はありますでしょうか?
Zuishin

2016/06/13 21:14

おっしゃる意味がわかりません。 フォームのサイズに合わせて大きさが調整されるなら、フォームからはみ出すこともないので、スクロールバーは必要ないでしょう。 フォームを大きくした時だけ合わせて大きくするということですか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.51%

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

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

質問する

関連した質問