zoukankan      html  css  js  c++  java
  • VB API 之 第九课 图像编程(二)

    用到2个API函数,Polyiine,Polylineto函数原型如下

    Declare Function Polyline Lib "gdi32" Alias "Polyline" (ByVal hdc As Long, lpPoint As POINTAPI, ByVal nCount As Long) As Long
    Declare Function PolylineTo Lib "gdi32" Alias "PolylineTo" (ByVal hdc As Long, lppt As POINTAPI, ByVal cCount As Long) As Long

    功能说明

      用来绘制线段

    参数

    hdc: Long   //设备的句柄

    lpPoint  指向一个POINTAPI的结构。

    nCount:Long   //lpPoint数组的点数。

    示例:

    Option Explicit
    
    Private Declare Function Polyline Lib "gdi32" (ByVal hdc As Long, lpPoint As point, ByVal nCount As Long) As Long
    Private Declare Function PolylineTo Lib "gdi32" (ByVal hdc As Long, lppt As point, ByVal cCount As Long) As Long
    Private Type point
        x As Long
        y As Long
    End Type
        
    
    
    Dim Flag1 As Boolean
    Dim Flag2 As Boolean
    
    Dim Pos(10) As point
    Dim i As Integer
    
    
    Private Sub Command1_Click()
        Flag1 = True
        Flag2 = False
    End Sub
    
    Private Sub Command2_Click()
        Flag1 = False
        Flag2 = True
    End Sub
    
    Private Sub Command3_Click()
        Flag1 = False
        Flag2 = False
    End Sub
    
    Private Sub Command4_Click()
        Me.Picture1.Cls
    End Sub
    
    Private Sub Form_Load()
        Flag1 = False
        Flag1 = False
        '禁止绘图
        Me.ScaleMode = 3
        Me.Picture1.ScaleMode = 3
        '设置对象坐标的度量单位为像素
        i = 0
    End Sub
    Private Sub Picture1_MouseUp(Button As Integer, Shift As Integer, x As Single, y As Single)
        If Flag1 Then
            Pos(i).x = x
            Pos(i).y = y
        If (i >= 3) Then
            Polyline Me.Picture1.hdc, Pos(0), 4
            Me.Picture1.Circle (x, y), 3
            i = 0
            Exit Sub
        End If
    End If
    '利用PolyLine函数绘图
    
    If Flag2 Then
        Pos(i).x = x
        Pos(i).y = y
        If (i >= 3) Then
            PolylineTo Me.Picture1.hdc, Pos(0), 3
            Me.Picture1.Circle (x, y), 3
            i = 0
            Exit Sub
        End If
    End If
    '利用PolyLineTo函数绘图
    If (i <= 3) Then
        i = i + 1
        Me.Picture1.Circle (x, y), 3
    End If
    End Sub
  • 相关阅读:
    MianShiTi
    C#多线程解决界面卡死问题的完美解决方案
    C#中的WebBrowser控件的使用
    解决Linq第一次调用存储过程时速度慢的问题
    AX 的 NumberSequences
    Ax 从一个form关闭另外一个form,AX全局变量
    查询数据库后台Block 的Sql存储过程
    Dynamic AX 4.0 用户组权限SecurityKey
    20160408 从软件工程的3大文档开始说起
    获取AX的窗口所有控件的lableID及内容
  • 原文地址:https://www.cnblogs.com/delphi2014/p/4026859.html
Copyright © 2011-2022 走看看