イベントの取得について

解決


EOF  2003-09-25 23:33:21  No: 79554

たびたび申し訳ありません。
イベントの取得方法についてご教授いただきたいです。
例えば、操作上にて「コンボボックス内のデータが切り替わった時」や
「テキストボックスにフォーカスが当たった時」などを拾い、見合った処理を
行ないたいのですが。VisualC++でいうなればWindowプロシージャに当たる記述方法についてご教授宜しくお願いいたします。


EOF  2003-09-25 23:43:58  No: 79555

すいません、ちょっと内容を改めます。
当初の投稿内容に、「テキストにフォーカスが・・・」というのは省いて下さい。
「コンボボックス内のデータが切り替わった時」のプロシージャについて
ご教授ください。


たかみちえ  URL  2003-09-26 00:00:15  No: 79556

用意してあるイベントに対応していないメッセージを拾いたいということでいいですよね?

  それならば、SetWindowLong APIを使って、ウィンドウをサブクラス化することで行えます。
ただし、その間はデバッグがうまくできなくなる上(ブレークポイントなどで止めると、そのまま強制終了することがある)、エラーが一つ起こるたびに、いきなり強制終了することもあります。

  あえて言うのなら、最終手段といったところかもしれません。
  この手の操作はできれば、他の言語でやることをおすすめしますが、できない場合はそれを覚悟の上でやってください。

  あと、サブクラス化中は開発環境の終了ボタンが使えません。
上と同じように強制終了します。
  "デバッグ中はサブクラス化しない"という方法もありますけどね。


たかみちえ  URL  2003-09-26 00:09:50  No: 79557

あ、確認はしてませんけど、SetWindowsHookExを使っても、できるのかもしれません。
  理由はDelphiの非ウィンドウコントロール(Delphiにはウィンドウコントロールではないが、ウィンドウを持っているかのように動作できるグラフィックコントロールがある)で、このAPIを使って親ウィンドウのメッセージをもらっているという話を、聞いたことがあるからです。
  あんまり話を理解できてないので、間違った解釈をしているかもしれませんが。


Say  2003-09-26 01:45:23  No: 79558

>SetWindowLong APIを使って、ウィンドウをサブクラス化することで行えます。
>SetWindowsHookExを使っても、できるのかもしれません。
どちらでも可能ですが、サブクラス化で対応できるなら、
フックする必要はないでしょう。

>あえて言うのなら、最終手段といったところかもしれません。
納品物として作っているのなら、SpyWorksのような
市販のサブクラスコントロールを使ったほうがいいかもしれません。


EOF  2003-10-07 22:06:52  No: 79559

検証時間が無いため、とりあえず解決とします。
Sayさん、たかみちえさん、またよろしくお願いします。


※返信する前に利用規約をご確認ください。

※Google reCAPTCHA認証からCloudflare Turnstile認証へ変更しました。






  このエントリーをはてなブックマークに追加