‘窗口代码
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
‘窗口代码Option ExplicitDim m_graphics As Long '设备场景的句柄Dim m_Pen As Long '画笔Private Sub Form_Load() InitGDIPlus '初始化 GdipCreateFromHDC Me.hDC, m_graphics '创建自DC图形 GdipCreatePen1 ChangeColo