第2回.フォームのプロパティ
ユーザーフォーム入門として基礎から解説します。
フォームのプロパティの主要なものについて説明します。
フォームの全プロパティ

いずれは、全て理解するに越したことはないですが、
とりあえず、以下に掲載している必要最低限のプロパティだけは把握しておきましょう。
フォームの主要なプロパティ
プロパティ | 説明 | ||||||
ActiveControl | コンテナ コントロール上のアクティブ コントロールを取得または設定します。 | ||||||
BackColor | 背景色を設定することができます。 | ||||||
BorderColor | BorderStyleが1の時、枠の色を設定することができます。 | ||||||
BorderStyle | フォームの枠に線を引くか引かないかの設定ができます。 | ||||||
Caption | タイトルバーに表示される文字列の設定ができます。 | ||||||
Controls | フォーム上に配置されたコントロールのコレクションを取得することが出来ます。 | ||||||
Enabled | Trueで通常の表示と操作ができます、Falseでイベントが応答しなくなります。 | ||||||
Font | フォーム上に配置されているコントロールの標準フォントを設定します。 | ||||||
ForeColor | フォーム上に配置されているコントロールの標準の前景色を設定します。 | ||||||
Height | フォームの高さの設定をすることができます。 | ||||||
Left | StartupPositionが0(手動)のとき、ユーザーフォームが表示される水平位置を設定できます。 | ||||||
ShowModal ※別途解説 |
ユーザー フォーム が作業ウィンドウ固定またはモードレスで表示されるように設定します。 実行時には値の取得のみ行えます。
|
||||||
SpecialEffect | フォームの枠のスタイルを設定することができます。 | ||||||
StartupPosition | フォームが表示される時の位置を設定することができます。 | ||||||
Tag | ユーザーが任意の値を設定することができます。 | ||||||
Top | StartupPositionが0(手動)のとき、ユーザーフォームが表示される垂直位置を設定できます。 | ||||||
Visible | フォームの表示/非表示の状態を取得します。 | ||||||
Width | フォームの幅を設定することができます。 | ||||||
Zoom | フォームの表示する時に拡大率を設定することができます。 |
とりあえず、このくらいを押さえておけば良いでしょう。
ドラッグでは、大雑把なサイズでしか設定できません、なかなかマウスでは細かい設定は無理ですよね。
そういう場合は、プロパティの数値を変更することで、正確なサイズを指定できます。
サイズのプロパティは、HeightとWidthになります。
ここの数値を変更することでサイズが変わります。
実際にプロパティを変更して変化した様子を確認すると覚えやすいものです。
ShowModalについて
ユーザーはアプリケーションの他の部分を使用する前に情報を提供するか、 ユーザー フォーム を閉じる必要があります。
ユーザー フォーム が非表示になるかアンロードされるまで、以降のコードは実行されません。
つまり、モーダルの場合、
バックにあるシートの操作は出来なくなります。
ユーザーは、 ユーザー フォーム を閉じることなく、他のフォームまたはウィンドウを表示できます。
モードレスのフォームはタスク バーに表示されず、ウィンドウ タブ オーダーに従っていません。
つまり、モードレスの場合、
バックにあるシートの操作が可能となります。
以下でもう少し詳しく解説します。
モーダルとは、Windowsに良くあるダイアログ画面です。
モーダルの場合は、
ユーザーフォームが表示されている間
Showメソッドの実行で止まり次には進みません。
Showメソッドの次のステートメントに進みます。
モードレスとは、画面表示中に他の処理ができる表示になります。
モードレスの場合は、
ユーザーフォームが表示されている間
Showメソッドの次のステートメントに進みます。
..Showで画面が表示され、そのまま次のステートメントに進んで処理が終了した状態のままになっています。
引数を省略した場合は、ShowModalプロパティに従いユーザーフォームが開かれます。
ShowModalプロパティの値に関わらず、モーダル/モードレスを指定する事が出来ます。
UserForm.Show vbModelessl ・・・ モードレス表示
シートのボタン押下等でフォーム画面を表示し、フォーム画面のOKボタンでシート操作に戻る。
良くあるこのような操作で使うのがモーダルになります。
シートのボタン押下等でフォーム画面を表示した後、
シート操作→フォーム画面操作→シート操作→フォーム画面操作・・・
このような操作を実現したい場合にモードレスを使います。
良くある例としては、
・シート操作の補助機能として複数のセル範囲の選択をさせる
モーダル/モードレスにより、VBAの構造は大きく違ってきます。
なにより設計からして全く違ってきます。
モードレスの場合はシート操作ができるので、アクティブシートも随時変化します。
したがって、モーダルに比べるとモードレスの方が設計が大変になる場合が多いでしょう。
今回はここまでです。
次回からは、フォームにいろいろな部品を追加していきます。
ではまた次回お会いしましょう。
同じテーマ「ユーザーフォーム入門」の記事
第1回.ユーザーフォームを挿入
第2回.フォームのプロパティ
第3回.コントロールの追加(コマンドボタン)
第4回.コントロールの位置・サイズ調整
第5回.ラベルの追加
第6回.テキストボックス(TextBox)の追加
第7回.テキストボックス(TextBox)の値をセルへ
第8回.セルの値をテキストボックスへ
第9回.標準モジュールとフォーム間のデータ受け渡しⅠ
第10回.標準モジュールとフォーム間のデータ受け渡しⅡ
第11回.コンボボックス(ComboBox)の追加
新着記事NEW ・・・新着記事一覧を見る
シート関数のCOUNTIFS,SUMIFS,MAXIFSと同じ処理|Power Query(M言語)入門(2023-02-28)
新旧マスタの差異比較|Power Query(M言語)入門(2023-02-28)
有効な最新単価の取得|Power Query(M言語)入門(2023-02-26)
有効な最新単価の取得|Power Query(M言語)入門(2023-02-21)
グルーブ内の最小・最大|Power Query(M言語)入門(2023-02-17)
2つのテーブルのマージ|Power Query(M言語)入門(2023-02-15)
「売上」が数値の行のみ取り込む|Power Query(M言語)入門(2023-02-13)
A列のヘッダー名を変更する|Power Query(M言語)入門(2023-02-11)
CSVのA列が日付の行だけを取り込む|Power Query(M言語)入門(2023-02-10)
列数不定のCSVの取り込み|Power Query(M言語)入門(2023-02-09)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
6.マクロって何?VBAって何?|VBA入門
7.並べ替え(Sort)|VBA入門
8.エクセルVBAでのシート指定方法|VBA技術解説
9.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
10.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
- ホーム
- マクロVBA応用編
- ユーザーフォーム入門
- フォームのプロパティ
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。