How to: Display Web-Style Links with the Windows Forms RichTextBox Control

How to: Display Web-Style Links with the Windows Forms RichTextBox Control


The Windows Forms RichTextBox control can display Web links as colored and underlined. You can write code that opens a browser window showing the Web site specified in the link text when the link is clicked.

To link to a Web page with the RichTextBox control

  1. Set the Text property to a string that includes a valid URL (for example, "").

  2. Make sure the DetectUrls property is set to true (the default).

  3. Create a new global instance of the Process object.

  4. Write an event handler for the LinkClicked event that sends the browser the desired text.

    In the example below, the LinkClicked event opens an instance of Internet Explorer to the URL specified in the Text property of the RichTextBox control. This example assumes a form with a RichTextBox control.

    System_CAPS_security Security Note

    In calling the Process.Start method, you will encounter a SecurityException exception if you are running the code in a partial-trust context because of insufficient privileges. For more information, see Code Access Security Basics.

    Public p As New System.Diagnostics.Process
    Private Sub RichTextBox1_LinkClicked _
       (ByVal sender As Object, ByVal e As _
       System.Windows.Forms.LinkClickedEventArgs) _
       Handles RichTextBox1.LinkClicked
          ' Call Process.Start method to open a browser
          ' with link text as URL.
          p = System.Diagnostics.Process.Start("IExplore.exe", e.LinkText)
    End Sub

    (Visual C++) You must initialize processp, which you can do by including the following statement in the constructor of your form:

    p = gcnew System::Diagnostics::Process();

    (Visual C#, Visual C++) Place the following code in the form's constructor to register the event handler.

    No code example is currently available or this language may not be supported.

    It is important to immediately stop the process you have created once you have finished working with it. Referring to the code presented above, your code to stop the process might look like this:

    Public Sub StopWebProcess()
    End Sub
© 2015 Microsoft