2009-09-10 1 views
4

Как вы находите местоположение маленького мигающего курсора, где пользователь может печатать, столбца и строки? Я ничего не мог найти.Поиск расположения курсора в текстовом поле в vb.net

+0

Что * точно * вы имеете в виду? WinForms, WebForms, WPF, консольное приложение или что-то еще? –

ответ

14

Если вы имеете в виду WinForms, используйте свойство SeletionStart, чтобы получить доступ к текущей позиции carret. Вот код для получения индекса, текущей строки и текущего столбца.

int index = myTextBox.SelectionStart; 
int currentLine = myTextBox.GetLineFromCharIndex(index); 
int currentColumn = index - myTextBox.GetFirstCharIndexFromLine(currentLine); 
+0

Это сделало, спасибо! – Cyclone

1
' 
' 
' 
'Imports 
Public Class frmMain 
    ' 
    '- See more at: http://www.visual-basic-tutorials.com/Tutorials/Strings/count-how-many-times-a-string-occurs-in-visual-basic.htm#sthash.zPPNxNjl.dpuf 
    ' But I heavily modidied it to suit My style and needs. VS2012 
    ' 
    'Used by the Sub StripPath(ByRef sPath As String) 
    Public PathOnly As String = Nothing 'Global 
    Public FileOnly As String = Nothing 'Global 
    ' 
    Private Sub frmMain_Load(sender As Object, e As EventArgs) Handles MyBase.Load 
     ' 
     Label1.Text = Nothing 
     ' 
     Me.Text = "Text Operations" 
     ' 
    End Sub 
    ' 
    Private Sub btnSearch_Click(sender As Object, e As EventArgs) Handles btnSearch.Click 
     ' 
     MsgBox("The word ''" & tbxSearch.Text & "'' occurs: " & vbCrLf & FindWords(tbxText.Text, tbxSearch.Text) & " time(s).") 
     ' 
    End Sub 
    ' 

    ' 
    Private Sub OpenToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles OpenToolStripMenuItem.Click 
     ' 
     Dim RetVal As String = GetOpenFileName() 
     ' 
     If RetVal <> Nothing Then 
      StripPath(RetVal) 
      ReadAllText(RetVal) 
      Me.Text = FileOnly + " - " + "Text Operations" 
      Label1.Text = PathOnly 
      'MsgBox(PathOnly) 
     End If 
     ' 
    End Sub 
    ' 
    Private Sub ExitToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles ExitToolStripMenuItem.Click 
     ' 
     Application.Exit() 
     ' 
    End Sub 
    ' 
    Private Sub WordCountToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles WordCountToolStripMenuItem.Click 
     ' 
     Dim Prompt As String = "Type the word that you wish to search for." 
     Dim Title As String = "Word Count" 
     Dim DefaultStr As String = "ico" 
     Dim RetVal As String = InputBox(Prompt, Title, DefaultStr) 
     ' 
     If RetVal <> Nothing Then 
      ' 
      tbxSearch.Text = RetVal 
      ' 
      MsgBox("The word ''" & tbxSearch.Text & "'' occurs: " & vbCrLf & FindWords(tbxText.Text, tbxSearch.Text) & " time(s).") 
      ' 
     End If 
     ' 
    End Sub 
    ' 
    Private Function FindWords(ByVal TextSearched As String, ByVal Paragraph As String) As Integer 
     ' 
     Dim location As Integer = 0 
     ' 
     Dim occurances As Integer = 0 
     ' 
     Do 
      ' 
      location = TextSearched.IndexOf(Paragraph, location) 
      ' 
      If location <> -1 Then 
       ' 
       occurances += 1 
       ' 
       location += Paragraph.Length 
       ' 
      End If 
      ' 
     Loop Until location = -1 
     ' 
     Return occurances 
     ' 
    End Function 
    ' 
    Private Sub StripPath(ByRef sPath As String) 
     ' 
     'oFileInfo.DirectoryName returns only the path without the "\" 
     'oFileInfo.Name returns only the filename.and extension. "some file.???" 
     Dim sFile As String = sPath '"c:\mydir\subdir\temp\myfile.txt" 
     Dim ioFileInfo As New System.IO.FileInfo(sFile) 
     PathOnly = ioFileInfo.DirectoryName 'Global 
     FileOnly = ioFileInfo.Name 'Global 
     ' 
    End Sub 'StripPath() 
    ' 
    Private Sub tbxText_Click(sender As Object, e As EventArgs) Handles tbxText.Click 
     'Your Code 
     ''int index = myTextBox.SelectionStart; 
     ''int currentLine = myTextBox.GetLineFromCharIndex(index); 
     ''int currentColumn = index - myTextBox.GetFirstCharIndexFromLine(currentLine); 
     'End Your Code 
     ' 
     Dim index = tbxText.SelectionStart 
     Dim currentLine = tbxText.GetLineFromCharIndex(index) 
     Dim currentColumn = index - tbxText.GetFirstCharIndexFromLine(currentLine) 
     tsslLine.Text = "Ln: " & currentLine 
     tsslCol.Text = "Col: " & currentColumn 
     ' 
    End Sub 
    ' 
    Private Sub tbxText_DoubleClick(sender As Object, e As EventArgs) Handles tbxText.DoubleClick 
     ' 
     tbxSearch.Text = tbxText.SelectedText 
     ' 
    End Sub 
    ' 
End Class 
+0

Мое преобразование в VS2012 .. это в - Private Sub tbxText_Click (отправитель как объект, e As EventArgs) Обрабатывает tbxText.Click – ZipFileX