困ってます。
前回ボタンクリックでチェックボックス768個を全部ONにしたりOFFにしたりするプログラムを教えてもらい何とかできたのですが、768個のチェックボックスを1個1個押したときのプログラムを一つにまとめたい場合は、どうすればよかったのでしょうか。
前回教えてもらった物をヒントに作ったのですが思った動きをしません。
初心者にわかりやすく教えてもらえますか。
ボタンクリックと同じ場所に飛ばしているせいか
Select Case DirectCast(sender, Button).Name
のbuttonでエラーが出ることが分かっています。
ただいろいろやりましたがSelectCase文で行っても1個のチェックボックスには反応しますがほかのチェックボックスは無視します。
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
CheckBoxをButtonにキャストしようとしていることが原因のように思えます。
CheckBoxとButtonを50個ずつ生成し、同じイベントハンドラを共用するサンプルを書いてみたので参考にしてみてください。
CheckBoxの名前は CheckBox00, CheckBox01 ・・・としてあります。
Buttonの名前は Button00, Button01 ・・・としてあります。
Public Class Form1
Private ctlCheck As CheckBox() = {}
Private ctlButton As Button() = {}
Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
Array.Resize(ctlCheck, 50)
Array.Resize(ctlButton, 50)
For i As Integer = 0 To 49
' CheckBoxの作成
ctlCheck(i) = New CheckBox()
ctlCheck(i).Name = "Check" + i.ToString("D2")
ctlCheck(i).Text = i.ToString()
ctlCheck(i).Location = New Point(4, i * 20)
ctlCheck(i).Size = New Size(30, 18)
' Buttonの作成
ctlButton(i) = New Button()
ctlButton(i).Name = "Button" + i.ToString("D2")
ctlButton(i).Text = i.ToString()
ctlButton(i).Location = New Point(80, i * 20)
ctlButton(i).Size = New Size(30, 18)
' イベントハンドラの登録(Clickイベントを同じメソッドで)
AddHandler ctlCheck(i).Click, AddressOf ControlClick
AddHandler ctlButton(i).Click, AddressOf ControlClick
Panel1.Controls.Add(ctlCheck(i))
Panel1.Controls.Add(ctlButton(i))
Next
End Sub
Private Sub ControlClick(ByVal sender As Object, ByVal e As EventArgs)
' コントロールの種類で振り分ける
If TypeOf sender Is Button Then ' senderがButtonの場合
Select Case DirectCast(sender, Button).Name
Case "" ' 割愛
End Select
ElseIf TypeOf sender Is CheckBox Then ' senderがCheckBoxの場合
Select Case DirectCast(sender, CheckBox).Name
Case "" ' 割愛
End Select
End If
' または
' ButtonもCheckBoxもControlから派生しているので、ControlにキャストすればどちらでもNameを取れる
Select Case DirectCast(sender, Control).Name
Case "" ' 割愛
End Select
End Sub
End Class
イベントハンドラをコントロールで分けるのであれば
AddHandler ctlCheck(i).Click, AddressOf CheckBoxClick
AddHandler ctlButton(i).Click, AddressOf ButtonClick
として、CheckBocClickメソッドとButtonClickメソッドを用意してください。引数は上記サンプルのControlClickメソッドと同じです。
返事遅くなりすみません。
回答ありがとうございました。
いろいろと試してみましたが、コントロールを分けるのが一番ベストですね。
後現在、チェックボックスをクリックするとテーブルにより値が入るように考えたのですが、非常に不細工なものになってしまいました。
何かもう少し簡潔なテーブルの設定方法はないものでしょうか。
Dim aa(767, 1) As Integer
Dim x As Short
Dim a As Short
Dim bb As Short
Dim cc As Short
bb = 0
cc = 0
For x = 0 To 1157
For a = 0 To 1
Select Case a
Case 0
If x < 8 Then
bb = bb + 1
aa(x, a) = bb
ElseIf x < 18 Then
If x > 9 Then
bb = bb + 1
aa(x, a) = bb
ElseIf x = 8 Then
bb = 0
End If
省略
ElseIf x < 1158 Then
If x > 1149 Then
bb = bb + 1
aa(x, a) = bb
ElseIf x = 1148 then
bb = 0
End If
End If
Case 1
If x < 8 Then
If x = 0 Then
cc = cc + 1
End If
aa(x, a) = cc
ElseIf x < 18 Then
If x > 9 Then
If x = 10 Then
cc = cc + 1
End If
aa(x, a) = cc
End If
以下省略
End If
End Select
Next
Next
No.2
- 回答日時:
補足のコードを見る限り、a=0のときは
bb = bb + 1
aa(x, a) = bb
と
bb = 0
の2種類に分かれるようですね。さらに、bb = 0とするのは常に定数のようなので、
If a = 0 Then
Select Case x
Case 8, ?, ?, ?, 1148 ' ←ここに bb = 0 にする定数をkカンマ区切りで並べる
bb = 0
Case Else
bb += 1
aa(x, a) = bb
End Select
End If
といった具合にできると思います。次に、a = 1 については特定の値のときに cc = cc + 1 とし、すべてのパターンで aa(x, a) = cc が実施されるように見えます。
If a = 1 Then
Select Case x
Case 0, 10, ?, ?, ?
cc += 1
End Select
aa(x, a) = cc
End If
といった具合にできそうです。
条件判定はもっと複雑なのかもしれませんが全容が見えないのでご提示されたコードの範囲で考えてみました。
配列の上限値とループの上限値が異なるのが気になりますが、コピペミスですかね?(このまま動かすと配列限界を超えます)
またこの処理がチェックボックスの変動とどのように関連するのかも不明です。どのようなことをしたいのか、が明確に教えてもらえればより解決に近い回答が得られると思いますよ。
ありがとうございました。
簡潔にまとめることができました。
本当にありがとうございました。
どのようなことをしたいのか、が明確に教えてもらえればより解決に近い回答が得られると思いますよ。
現在、I/Oボードのチェック用プログラムを作成しています。
1ボードに16個のポートがあり1個のポートに8個のOUTPUTが出来るので128個×6ボード分の768個のOUTPUTがありチェックボックスにチェックを入れるとポート番号と、OUTPUT番号がボードに送られてランプがつき
チェックを外すとランプが消えるプログラムを作成しています。
これで基板の配線ミスやコードのつなぎ間違いなどをチェックします。
配列の上限値とループの上限値が異なるのが気になりますが、コピペミスですかね?(このまま動かすと配列限界を超えます)
私の勘違いでチェックボックスが768個ですがOUTPUT番号とポート番号と連動できるようにチェックボックスの名前の後ろに0,1,2,3,4,5,6,7,10,11,12,13,14,15,16,17,20,21,・・・・・・157,
200,201,202,203,204,・・・357,400,401・・・・,1157
と続けたのですが、番号数ではなくチェックボックスの数で配列の数を決めたので間違えてしまいました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
DataGridViewでセルクリックイ...
-
エクセルVBAで、条件に一致する...
-
Labelコントロールに数字を代入...
-
エクセルVBAにおけるON TIMEメ...
-
Application.Wait の参照設定
-
エクセルのマクロでプリンタを...
-
drawStringで文字間隔の調整
-
VBPをダブルクリックするとたま...
-
VBA/FIND関数を使っての先頭文...
-
コマンドプロンプト実行後に画...
-
ArrayListのgetメソッドが実行...
-
FEM解析の読み方は?
-
PropertyGridの中央の縦線
-
IDispatch と dispinterface の...
-
mainメソッドのthrows節で設定...
-
引数は省略できません。とのコ...
-
Refreshメソッドの使い方
-
JAVAのメソッドがありますが
-
【sendkeysメソッドが動かずに...
-
変数名の付け方
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
DataGridViewでセルクリックイ...
-
コマンドプロンプト実行後に画...
-
Labelコントロールに数字を代入...
-
エクセルVBAにおけるON TIMEメ...
-
JSPで<SELECT>の中にDBから持っ...
-
ウィンドウを最前面にできません
-
final修飾子を使っているのに、...
-
【sendkeysメソッドが動かずに...
-
mainメソッドのthrows節で設定...
-
Application.Wait の参照設定
-
onClickで関数呼出し後に、結果...
-
VBA コピーが出来ません…!
-
VBPをダブルクリックするとたま...
-
javascriptからjavaを呼び出したい
-
Refreshメソッドの使い方
-
配列のメソッド
-
エクセルのマクロでプリンタを...
-
boolean型のフィールドとゲッタ...
-
C#で右からnカラム目に文字を挿...
おすすめ情報