![](http://oshiete.xgoo.jp/images/v2/pc/qa/question_title.png?e8efa67)
自作のユーザーコントロールをフォームに貼り付け、
それをクラスに渡してクラス内でそのコントロールのVisibleを制御しようとしておりますが、
フォームからコントロールのVisibleプロパティにアクセスできますが、
クラスからだと、
メソッドまたはデータメンバが見つかりません
とコンパイルエラーが出ます。
そこで、コントロールをControlやUserControlにキャストしてみましたが
型が一致しません
というエラーとなってしまいます。
コントロールにVisibleプロパティの追加を試みましたが、
ActiveXコントロールインタフェースウィザードの使用できる名前に於いて
それらのプロパティが列挙されません。
対象がユーザーコントロールでなく、ボタンなどの標準コントロールの場合は
できたのですが・・・
なにか方法をご存知でしたらご教授ください。
No.1ベストアンサー
- 回答日時:
Visibleプロパティを管理しているのがコンテナ側だからですよ
FormやPictureBoxはコンテナになりますのでフォームにはったUserControlの場合はVisibleプロパティが操作可能です
クラスに渡した UserControlですとこのコンテナが提供するExtenderプロパティを直接操作することが出来ないのではと思います
UserControlにVisibleを操作するプロパティを追加してみましょう
private bVisible as Boolean
Public Property Let MyVisible(value as Boolean)
bVisible = value
' Extenderを通してVisibleを操作
Extender.Visible = value
PropertyChanged "MyVisible"
End Property
Public Property Get MyVisible() as Boolean
MyVisible = bVisible
End Property
Private Sub UserControl_InitProperties()
' プロパティの初期化
bVisible = Extender.Visible
End Sub
Private Sub UserControl_ReadProperties(PropBag As PropertyBag)
bVisible = PropBag.ReadProperty("MyVisible", Extender.Visible)
End Sub
Private Sub UserControl_WriteProperties(PropBag As PropertyBag)
PropBag.WriteProperty "MyVisible", bVisible, Extender.Visible
End Sub
といった具合のコードを追加しておきます
クラス側では
obj.MyVisible = True
または
obj.MyVisible = False
といった具合で操作してみましょう
できました!!!
Extenderプロパティが要点なんですね。
どういうものかいまいちわかっていませんが。
とにかく、これを使ってActiveXコントロールインタフェースウィザードなんか気にせず無理やり実装しちゃえばよさそうですね。
実をいいますとVisible以外にもWidthとかHeightとか必要で結構面倒です(涙)。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(Microsoft Office) EXCELでバーコードを作成すると白くなってコードが見えません 1 2022/04/04 14:24
- C言語・C++・C# ActiveXコントロールを.NETにインポートできない??? 2 2023/05/02 02:50
- Excel(エクセル) コントロールにリンクするセルが選択されない 3 2022/06/12 14:37
- Visual Basic(VBA) EXCEL VBAにて動的にCheckBOXを複数作成し、同BOXにイベントを追加したい 1 2023/03/16 07:05
- Access(アクセス) capeofdragonと申します。 Access2016を使っております。 あるフォームがあり、テ 2 2022/09/09 13:18
- Excel(エクセル) エクセル バーコード作成で他のシートを参照するには? 2 2023/05/03 16:57
- その他(コンピューター・テクノロジー) コントロール+Fキーについて 2 2022/10/03 16:59
- セキュリティホール・脆弱性 論理的アクセス・コントロールに関する問題で悩んでいます 1 2022/10/08 08:42
- Bluetooth・テザリング スマートウォッチについて質問です。 スマートウォッチには音楽コントロール(再生、停止など)ができる機 1 2022/03/27 18:27
- 医学 即時型アレルギーの完全なコントロール技術はいつ出来上がるのでしょうか? 以下、Wikipediaの花 1 2023/04/23 00:00
このQ&Aを見た人はこんなQ&Aも見ています
-
「環境が人を育てる」って本当?環境によって人格や生き方は本当に変わるのか
環境が人生に与える影響は実際どれほどのものなのか、専門家の田宮由美さんに伺った。
-
frxファイルの役目
Visual Basic(VBA)
-
VB6.0のWritePropertyとReadPropertyについて
Visual Basic(VBA)
-
VB6で開発中…標準モジュール間での関数の呼び出し方は?
Visual Basic(VBA)
-
-
4
コンパイルエラー:ユーザ定義型は定義されていません、と出るのですがどのライブラリファイルかわかりません。
Visual Basic(VBA)
-
5
VBの「As String * 128」とは?
Visual Basic(VBA)
-
6
VB6とVB.NETでNullの扱いが違う?
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
カメラスクロールするのを動画...
-
ExcelVBAのコントロールの種類...
-
VBAのフォームでTextBoxがいっ...
-
ExcelVBAでListViewが使用できない
-
Groupboxの配下のコントロール...
-
chr関数の呼び出しで「プロ...
-
無料で使えるグリッドコントロール
-
excel vbaでユーザーフォームに...
-
ACCESS2010のVBAでフォーム内ク...
-
アクセス特有の書き方?
-
OCXって何ですか?
-
C#で角が丸いテキストボックス
-
C#,vb.netで業務用アプリ開発と...
-
VBのフォーム上にPDF文書を表示...
-
VBA ユーザーフォームの Keypre...
-
VBAのエラーについて、”実行時...
-
我慢して心の平和って保てますか?
-
カレンダーコントロール
-
ActiveX
-
Access カレンダー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
カメラスクロールするのを動画...
-
エクセル・VBA CheckBoxのオブ...
-
vb.netで画面のコントロールId...
-
EXCELでactivexコントロールを...
-
C#で角が丸いテキストボックス
-
(VBA)スピンボタンの大量...
-
chr関数の呼び出しで「プロ...
-
変数をコントロール型で使用す...
-
ExcelVBAでListViewが使用できない
-
VBAのエラーについて、”実行時...
-
間違えて配置してしまったコン...
-
VBAのフォームでTextBoxがいっ...
-
Groupboxの配下のコントロール...
-
excelのリストボックスで選択し...
-
ACCESS2010のVBAでフォーム内ク...
-
エクセルVBAでオプションボタン...
-
フォーム上の現在アクティブな...
-
ユーザーフォームで動的(Me.Con...
-
コンボボックスの文字によるif...
-
コントロールを移動できない
おすすめ情報