用vb创建不规则窗口    迄今为止,我们用vb编制的程序窗口大都是标准的四方形,看上去很没有个性。如果你想让你的程序与众不同的话,可以利用以下几个api函数来创建不规则窗口:
   createrectrgn(byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) '创建一个矩形区域,四个参数分别代表左、上、右、下的坐标;
   createellipticrgn(byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) '创建一个椭圆形区域,参数同上;
   createpolygonrgn(ppoint as pointapi, byval ncount as long, byval npolyfillmode as long) '创建一个多边形区域,ppoint参数为一个pointapi型数组,ncount参数说明顶点数,npolyfillmode参数为填充模式;
   combinergn(byval hdestrgn as long, byval hsrcrgn1 as long, byval hsrcrgn2 as long, byval ncombinemode as long) '合并两个区域,hdestrgn是合并后的区域,hsrcrgn1和hsrcrgn2是欲合并的目标区域,ncombinemode为合并方式;
   setwindowrgn((byval hwnd as long, byval hrgn as long, byval bredraw as boolean) '设置窗体为指定样式,hrgn为上述几个函数创建的区域,bredraw决定是否立即重画窗体。
   有了这些“神兵利器”,我们就可以随心所欲地制作出各式各样的窗体。示范程序如下:
   private declare function createellipticrgn lib "gdi32" (byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) as long
   private declare function setwindowrgn lib "user32" (byval hwnd as long, byval hrgn as long, byval bredraw as boolean) as long
   private sun form_load()
   dim x,y as long
   x=createellipticrgn(0,0,100,200)
   y=setwindowrgn(me.hwnd,x,true)
   end sub
   以上程序可以创建一个椭圆形窗体,并在vb6.0,win 98环境下调试通过。有兴趣的朋友可以参考以上的api函数以及示范程序编写其它几种不规则窗口。

解决方案 »

  1.   

    用vb创建不规则窗口    迄今为止,我们用vb编制的程序窗口大都是标准的四方形,看上去很没有个性。如果你想让你的程序与众不同的话,可以利用以下几个api函数来创建不规则窗口:
       createrectrgn(byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) '创建一个矩形区域,四个参数分别代表左、上、右、下的坐标;
       createellipticrgn(byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) '创建一个椭圆形区域,参数同上;
       createpolygonrgn(ppoint as pointapi, byval ncount as long, byval npolyfillmode as long) '创建一个多边形区域,ppoint参数为一个pointapi型数组,ncount参数说明顶点数,npolyfillmode参数为填充模式;
       combinergn(byval hdestrgn as long, byval hsrcrgn1 as long, byval hsrcrgn2 as long, byval ncombinemode as long) '合并两个区域,hdestrgn是合并后的区域,hsrcrgn1和hsrcrgn2是欲合并的目标区域,ncombinemode为合并方式;
       setwindowrgn((byval hwnd as long, byval hrgn as long, byval bredraw as boolean) '设置窗体为指定样式,hrgn为上述几个函数创建的区域,bredraw决定是否立即重画窗体。
       有了这些“神兵利器”,我们就可以随心所欲地制作出各式各样的窗体。示范程序如下:
       private declare function createellipticrgn lib "gdi32" (byval x1 as long, byval y1 as long, byval x2 as long, byval y2 as long) as long
       private declare function setwindowrgn lib "user32" (byval hwnd as long, byval hrgn as long, byval bredraw as boolean) as long
       private sun form_load()
       dim x,y as long
       x=createellipticrgn(0,0,100,200)
       y=setwindowrgn(me.hwnd,x,true)
       end sub
       以上程序可以创建一个椭圆形窗体,并在vb6.0,win 98环境下调试通过。有兴趣的朋友可以参考以上的api函数以及示范程序编写其它几种不规则窗口。
      

  2.   

    SetWindowRgn VB声明 
    Declare Function SetWindowRgn Lib "user32" Alias "SetWindowRgn" (ByVal hWnd As Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) As Long 
    说明 
    这是那些很难有人注意到的对编程者来说是个巨大的宝藏的隐含的API函数中的一个。本函数允许您改变窗口的区域。
    通常所有窗口都是矩形的——窗口一旦存在就含有一个矩形区域。本函数允许您放弃该区域。这意味着您可以创建圆的、星形的窗口,也可以将它分为两个或许多部分——实际上可以是任何形状 
    返回值 
    Long,执行成功为非零值,失败为0 
    参数表 
    参数 类型及说明 
    hWnd Long,将设置其区域的窗口 
    hRgn Long,将设置的区域的句柄,一旦设置了该区域,就不能使用或修改该区域句柄,也不要删除它 
    bRedraw Boolean,若为TRUE,则立即重画窗口 
    注解 
    为区域指定的所有坐标都以窗口坐标(不是客户坐标)表示,它们以整个窗口(包括标题栏和边框)的左上角为起点
      

  3.   

    CreatePolygonRgn VB声明 
    Declare Function CreatePolygonRgn Lib "gdi32" Alias "CreatePolygonRgn" (lpPoint As POINTAPI, ByVal nCount As Long, ByVal nPolyFillMode As Long) As Long 
    说明 
    创建一个由一系列点围成的区域。windows在需要时自动将最后点与第一点相连以封闭多边形 
    返回值 
    Long,执行成功为创建的区域句柄,失败则为0 
    参数表 
    参数 类型及说明 
    lpPoint POINTAPI,nCount个POINTAPI结构中的第一个POINTAPI结构 
    nCount Long,多边形的点数 
    nPolyFillMode Long,描述多边形填充模式。可为ALTERNATE 或 WINDING常数。参考SetPolyFillMode函数对多边形填充模式的解释 
    注解 
    不用时一定要用DeleteObject函数删除该区域
     
      

  4.   

    必須借助 CreateEllipticRgn 及 SetWindowRgn 二個 API  
    ,例如:  
    Private Declare Function CreateEllipticRgn Lib "gdi32" (ByVal X1 As _ 
    Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long 
    Private Declare Function SetWindowRgn Lib "user32" (ByVal hWnd _ 
    As Long, ByVal hRgn As Long, ByVal bRedraw As Boolean) As Long 
    Private Sub Form_Load() 
    Dim lReturn As Long 
    Me.Show 
    lReturn = SetWindowRgn(hWnd, CreateEllipticRgn(10, 10, 340, 150), True) 
    End Sub 
     
    CreateEllipticRgn 之四個參數說明如下: 
    X1:橢圓中心點之X軸位置,但以 Form 的實際邊界為限。 
    Y1:橢圓中心點之Y軸位置,但以 Form 的實際邊界為限。 
    X2:橢圓長邊的長度 
    Y2:橢圓短邊的長度的
      

  5.   

    如果我的form是根据一张图形来定义的,由于图形复杂,所以要找出个点比较麻烦,以前好像有个辅助工具来做的,但现在找不到。