Go Premium for a chance to win a PS4. Enter to Win


Need Round corner text box in Visual Basic 6

Posted on 2010-11-17
Medium Priority
Last Modified: 2012-05-10
Hi Experts,
I need to use text box that has rounded corners, in a Visual Basic 6 application . A customer has specifically asked for rounded-corner text boxes. If anyone has used it or know where to find it, please pass on the information.
Question by:uzairp
  • 3
  • 3
  • 2
  • +1

Author Comment

ID: 34164119
Codebot, The source code is in VB.net that I do not have much experience with. How can I use it in VB6?
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 29

Expert Comment

ID: 34164868
You can create round edges using the following functions. You will want to change the borderstyle of your textboxe to - None to get a decent result. See code block for example.



Option Explicit

Private Declare Function CreateRoundRectRgn Lib "Gdi32.dll" (ByVal nLeftRect As Long, ByVal nTopRect As Long, ByVal nRightRect As Long, ByVal nBottomRect As Long, ByVal nWidthEllipse As Long, ByVal nHeightEllipse As Long) As Long
Private Declare Function SetWindowRgn Lib "User32.dll" (ByVal hWnd As Long, ByVal hRgn As Long, ByVal bRedraw As Long) As Long
Private Declare Function DeleteObject Lib "Gdi32.dll" (ByVal hObject As Long) As Long

Public Sub MakeRound(ByRef t As TextBox)
    Dim hRgn As Long
    hRgn = CreateRoundRectRgn(0, 0, _
        t.Width / Screen.TwipsPerPixelX, _
        t.Height / Screen.TwipsPerPixelX, 5, 5)
    If hRgn Then
        SetWindowRgn t.hWnd, hRgn, 1
        DeleteObject hRgn
    End If

End Sub

Private Sub Form_Load()
    MakeRound Text1
End Sub

Open in new window


Expert Comment

ID: 34185812
An alternate way of creating a textbox with round corners is by using an image and creating a pseudo-round cornered textbox. You could make the image in photoshop then use it as a background for your form or place an image control on the form to contain the picture. Your form would look like this: http://dennisdel.com/wp-content/uploads/2010/07/image4.png. From there, place a text box with no border on top of that picture box and make sure the bounds of the text box fit within the text box image. This is the way I always used to do my custom style controls. It's not perfect, but it works, and it's quick. For any clarifications, just ask :)

Author Comment

ID: 34193532
The textbox looks nice. Would you be able to point me to the code that is ready to be used for the textbox you sent?

Codebot: I have not been able to create the textbox with the example you sent. where do I put the Xml code that is followed by the line, shown in the link you sent?
The manifest XML document required to use XP Visual Styles is as follows:

Accepted Solution

sabrehagen earned 2000 total points
ID: 34193636
I have attached an example solution illustrating the method described in my post above. The jpg in the folder is used as the form background, and the only code on the form sets the background colour of the grey text box. Rounded-Corners.zip

Expert Comment

ID: 34271734
Has this solved your problem uzairp? If so, could you please select a comment as the solution please?

Author Comment

ID: 34388667
Yes, I can use the code example that sabrehagen sent. Thank you.

Featured Post

Ask an Anonymous Question!

Don't feel intimidated by what you don't know. Ask your question anonymously. It's easy! Learn more and upgrade.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Have you ever wanted to restrict the users input in a textbox to numbers, and while doing that make sure that they can't 'cheat' by pasting in non-numeric text? Of course you can do that with code you write yourself but it's tedious and error-prone …
This article describes some techniques which will make your VBA or Visual Basic Classic code easier to understand and maintain, whether by you, your replacement, or another Experts-Exchange expert.
Get people started with the process of using Access VBA to control Outlook using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Microsoft Outlook. Using automation, an Access applic…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
Suggested Courses

927 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question