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

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

ただいまの
回答率

89.13%

【WindowsFormアプリケーション】大分類から機能を選択するようなメニュー画面を実装したい

解決済

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,866

sujico.net

score 437

 実現したいこと

WindowsFormアプリケーションにて、左ペインの大分類ボタンを押下すると対応する小カテゴリのボタンが右ペインに表示されるような
よくあるメニュー画面を実装したいです。

 質問したいこと

適切な実装方法のイメージがわかないので、より良いアイディアがあればご教示いただきたく存じます。
また稚拙ではありますが、私が考えうる精一杯の実装方法(後述)も紹介させて頂きます。

 画面イメージ

イメージ説明
panel1のボタンを押すと、対応するボタンがpanel2に表示される という動作イメージ

 考えた実装方法

panel1のボタンを押下した際のクリックイベントで、panel2の領域内にサブフォームを読み込む。
サブフォームはWindowsの枠を削除しており、カテゴリ別のボタンが配置されている…というイメージ。

 質問に至った経緯

考えた方法で実装可能ではありますが、
なんとなくスマートではない、無駄の多い実装方法だという考えが払拭できません。

もしかっこいい実装方法をご存知の方がいらっしゃれば、是非参考にさせて頂きたいと考えました。

 開発環境

VisualStudio2017
.NETFramework4.6.1
C#
Windows7

不足情報があれば、追記させていただきます。
何卒、宜しくお願い致します。

 【追記】

・何故ボタンで切り替えようと思ったか?
→ 動機として、なんとなくWebっぽく見えるかなと思い選びました。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+3

TabControl でいいのではないでしょうか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/08/08 17:57

    それでもこの形で実装したいというのであれば、画面の数だけコントロールを作り、ボタンクリックで BringToFront() して Focus() するのが簡単かと思います。

    キャンセル

  • 2018/08/08 17:59

    確かに仰るとおりです。
    一度コントロールの選定を見直してみたいと思います。
    ありがとうございます!

    キャンセル

  • 2018/08/08 17:59

    イメージとしては https://water2litter.net/gin/?p=1438 このような感じですね。
    ありがとうございます。
    なにが一番適切か、検証してみたいと思います。

    キャンセル

+2

概要

業務アプリケーションで考えたやり方としては、
ListViewを使用して、メニューを自前でレンダリングするという方法を実装しました。
ListViewはツリー構造を作れるので、階層構造が2段階までという前提であるならば、
適用可能かと存じます。

実現方法

ListViewを2つ用意し、左側にグループ化されたメニューを配置し、
右側に詳細を表示します。
左側のListViewにはグループを登録すると同時に、明細を登録します。
左側のListViewアイテムが選択されたときに、選択されたアイテムのTagを参照して
右側のListViewにアイテムを追加します。
※一般的にはやっている人が少なそうなので、微妙なのかもしれません

理由

このような複雑な仕組みにした理由は以下の通りなので、工数がある程度とれる場合のみ採用できる内容かと存じます。

  • 可変メニューである
  • CSVデータの読み込みでメニューの構成内容を変更できるようにしている
  • ランチャのような動作をする(外部exeを実行して、画面が表示されたらメニューを非表示にして、プロセスが終了したら再表示する)
  • 起動後の操作により特定のデバイスと接続状態になってから操作可能にする
  • デバイスによって特定の条件を満たす場合は非表示にするものがある
  • 各メニューに説明を併記する

サンプル

sample

Github menu sample

※.NET Core 3.0では残念ながら上記コードは動作しません、.NET Frameworkでの動作を期待します
.NET Core3.1で動作しました。当時(2020/01)OwnerDrawイベントが全く動かなかったのですが動くようになっていて感動しました。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/08/09 08:51

    のちのち変更できる点が非常に魅力的だと思います!
    ListViewを使ってそんなことが出来るんですね……ほぼ使ったことが無いので実際にどう実装すればいいかイメージがすぐ落ちてこないので、似たようなことをしている人がいないか調べてみます。
    明示的で分かりやすいご提案ありがとうございます!
    ベストアンサーを既に投票してしまったため、ベストアンサーを差し上げることが出来かねますが、高評価+1させて頂きます。
    ありがとうございます!

    キャンセル

  • 2018/08/09 18:51

    調べた限り、同じような実装を見ていないので、気が向いたらどこかに投稿するかもしれません。
    ただ、前述の通り、工数がある程度潤沢にないと実現が難しいことはお忘れなく。(試験込みで10人日程度)

    キャンセル

+1

この画面構成を使うのならば、[メニュー1][メニュー2][メニュー3]...それぞれを押された時に何かしらのフラグを立てて、panel2のボタンのTextやVisibleを切り替えて、処理もフラグで分岐させるとか?

ZuishinさんのようにTabで画面を切り替えたほうがわかりやすいと思いますが...

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/08/08 17:33

    https://water2litter.net/gin/?p=1438
    こんな感じでしょうか!

    うーん…そちらの方が分かりやすいようであれば、その実装の方がいいかも知れません…。
    ご回答頂きありがとうございます。

    キャンセル

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

  • ただいまの回答率 89.13%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • C#に関する質問
  • 【WindowsFormアプリケーション】大分類から機能を選択するようなメニュー画面を実装したい