2009-03-31 10 views
14

Tôi đang làm việc trên một ứng dụng WinForms SmartClient, sử dụng rất nhiều điều khiển RichTextBox - một số thay cho TextBox thông thường vì nhiều lý do khác nhau. Thật không may RichTextBox vẽ biên giới 3D xấu xí Win95 thay vì đường viền theo phong cách XP hoặc Vista theo chủ đề.Làm cách nào để cung cấp cho RichTextBox một giao diện phẳng?

Có ai biết cách áp dụng đường viền theo chủ đề cho RichTextBox không? Tôi không ngại phân lớp chúng cho mục đích này.

Cảm ơn!

+1

thực sự - không có câu trả lời cho điều này? ... mà hút –

+0

Câu hỏi hay với câu trả lời không may! –

Trả lời

27

Đây thực sự là một hack nhưng một điều bạn có thể làm là thả một điều khiển Panel lên trang. Đặt cho nó một BorderStyle của FixedSingle (nó sẽ là None theo mặc định.)

Thả RichTextBox của bạn vào bảng điều khiển và đặt BorderStyle thành không. Sau đó thiết lập thuộc tính Dock của RichTextBox thành Fill.

Điều này sẽ cung cấp cho bạn RichTextBox với đường viền bằng phẳng.

+1

Điều này phải được chấp nhận làm câu trả lời. Nó không phải là một phương pháp thẳng về phía trước nhưng nó hoạt động. – Isuru

+0

Tôi đã làm theo lời khuyên này, ngoại trừ tôi đã sử dụng hộp nhóm. +1 – contactmatt

2

Quay lại trong ngày, tôi phải giải quyết vấn đề này bằng bảng điều khiển nơi hộp văn bản là thành phần bên trong và có DockPadding được đặt thành 3 hoặc 4 pixel. Sau đó tôi sẽ tạo kiểu bảng đó thành một pixel đơn lẻ.

Tôi luôn thấy điều này thực sự gây phiền nhiễu!

+2

Điều này thực sự gây phiền nhiễu và phải có một cách tốt hơn vì điều này không cung cấp cho chủ đề hộp văn bản thực sự. – grover

0

Đây là VB.NET mã, nó thổi phồng vùng nonclient với -1 và sau đó lấp đầy diện tích nonclient với caded màu xanh da trời. Nó có thể được chuyển đổi sang C# bằng SharpDevelop 4.4. Tôi lấy mã từ bài viết này:

http://www.codeproject.com/Articles/13723/Themed-RichTextBox-A-RichTextBox-with-XP-styled-bo

Imports System.Runtime.InteropServices 
Imports System.Windows.Forms 
Imports System.Windows.Forms.VisualStyles 
Imports System.Drawing 
Imports System.Diagnostics 

Public Class FlatRichTextBox 
    Inherits RichTextBox 

    Private BorderRect As RECT 

    Sub New() 
     If VisualStyleInformation.IsEnabledByUser Then 
      BorderStyle = BorderStyle.None 
     End If 
    End Sub 

    Protected Overrides Sub WndProc(ByRef m As Message) 
     Const WM_NCPAINT = &H85 
     Const WM_NCCALCSIZE = &H83 
     Const WM_THEMECHANGED = &H31A 

     Select Case m.Msg 
      Case WM_NCPAINT 
       WmNcpaint(m) 
      Case WM_NCCALCSIZE 
       WmNccalcsize(m) 
      Case WM_THEMECHANGED 
       UpdateStyles() 
      Case Else 
       MyBase.WndProc(m) 
     End Select 
    End Sub 

    Private Sub WmNccalcsize(ByRef m As Message) 
     MyBase.WndProc(m) 

     If Not VisualStyleInformation.IsEnabledByUser Then Return 

     Dim par As New NCCALCSIZE_PARAMS() 
     Dim windowRect As RECT 

     If m.WParam <> IntPtr.Zero Then 
      par = CType(Marshal.PtrToStructure(m.LParam, GetType(NCCALCSIZE_PARAMS)), NCCALCSIZE_PARAMS) 
      windowRect = par.rgrc0 
     End If 

     Dim clientRect = windowRect 

     clientRect.Left += 1 
     clientRect.Top += 1 
     clientRect.Right -= 1 
     clientRect.Bottom -= 1 

     BorderRect = New RECT(clientRect.Left - windowRect.Left, 
           clientRect.Top - windowRect.Top, 
           windowRect.Right - clientRect.Right, 
           windowRect.Bottom - clientRect.Bottom) 

     If m.WParam = IntPtr.Zero Then 
      Marshal.StructureToPtr(clientRect, m.LParam, False) 
     Else 
      par.rgrc0 = clientRect 
      Marshal.StructureToPtr(par, m.LParam, False) 
     End If 

     Const WVR_HREDRAW = &H100 
     Const WVR_VREDRAW = &H200 
     Const WVR_REDRAW = (WVR_HREDRAW Or WVR_VREDRAW) 

     m.Result = New IntPtr(WVR_REDRAW) 
    End Sub 

    Private Sub WmNcpaint(ByRef m As Message) 
     MyBase.WndProc(m) 

     If Not VisualStyleInformation.IsEnabledByUser Then Return 

     Dim r As RECT 
     GetWindowRect(Handle, r) 

     r.Right -= r.Left 
     r.Bottom -= r.Top 
     r.Top = 0 
     r.Left = 0 

     r.Left += BorderRect.Left 
     r.Top += BorderRect.Top 
     r.Right -= BorderRect.Right 
     r.Bottom -= BorderRect.Bottom 

     Dim hDC = GetWindowDC(Handle) 
     ExcludeClipRect(hDC, r.Left, r.Top, r.Right, r.Bottom) 

     Using g = Graphics.FromHdc(hDC) 
      g.Clear(Color.CadetBlue) 
     End Using 

     ReleaseDC(Handle, hDC) 
     m.Result = IntPtr.Zero 
    End Sub 

    <DllImport("user32.dll")> 
    Public Shared Function GetWindowRect(hWnd As IntPtr, ByRef lpRect As RECT) As Boolean 
    End Function 

    <DllImport("user32.dll")> 
    Public Shared Function GetWindowDC(hWnd As IntPtr) As IntPtr 
    End Function 

    <DllImport("user32.dll")> 
    Public Shared Function ReleaseDC(hWnd As IntPtr, hDC As IntPtr) As Integer 
    End Function 

    <DllImport("gdi32.dll")> 
    Public Shared Function ExcludeClipRect(hdc As IntPtr, nLeftRect As Integer, nTopRect As Integer, nRightRect As Integer, nBottomRect As Integer) As Integer 
    End Function 

    <StructLayout(LayoutKind.Sequential)> 
    Public Structure NCCALCSIZE_PARAMS 
     Public rgrc0, rgrc1, rgrc2 As RECT 
     Public lppos As IntPtr 
    End Structure 

    <StructLayout(LayoutKind.Sequential)> 
    Public Structure RECT 
     Public Left As Integer 
     Public Top As Integer 
     Public Right As Integer 
     Public Bottom As Integer 

     Public Sub New(left As Integer, top As Integer, right As Integer, bottom As Integer) 
      Me.Left = left 
      Me.Top = top 
      Me.Right = right 
      Me.Bottom = bottom 
     End Sub 
    End Structure 
End Class 
0

Cách đơn giản nhất để thoát khỏi 3D biên giới là để thiết lập một số khác:

richTextBox.BorderStyle = BorderStyle.FixedSingle; 

Các FixedSingle -BorderStyle là gần nhất với số FlatStyle của ví dụ Nút