VB6.0 【GDI+ 画直线】

时间:2022-11-08 10:53:57

VB6.0 【GDI+ 画直线】VB6.0 【GDI+ 画直线】VB6.0 【GDI+ 画直线】

VB6.0 【GDI+ 画直线】

‘窗口代码
Option Explicit
Dim m_graphics As Long '设备场景的句柄
Dim m_Pen As Long '画笔
Private Sub Form_Load()
    InitGDIPlus '初始化
    GdipCreateFromHDC Me.hDC, m_graphics '创建自DC图形
    GdipCreatePen1 ChangeColor(255), 1, UnitPixel, m_Pen '创建画笔
    GdipDrawLineI m_graphics, m_Pen, 20, 100, 560, 100 '画直线I
End Sub

Private Sub Form_Unload(Cancel As Integer)
    GdipDeletePen m_Pen '删除画笔
    GdipDeleteGraphics m_graphics '释放内存
    TerminateGDIPlus  'Gdiplus关闭
End Sub


'模块代码
Option Explicit
    Dim m_token As Long
Public Type GdiplusStartupInput
    GdiplusVersion As Long
    DebugEventCallback As Long
    SuppressBackgroundThread As Long
    SuppressExternalCodecs As Long
End Type

Public Enum GpUnit
    UnitWorld
    UnitDisplay
    UnitPixel
    UnitPoint
    UnitInch
    UnitDocument
    UnitMillimeter
End Enum
'-----------------------------------------------------------------------------------------------------------------------
Public Declare Function GdipCreateFromHDC Lib "gdiplus" (ByVal hDC As Long, Graphics As Long) As Long
Public Declare Function GdiplusStartup Lib "gdiplus" (token As Long, inputbuf As GdiplusStartupInput, Optional ByVal outputbuf As Long = 0) As Long
Public Declare Function GdiplusShutdown Lib "gdiplus" (ByVal token As Long) As Long
Public Declare Function GdipDeleteGraphics Lib "gdiplus" (ByVal Graphics As Long) As Long
Public Declare Function GdipCreatePen1 Lib "gdiplus" (ByVal Color As Long, ByVal Width As Single, ByVal unit As GpUnit, pen As Long) As Long
Public Declare Function GdipDrawLineI Lib "gdiplus" (ByVal Graphics As Long, ByVal pen As Long, ByVal x1 As Long, ByVal y1 As Long, ByVal x2 As Long, ByVal y2 As Long) As Long
Public Declare Function GdipDeletePen Lib "gdiplus" (ByVal pen As Long) As Long
Public Function InitGDIPlus()     '初始化GDI+。使用GID+之前必须初始化 返回一个标记,用作关闭
    Dim StartupInput As GdiplusStartupInput
    Dim token As Long
    StartupInput.GdiplusVersion = 1 '版本 默认为1
    GdiplusStartup token, StartupInput, 0
    m_token = token
End Function

Public Function TerminateGDIPlus()  'Gdiplus关闭
        GdiplusShutdown m_token
End Function
'RGB颜色转换成ARGB
Public Function ChangeColor(ByVal Color As Long, Optional ByVal Alpha As Long = &HFF000000) As Long
    ChangeColor = Alpha Or ((Color And &HFF0000) \ &H10000) Or (Color And &HFF00&) Or ((Color And &HFF&) * &H10000)
End Function