第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 ・・・新着記事一覧を見る
PropertyのSetはLetでも良い|VBA技術解説(2021-03-31)
エクセル麻雀ミニゲーム|VBAサンプル集(2021-03-09)
VBA100本ノック 100本目:WEBから100本ノックのリストを取得|VBA練習問題(2021-03-03)
VBA100本ノック 魔球編:2桁の最小公倍数|VBA練習問題(2021-02-02)
Select Caseでの短絡評価(ショートサーキット)の使い方|VBA技術解説(2021-01-03)
VBA100本ノック 迷宮編:巡回セル問題|VBA練習問題(2020-12-31)
VBA100本ノック 魔球編:閉領域の塗り潰し|VBA練習問題(2020-12-16)
VBA100本ノック 魔球編:組み合わせ問題|VBA練習問題(2020-12-02)
将棋とプログラミングについて~そこには型がある~|エクセル雑感(2020-11-22)
VBA100本ノック 1本目:セルのコピー|VBA練習問題(2020-10-19)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.Excelショートカットキー一覧|Excelリファレンス
6.繰り返し処理(For Next)|VBA入門
7.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
8.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
9.セルに文字を入れるとは(Range,Value)|VBA入門
10.とにかく書いてみよう(Sub,End Sub)|VBA入門
- ホーム
- マクロVBA応用編
- ユーザーフォーム入門
- フォームのプロパティ
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。