VB6 TextBoxの先頭が自動改行される件について

このQ&Aのポイント
  • Visual Basic 6.0を使用してメモを作成する際、Text1からText2への転写は問題なく行えるが、2回目以降にText1の先頭が自動改行される現象が発生する。
  • Text1の先頭自動改行の件について、見た目の問題を解決する方法をお探しです。
  • VB6でのメモ作成時にText1の先頭自動改行が起きる問題があり、解決策をご教授いただけませんか。
回答を見る
  • ベストアンサー

VB6 TextBoxの先頭が自動改行されてしまう

中を見ていただき、ありがとうございます。 Visual Basic 6.0 をWinXP SP3で使って、メモを作っています。 機能としては非常に単純で、書き込み用のテキストボックス(以下Text1とします)と記録用のテキストボックス(つまりLocked=Trueとして書き込めないようにしている:以下Text2とします)があって、(1)Text1にメモを書いてEnterを押せば、(2)その内容がText2に転写され、(3)Text1の内容は消える、というものです。 ところが、以下のプログラムによってこれを実装しようとしたところ、Text1からText2への転写はうまくいくものの、2回目以降はText1の1行目が自動的に改行された状態になってしまい、必ず2行目から文章を打たなくてはいけないようになってしまいます。 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then Text2.Text = Text2.Text & vbclrf & Text1.Text Text1.Text = "" End If End Sub 使用する上では特に問題無いのですが、見た目が少し悪いので、この1行目の「自動改行」をキャンセルする方法をご存知の方がいらっしゃいましたら、ご教授くださいますようお願い致します。

質問者が選んだベストアンサー

  • ベストアンサー
回答No.13

>ただ、このコードでは、半角文字を2つ打った瞬間にText1の内容がすべて消えてしまいますので、全角のメモにしか使えません(vbの処理が追いつかないぐらい早く連打すればいけますが)。ですから、やはりText1へのvbCrLfをキャンセルしないといけないですね。 本来テキストボックスに入力する前に、Text1.Text = "" のようにクリアして置くべきで 当然投稿されたコード以外の所でクリアされている物と思っていたのですが。 下記を試して見て下さい。 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then If Text2.Text = "" Then '1行目の書き込みの場合 Text2.Text = Text1.Text Else '2行目以降の書き込みの場合 Text2.Text = Text2.Text & vbCrLf & Text1.Text End If 'ここではText1.Text 内の vbCrLf が消えません。 Text1.Text = "" End If End Sub Private Sub Text1_KeyUp(KeyCode As Integer, Shift As Integer) '下記のようにして消すか If KeyCode = 13 Then Text1.Text = "" End If End Sub 又は、 Private Sub Text1_GotFocus() '入力前に消すか '本来は、 Text1.Text = ""  ですが If Text1.Text = vbCrLf Then Text1.Text = "" End If End Sub >ところで、もしかして「VBレスキュー花ちゃん」の花ちゃん様でしょうか。 そうです。

Caryo_t
質問者

お礼

ご回答ありがとうございます。 >>ところで、もしかして「VBレスキュー花ちゃん」の花ちゃん様でしょうか。 >そうです。 そうでしたか。ここでお会いできるとは幸運です。 何年も、困ったときにはお世話になっています。 主に私は6.0を使っていますので、昔のものを残しておいていただいているのがとても助かります。 今後とも、できれば残しておいていただけますと、1ファンとしては嬉しいです。 >本来テキストボックスに入力する前に、Text1.Text = "" のようにクリアして置くべきで ちょうどチャットのように、書き込みながら履歴を参照するということをしたかったので、Enterのタイミングで消すことを前提にしていました。 いずれにいたしましても、KeyUpイベントを受けて If KeyCode = 13 Then Text1.Text = "" とすることで解決いたしました。 ありがとうございました。 この場をお借りして tissue001様、また、他の回答者の皆様にも心より御礼申し上げます。 ベストアンサーしか選べなくなっているため、解決方法を教えてくださったので、vbhanatyan様を選ばせていただきますが、あしからずご了承いただき、今後ともお知恵をお貸しいただけますようお願い申し上げます。

その他の回答 (12)

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.12

お騒がせいたしました。 今回、私が一番初めにe.Handled = Trueと回答した後に No.6さんが >End Sub の前に Keycode = 0 と入れてみたら? >Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) >If KeyCode = 13 Then >Text2.Text = Text2.Text & vbclrf & Text1.Text >Text1.Text = "" >End If >Keycode = 0 '←位置を変えたほうが良いかも >Text2.Text = mid(Text2.Text,3) '←乱暴な気がするけど・・ >End Sub Keycode = 0 '←位置を変えたほうが良いかも は試しましたか? Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then Keycode = 0 '←この位置にに変えてみて下さい。 Text2.Text = Text2.Text & vbclrf & Text1.Text Text1.Text = "" End If Text2.Text = mid(Text2.Text,3) '←乱暴な気がするけど・・ End Sub こうする事で、EnterをKeyDownからKeyUpまでをなかった事にしてくれるかもしれません。 なにぶんvb2008しかわかりません。

Caryo_t
質問者

お礼

ご回答ありがとうございます。 こちらこそ、お騒がせしており、申し訳ございません。 どうやらVB6は、変なところはいい加減なのに、ここは融通が利かないようで、キャンセルできませんでした。簡単っぽくみえるのですが、以外に難問ですね。

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.11

Caryo_t さんごめんなさい。 ちょっと引けなくなったので... >そもそも、下記コードで、Text1.Text に vbCrLf が入ると勘違いされているのが原因では。 >KeyDown イベントでは入力が確定していないので、Text1.Text には、 >vbCrLf が書き込まれていません。 >KeyUP イベントなら書き込まれますが。 vbcrlfが書き込まれるタイミングはわかりませんが、 質問内容の > 以下のプログラムによってこれを実装しようとしたところ つまりKeyUpまでを行っているんです。 ゆえに、質問者さんのText1にvbcrlfが書き込まれているんです。 質問者さんは、このText1に入るvbcrlfを取り消したいと言っているんです。 確かに1回目の実行時には、Text2は初めは空なので、1行目に改行は入るでしょう。 でも、それに対して困っているのではありません。 勿論、質問者さまは初めのあなたの回答に >この短いサンプルコードにも、いくつも不足している部分があって、お恥ずかしいです。 >Text2の一番初めには、そのような条件設定が必要になるようですので、 >気をつけます。ありがとうございました。 と言っています。 つまり、こんな事も考えなくてはいけないのですね...って事なのです。 Text2に意図しない改行が入るという事を今回質問したのではないのです。

Caryo_t
質問者

お礼

コメントありがとうございます。 また、お気遣いいただきありがとうございました。 ご指摘の通りですので、どうか収めていただけますようお願い致します。 お二人のコメントを通じ、Text1にvbCrLfが書き込まれるタイミングがKeyUp時であることが判りましたので、KeyUp時にText1の長さを調べて、それが2であったなら(つまり改行だけであったなら)Text1の内容を消すようにしてみました。 このコードでは、Text2の先頭の改行は消していませんが、これはvbhanatyan様のご回答をもとに対応しようと思います。 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then If Text1.Text <> "" Then Text2.Text = Text2.Text & vbCrLf & Text1.Text Text1.Text = "" End If End If End Sub Private Sub Text1_KeyUp(KeyCode As Integer, Shift As Integer) If Len(Text1.Text) = 2 Then Text1.Text = "" End Sub ただ、このコードでは、半角文字を2つ打った瞬間にText1の内容がすべて消えてしまいますので、全角のメモにしか使えません(vbの処理が追いつかないぐらい早く連打すればいけますが)。ですから、やはりText1へのvbCrLfをキャンセルしないといけないですね。

回答No.10

>> 2回目以降はText1の1行目が自動的に改行された状態になってしまい、 >> 必ず2行目から文章を打たなくてはいけないようになってしまいます。 >あなたは、どう捉えますか? Text2.Text = Text2.Text & vbclrf & Text1.Text では Text2.Text に何も書き込まれていない状態の時にvbCrLf & Text1.Text がかきこまれるので 改行する必要が無い状態で改行しているから先頭行が vbCrLf だけの空行ができるのです。 そもそも、下記コードで、Text1.Text に vbCrLf が入ると勘違いされているのが原因では。 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then Text2.Text = Text2.Text & vbclrf & Text1.Text Text1.Text = "" End If End Sub KeyDown イベントでは入力が確定していないので、Text1.Text には、vbCrLf が書き込まれて いません。 KeyUP イベントなら書き込まれますが。 Form にテキストボックス2個貼り付けて下記コードを試して見て下さい。 Text1 に 1 2 3 a 個別にキー入力して見て下さい。 () Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 65 Then Text2.Text = Text2.Text & vbCrLf & Text1.Text Text1.Text = "" End If End Sub

Caryo_t
質問者

お礼

コメントありがとうございます。 >Text2.Text = Text2.Text & vbclrf & Text1.Text では >Text2.Text に何も書き込まれていない状態の時にvbCrLf & >Text1.Text がかきこまれるので >改行する必要が無い状態で改行しているから先頭行が >vbCrLf だけの空行ができるのです。 これは知りませんでした。 ご教授いただいたコードを試してみましたところ、たしかにText1に「a」が取り残されたまま、123だけがText2に移りました。 これと同様にして、「改行」が取り残されたまま、Text1の内容がText2に移っているのですね。あとは改行を失くすだけですが、Text1.Text=""で改行が消えないのが不思議ですね…。 いや、よく考えると不思議でもないのでしょうか。もう少し考えてみます。

Caryo_t
質問者

補足

他の方へのお礼と一部重複いたします無礼をお許し下さい。 お二人のコメントを通じ、Text1にvbCrLfが書き込まれるタイミングがKeyUp時であることが判りましたので、KeyUp時にText1の長さを調べて、それが2であったなら(つまり改行だけであったなら)Text1の内容を消すようにしてみました。 このコードでは、Text2の先頭の改行は消していませんが、これはvbhanatyan様のご回答をもとに対応しようと思います。 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then If Text1.Text <> "" Then Text2.Text = Text2.Text & vbCrLf & Text1.Text Text1.Text = "" End If End If End Sub Private Sub Text1_KeyUp(KeyCode As Integer, Shift As Integer) If Len(Text1.Text) = 2 Then Text1.Text = "" End Sub ただ、このコードでは、半角文字を2つ打った瞬間にText1の内容がすべて消えてしまいますので、全角のメモにしか使えません(vbの処理が追いつかないぐらい早く連打すればいけますが)。ですから、やはりText1へのvbCrLfをキャンセルしないといけないですね。 ところで、もしかして「VBレスキュー花ちゃん」の花ちゃん様でしょうか。 そうであるならば、光栄です。昔からいつも大変お世話になっております。

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.9

喧嘩しているつもりはないけど... 質問者さんの質問文 > 2回目以降はText1の1行目が自動的に改行された状態になってしまい、 > 必ず2行目から文章を打たなくてはいけないようになってしまいます。 > この1行目の「自動改行」をキャンセルする方法 あなたは、どう捉えますか? 私はText1に意図しない改行が入る事を防ぐ事は今回の質問者さんの質問だととらえます。 あなたは > 質問者が困っているのは、Text2.Text の先頭行に空行(VbCrLf だけの)が入ってしまうと > 言う事じゃないですか? だと言う。 Text2の先頭行に空白が入っているという文は、どこにも出てきません。 私は恥をかきましたか? どうでしょうか?

Caryo_t
質問者

お礼

質問を整理していただき、ありがとうございます。 これも横レスのようになってしまうのですが、仰るとおり「Text1に改行が入る」のが私の困っている点です。 Text1とText2ではなく、MotoTxtとSakiTxtとしておけばよかったですね。すみません。

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.8

喧嘩しているつもりはないけど... 質問者さんの質問ぶん > 2回目以降はText1の1行目が自動的に改行された状態になってしまい、 > 必ず2行目から文章を打たなくてはいけないようになってしまいます。 あなたは、どう捉えますか?

Caryo_t
質問者

お礼

コメントありがとうございます。 私に対するご質問ではないので、なんだか横レスのようになってしまって恐縮ですが、私の困っておりますのは「Text1に改行が入ること」です。 誤解を招いておりますのは私の書き方のようですので、何卒穏便にお力をお貸しいただければと思います。

回答No.7

No.5 回答者:tissue001 回答日時:2011/01/26 11:52 よく試して書かないと恥をかくのは貴方ですよ。 >この回答は、質問者様がこまっているものとは違う種のものです。 元質問者が困っているのは、Text2.Text の先頭行に空行(VbCrLf だけの)が入ってしまうと 言う事じゃないですか? 元質問内容(Text1からText2への転写はうまくいくものの、2回目以降はText1の1行目が 自動的に改行された状態になってしまい...。) 勿論、それに対して答えた回答も間違っていませんよ。 No.6 で答えておられる if Text2.Text = "" then   Text2.Text = Text1.Text else   Text2.Text = Text2.Text & vbclrf & Text1.Text end if と同じ事です。

Caryo_t
質問者

お礼

ご回答、ありがとうございます。 少し離席している間に、多くの書き込みがあり、びっくりいたしました。 私の書き方が誤解を招いてしまっているようです。 Text2にも、確かに不必要な改行が入ってしまうかもしれませんが、今困っておりますのは、Text1に入る改行の方です。 つまり、Text1に文字を打って行き、その文字がEnterであれば、Text2にText1の内容をすべて移すということをしているのですが、Enterはこの「転写のきっかけ」であると同時に、Text1の中では「改行」の意味も持つため、Text1では常に1行目が改行されているようなのです。 ご回答に感謝いたしますとともに、わかりにくい質問文、そして不完全なコードで誤解を招いてしまいましたことをお詫びいたします。

  • nicotinism
  • ベストアンサー率70% (1019/1452)
回答No.6

End Sub の前に Keycode = 0 と入れてみたら? 個人的にはText2.Textのいちばん最初に改行コードが入ってしまう方が気になるけど と思ったらレスがついてるので、 Private Sub Text1_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then Text2.Text = Text2.Text & vbclrf & Text1.Text Text1.Text = "" End If Keycode = 0 '←位置を変えたほうが良いかも Text2.Text = mid(Text2.Text,3) '←乱暴な気がするけど・・ End Sub とかでは? No4さんの方向だと if Text2.Text = "" then Text2.Text = Text1.Text else Text2.Text = Text2.Text & vbclrf & Text1.Text end if ということを言いたかったのでは?

Caryo_t
質問者

お礼

ご回答ありがとうございます。 なるほど、KeyCodeを0にしてキャンセルするのですね。 結果としてはうまくいかなかったのですが、たいへんさんこうになりました。ありがとうございます。 ところで、最後でMidを使うと奇妙な動きをしますね。順を追って理解すれば解るのですが、面白いと思いました。

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.5

> Text2.Text="" の時に下記のコードを実行すると >>Text2.Text = Text2.Text & vbclrf & Text1.Text >空のText2.Text に vbclrf & Text1.Text を書き込む事になり >先頭行が改行だけの空行ができるのです。 これは間違いです。 Text2.TextはText2.Text & vbclrf & Text1.Text が入ります。 >従って、 >If Text2.Text="" Then >Text2.Text = Text1.Text >End If これは間違いなので、従わないでください。 >この種の事は、vbclrf を前に付けるか、後ろにつけるかによって >同様の処理をする必要があります。 この回答は、質問者様がこまっているものとは違う種のものです。

Caryo_t
質問者

お礼

ご指摘、ありがとうございます。 tissue001さんの仰るとおりした。テキストの処理は、ケアレスミスが多いので、大変参考になりました。ありがとうございました。

回答No.4

Text2.Text="" の時に下記のコードを実行すると >Text2.Text = Text2.Text & vbclrf & Text1.Text 空のText2.Text に vbclrf & Text1.Text を書き込む事になり 先頭行が改行だけの空行ができるのです。 従って、 If Text2.Text="" Then Text2.Text = Text1.Text End If のように条件設定をする必要があります。 この種の事は、vbclrf を前に付けるか、後ろにつけるかによって 同様の処理をする必要があります。

Caryo_t
質問者

お礼

ご回答ありがとうございます。 この短いサンプルコードにも、いくつも不足している部分があって、お恥ずかしいです。 Text2の一番初めには、そのような条件設定が必要になるようですので、気をつけます。ありがとうございました。 追伸 もしかして「VBレスキュー花ちゃんの」花ちゃん様でしょうか。

  • tissue001
  • ベストアンサー率21% (28/132)
回答No.3

No.2です。 補足です。 要はText1でのKeyDoown時にEnterが押されたのを取り消してあげればいいのです。 KeyDown時にEnterを認識して改行が入っています。

Caryo_t
質問者

お礼

重ねてのご回答、ありがとうございます。 そうですね。何らかの方法でできると思いますので、探してみます。原因をご指摘いただき、ありがとうございました。

関連するQ&A

  • テキストボックスのエンターキー無効

    VB6.0について質問いたします。 テキストボックスの入力の際に改行を強制的にできないように制御したいのですが次のプログラムでは上手くいきませんでした。 Private Sub Text_KeyDown(KeyCode As Integer, Shift As Integer) If vbcode = vbKeyReturn Then Exit Sub End If End Sub エンターキーを押したとき何も実行しないようにするにはどうしたらいいですか? テキストボックスはスクロールバーを設置してMultiLine プロパティをtrueに設定しています。

  • テキストボックスでMAX文字数を入れたらTABで飛びたい

    テキストボックスで、2バイト入力されたらTABで次のテキストボックス に移動すると言うイベントを4つのテキストボックスのKeyUpイベント に記述しました。 サンプルとして一つ書きます。 Private Sub Text1_KeyUp(KeyCode As Integer, Shift As Integer) If Len(Text1.Text) = 2 Then SendKeys "{TAB}" KeyCode = 0 End If End Sub 上記のソースでプログラムを実行し、Text1に2バイト入力されると、 次のテキストボックス(Text2)に移動します。 更にText2,Text3に、2バイト入力しますと、カーソルがText4に来ます。 ここで、マウスでText1にカーソルを持っていき、値を変更すると、 Text2に移動するはずが、Text4にカーソルが移動します。 なぜでしょうか?? くだらない質問ですが、よろしくお願いします。

  • ユーザーフォームのTextBoxの操作について

    皆様、こんにちは。 いつもお世話になっております。 ユーザーフォームのテキストボックスに何も入力されていないと自動的に0が表示されるようにしたいですが、エラーが出てしまいます。 具体的に、 1テキストボックス 2テキストボックス ・・・ 合計テキストボックス があって、詳細が分からなくて合計のテキストボックスにのみ入力する時に、合計テキストボックスをクリックしたときにその他のボックスに0が表示されるように書きたいです。 Private Sub TextBox9_Enter() Dim i As Integer For i = 1 To 8 If TextBox(i).Text = "" Then TextBox(i).Text = "0" End If Next i End Sub のように考えましたが、間違っていますね。 教えていただければ幸いです。 どうぞよろしくお願いいたします。

  • VB2008改行できません

    VB2008改行できません お願いします。 メロンパン 3個 240円 コロッケパン 2個 … という風にしたいのですが、 一行目が表示され、2行目の「コロッケパン」を入れた瞬間、 1行目が消え、 コロッケパンのみが表示されます。 なぜでしょうか。 正しいコードと、どのような理屈でそうなるのか頂けると嬉しいです。 Public Class Form1 Dim cm, a As String Dim kosu, en As Integer Private Sub ShapeComboBox_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ShapeComboBox.SelectedIndexChanged cm = ShapeComboBox.Text End Sub Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click kosu = TextBox1.Text Select Case ShapeComboBox.SelectedIndex Case 0 en = kosu * 120 Case 1 en = kosu * 180 Case 2 en = kosu * 240 End Select txtKaimono.Text = cm + kosu.ToString(" ##個") + en.ToString(" #,###円") + vbCrLf End Sub Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click Application.Exit() End Sub End Class

  • TextBox内で日本語入力中を判断する方法

    TextBox内で「Enter」PUSHの有無を下記コードで実現しておりますが Private Sub TextBox1_KeyUp(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then     処理 End If End Sub 日本語変換の際(もじ→文字)の「Enter」を処理対象外にする方法を教えていただけないでしょうか? もしくは日本語入力中を判断する方法を教えていただけないでしょうか? 言語はVB6.0です。 よろしくお願い致します。

  • vb コンボボックスのイベントについて

    こんばんわ。 コンボボックスで、 指定の値をマウス操作でクリックしたときと、 キーボードの上下で、移動後returnを押したときだけ、 MsgBox "処理実行" を実行したいです。 keystateを使ってみたのですが、前の情報が残っているのかうまくいきません。keystateの情報をクリアさせるか、シンプルに上記を動作させる何かよい方法はありますでしょうか。 Private Declare Function GetKeyState Lib "user32" (ByVal nVirtKey As Long) As Integer Dim flg1 As Boolean Private Sub form_load() Combo1.AddItem (11) Combo1.AddItem (22) Combo1.AddItem (33) Combo1.AddItem (44) End Sub Private Sub Combo1_Keyup(KeyCode As Integer, Shift As Integer) If KeyCode = 13 Then 'return flg1 = True Call Combo1_click End If End Sub Private Sub Combo1_click() If (GetKeyState(&H26) <> 0) Or (GetKeyState(&H28) <> 0) Then ' ↑↓ If flg1 = False Then Exit Sub End If End If MsgBox "処理実行" flg1 = False End Sub

  • エクセル VBA タブストップに対する質問2

    下記の「エクセル VBA タブストップに対する質問」に書き込みした者ですが、一難去ってまた一難です。又、暗雲が漂ってきました。 条件は下記といっしょで テキストボックスが1~5まであり、テキストボックス2~4まではデータが入っています。 全てのTabStopはTrue、TabIndexは順に1~5が入っています。 テキストボックス1に何もデータを入れないで、Enterが押された場合、 テキストボックス1をアクティブにしたいのですが、下記で質問した回答で動かしても、きちんと動いてくれません。 どうかご指導よろしくお願いいたします。 Private Sub TextBox1_KeyDown(ByVal KeyCode As MSForms.ReturnInteger, ByVal Shift As Integer) If KeyCode = 13 Then 'ENTER If TextBox1.Value = "" Then TextBox1.SetFocus End If End If End Sub このコードでテキストボックス1に何も入れずにEnterを押すとテキストボックス2がアクティブになってしまいます。

  • 特定の文字だけ太文字にするには・・

    簡易チャット作ってます。発言者の名前の部分だけ太文字にしようとしてい ます。 テキストボックス2に文を書いてエンターを押すとテキストボックス1に書 花子:~~~  と書き込まれるようにはできました。花子の部分 だけふと文字にするには?? Private Sub Text2_KeyPress(KeyAscii As Integer) If (KeyAscii = 13) Then Text1.Text = Text1.Text + "花子:" + Text2.Text + vbCrLf Text2.Text = "" KeyAscii = 0 End If End Sub

  • VB6.0 KeyDownイベントの対応

    VB6.0を使ってプログラム中ですが、下記の  Command10_KeyDown で、複合キー「 Ctrl + ↓」 だとイベント KeyDown を受信できるのですが、単純な キー「↓」だと、イベント KeyDown を受信でず、他のボタンにフォーカスが移ってしまいます。 Comman10_GotFocus に何か対応策を入れて、単純な キー「↓」のイベント KeyDown を受信する方法はないでしょうか? Private Sub Command10_KeyDown(KeyCode As Integer, Shift As Integer) If KeyCode = 40 Then execsub001() End If End Sub Private Sub Commnad10_Click() execsub001() End Sub Private Sub Comman10_GotFocus() 上記問題への対応策を此処に記述したい End If Private Sub execsub110() 内容は省略 End Sub

  • VBのプログラム

    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click If Not Integer.TryParse(TextBox1.Text, rows) OrElse _ Not Integer.TryParse(TextBox2.Text, columns) OrElse _ Not Integer.TryParse(TextBox3.Text, number) Then MessageBox.Show("数字で入力してください", Me.Text, MessageBoxButtons.OK, MessageBoxIcon.Error) Exit Sub End If Me.Bounds = New Rectangle(10, 10, 1300, 900) Dim cnt As Integer = 0 For k As Integer = 1 To number For i As Integer = 1 To rows For j As Integer = 1 To columns Dim tb As TextBox = New TextBox() cnt += 1 tb.Name = "tb" + cnt.ToString() Me.Controls.Add(tb) tb.Top = (i - 1) * 20 + 70 tb.Left = (j - 1) * 50 + 60 * (columns * (k - 1)) + 5 tb.Width = 55 Next Next Next End Sub これはボタンを押すと テキストボックスに入力された値分だけテキストボックスが出てくるというものです。 例えば 3 4 4とテキストボックスに値が入力された場合 3行4列が4個分テキストボックスが出てきます。 しかし6 6 6と入力した場合画面に入りきらなくなってしまいます。 大きな値を入力しても画面に入れたいです。 これはスクロールなどしてできるようにしたいです。 どのようなソースでできるのでしょうか。

専門家に質問してみよう