0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

プログラム初心者勉強会 5回目 -C# Windowsフォーム入門

Last updated at Posted at 2021-11-04

#目次
1. 前回リンク
2. 次回リンク
3. やったこと
4. 配信時の録画
5. 今回学んだこと
6. リソースの追加について
7. リソースの活用
8. ダイアログの勉強
9. デザイン画面から生成したイベントハンドラ関数を削除する手順
10. 振り返り
11. 次回予告

#1. 前回リンク
https://qiita.com/Usyuuu-program-beginner/items/ef0d6aad24ad3bdeb5e2

#2. 次回リンク
https://qiita.com/Usyuuu-program-beginner/items/cc17e799bc0538902ffd

#3. やったこと
下のサイトの 8.リソース と 9. ダイアログ(1)を学習

ダイアログに関しては、以下サイトの内容を主に勉強

#4. 配信時の録画
https://youtu.be/hDGb4d9oD68

#5. 今回学んだこと
リソースの内容を自学習してしまってたので、9章も勉強したよ。
記事には参考サイトに記載していないところで学びのあった所をまとめます。

#6. リソースの追加について
##6.1 プロパティ画面の開き方
2通り存在する

  • 「Resources.resx」ファイルの使用

image.png
ソリューション エクスプローラ画面から「Resources.resx」をダブルクリックすることで、プロジェクトのプロパティ画面が開けます。

  • プロジェクト名を右クリック → 「プロパティ(R)」を選択

手順は前回記事の7.1章を参照

##6.2 画像データの追加
前回記事の7.1章を参照

##6.3 アイコンの追加

  1. [5.1 プロパティ画面の開き方](#51 プロパティ画面の開き方)の方法でプロパティ画面に行く
  2. 下画像の「アイコン Ctrl +3」を選択
  3. 「リソースの追加(R)」で” ???.ico ”ファイルを追加
    プロパティ_アイコン.png

注意
・ アイコンは「.ico」形式のファイルのみ登録可能です。
・ アイコンファイルの名前先頭に数字がある場合、ビルドに失敗する場合があります。英字にしておきましょう。

##6.4 音楽データの追加

  1. [5.1 プロパティ画面の開き方](#51 プロパティ画面の開き方)の方法でプロパティ画面に行く
  2. 下画像の「オーディオ Ctrl +4 」を選択
  3. 「リソースの追加(R)」で” ???.wav ”ファイルを追加
    プロパティ_オーディオ.png

注意
・ オーディオファイルは「.wav」形式のファイルのみ登録可能です。
・ .mp3形式の場合、リソースの種別は「ファイル」となります。

##6.5 文字列データの追加

  1. [5.1 プロパティ画面の開き方](#51 プロパティ画面の開き方)の方法でプロパティ画面に行く
  2. 下画像の「文字列 Ctrl +1 」を選択
  3. 名前列に”変数名”、値列に”表示したい文字列”を記載する
    image.png

#7. リソースの活用
##7.1 画像データの活用
前回記事の7.2章を参照

##7.2 アイコンデータの活用
###7.2.1 ウィンドウ左上のアイコン変更
以下サイトに手順記載あり。参考サイトでは直接コード記載して変更する手順書いてたけど、絶対こっちの方が簡単

###7.2.2 実行ファイルのアイコン変更

  1. プロパティ画面を開く
  2. 「アプリケーション」タブメニュ―を開く
  3. 画面下部の「アイコン:」右の「参照…」ボタンから、実行ファイルのアイコンに設定したい「???.ico」ファイルを選択
  4. ビルドする

上記手順で実行ファイルのアイコンを変更可能

アイコン変更.PNG

##7.3 音楽ファイルの再生
音楽再生に関しては以下記事が一番参考になった

ここで解説しているように、wav形式ならSystem.Media.SoundPlayerを使用するだけで再生、停止が簡単にできます。

MP3形式は標準で使用できないので、Small Basicのdllを参照する方法が一番簡単そう。 .Net Framework上で動く設計で、dll参照さえすればすぐに使えるのがいいね!

##7.4 リソース追加した文字列の活用
メッセージボックスに表示する文字列をあらかじめ用意し、管理できたりする。(正直仕事でどのように活用できるかは詳しくわかってない)

以下のようなコードを書けば、メッセージボックスに文字列が表示できるよ

リソース追加した文字列を表示
// 5.5章でリソースに追加した文字列
string str = Properties.Resources.ShowUsyuuuText;
string str2 = Properties.Resources.strstr;
// リソースに追加した文字列をメッセージボックスに表示
MessageBox.Show(str,str2);

#8. ダイアログの勉強
正直下のURLの内容を読めば、ダイアログの追加から情報の取得まで学べます。
ですがこのサイトのコードのままだと実装ができないので、そのあたり解説

##8.1 追加したダイアログを呼び出す
以下画面の「Dialog」ボタンを押すと、ダイアログが表示されるようにする
image.png

ダイアログクリック時のイベントハンドラ関数に、参考サイト先のサンプルコードをそのまま書き込むとエラーになってしまう

era-.png

##8.2 エラー原因
これの原因は「名前空間が違う場所のクラスを参照しているから」でした。
追加したダイアログ用関数の名前空間を、クラス前に記載することでエラーが無くなったよ。

エラーの出ないダイアログ呼び出し(DialogFormはダイアログ用クラスの名前空間)
private void button3_Click(object sender, EventArgs e)
{
     using (DialogForm.DialogSample dlg = new DialogForm.DialogSample())
     {
          if (dlg.ShowDialog() == DialogResult.OK)
          {
             //OKがクリックされた場合
             MessageBox.Show(dlg.GetTextInput());
          }
          else
          {
             //キャンセルがクリックされた場合
             MessageBox.Show("キャンセルされました。");
          }
    }
}

#9. デザイン画面から生成したイベントハンドラ関数を削除する手順
デザイン画面のボタンコントロールをダブルクリックすると、以下のようなイベントハンドラ関数が自動生成される。
削除部分.PNG

もしソースコードの該当関数を削除してしまうと、以下のようにデザイン画面にエラーが出てしまう
ボタンクリックイベントハンドラを削除.PNG

これを回避するためには、以下手順で削除する必要があります。

  1. デザイン画面を開き、イベントハンドラを削除したいコントロールを選択状態にする。
  2. プロパティ画面の稲妻マークをクリックする
  3. 選択コントロールに割り当てられたイベントを削除する
  4. ソースコードからイベントハンドラ関数を削除する

イベント用プロパティ.PNG

これでデザイン画面を開いてもエラーが出ません!

#10. 振り返り
リソースよりもダイアログ表示に今回は時間を割いちゃいました。次回もダイアログの勉強頑張るぞ!

#11. 次回予告
第6回は11月7日(日)の夜8時から以下チャンネルで行います!

##ニコニコ配信先
https://com.nicovideo.jp/community/co3601066

Twitch配信先

Discordリンク

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?