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

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

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

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

Visual Studio

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

Q&A

解決済

4回答

2024閲覧

共通イベントハンドラを使用した多オブジェクトに対するコードの短縮化について

P5_USER

総合スコア73

C#

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

Visual Studio

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

1グッド

0クリップ

投稿2018/08/06 05:28

いつもお世話になっています。

前提・実現したいこと

前提1:(UserControl内にtableLayoutPanelで)ボタンが60個ある。
前提2:それらのボタンはドラッグアンドドロップでファイルを受け付けてファイル名を(各ボタン名).textに表示している。

実現したいこと:60個のボタンに対応するコードを短縮させたい。

※具体的には

string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); input1_1.Text = Path.GetFileName(filename[0]); input1_1.BackColor = Color.Chartreuse;

を1つのメソッドに置き換える事で達成できればと思っています。
(でも、if文の中にあるボタンのNameをどのようにすればよいのかわかっていません)

該当のソースコード

input1_1やinput1_2はボタンのNameです。

C#

1 private void DragDrop(object sender, DragEventArgs e) 2 { 3 if (sender.Equals(input1_1)) { 4 string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); 5 input1_1.Text = Path.GetFileName(filename[0]); 6 input1_1.BackColor = Color.Chartreuse; 7 } 8 else if (sender.Equals(input1_2)) { 9 string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); 10 input1_2.Text = Path.GetFileName(filename[0]); 11 input1_2.BackColor = Color.Chartreuse; 12 } 13 else if (sender.Equals(input1_3)) { 14 string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); 15 input1_3.Text = Path.GetFileName(filename[0]); 16 input1_3.BackColor = Color.Chartreuse; 17 } 18 else if (sender.Equals(input1_4)) { 19 string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); 20 input1_4.Text = Path.GetFileName(filename[0]); 21 input1_4.BackColor = Color.Chartreuse; 22 } 23 } 24

補足情報(FW/ツールのバージョンなど)

VisualStudio2017 (Community)
.NET Framework Ver 4.7.03056

Hawn👍を押しています

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

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

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

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

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

guest

回答4

0

60個を全て一つのイベントハンドラを登録して、Senderで区別すればいいです

動かしてないけどこんな感じ

C#

1 private void DragDrop(object sender, DragEventArgs e) 2 { 3 Button btn = Sender as Button; // これで発動元のボタンが取れる 4 string name = btn.Name; // ボタンの名前

投稿2018/08/06 05:30

編集2018/08/06 05:34
y_waiwai

総合スコア87747

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

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

0

C#

1if(senderが60個のボタンのうちのどれかであれば){ 2 senderを操作する(ボタンにキャストして) 3}

senderが60個のボタンのうちのどれかであればはボタンのリストなり配列なり作ればいいです。

投稿2018/08/06 05:41

ozwk

総合スコア13521

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

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

0

ベストアンサー

senderをキャストすればいいんでは。キャスト先がTextBoxでいいのかわからんけど。

private void DragDrop(object sender, DragEventArgs e) {       TextBox input = (TextBox)sender; string[] filename = (string[])e.Data.GetData(DataFormats.FileDrop, false); if( input != null && filename.Any()) { input.Text = Path.GetFileName(filename[0]); input.BackColor = Color.Chartreuse; }      }

投稿2018/08/06 05:36

kiichi54321

総合スコア1984

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

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

P5_USER

2018/08/06 05:58

kiichi54321さん ありがとうございます。 私の場合は、Buttonをキャスト先にする必要がありました。 教えてもらったそのコードを一部改変すると、 望み通りの動きになってくれました。 というのも、Buttonと打っただけでは、IntelliSenseの候補の中に、 自分の設定したnamespaceのButtonと System.Windows.Forms.Buttonと VisualStyleElement.Buttonがあり、 真ん中のSystem.Windows.Forms.Buttonにしなければいけなかったからです。
guest

0

ボタンから派生した新たなコントロールを作るのが良いのではないかと思います。

投稿2018/08/06 05:32

Zuishin

総合スコア28660

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問