浅谈如何利用PB实现树型列表动态半透明提示(四)(原创)

发表于:2007-06-08来源:作者:点击数: 标签:
MI LY: 仿宋_GB2312; LETTER-SPACING: 0.2pt>作者: BALLOONMAN2002 2004年6月26日 4、创建用户函数wf_maketrans,用于实现半透明效果: Long hDCscr,bhandle,hdest,frmdc,BlendLng,copywidth,copyheight,copyleft,copytop,ret long copywidth2,copyheight2,

MILY: 仿宋_GB2312; LETTER-SPACING: 0.2pt">作者:BALLOONMAN2002  2004年6月26日

4、创建用户函数wf_maketrans,用于实现半透明效果:

Long hDCscr,bhandle,hdest,frmdc,BlendLng,copywidth,copyheight,copyleft,copytop,ret

long copywidth2,copyheight2,copyleft2,copytop2,mledc

Long xDeviation,yDeviation

blendfunction Blend

Window lw_tmp

 

//BlendLng = 11796480

Blend.SourceConstantAlpha = char(trans)

CopyMemory2(BlendLng, Blend, 4)

 

lw_tmp=frm.getparent()

//lw_tmp.setredraw(true)

copywidth = UnitsToPixels(frm.Width, XUnitsToPixels!)

copyheight = UnitsToPixels(frm.Height, YUnitsToPixels!)

copywidth2 = UnitsToPixels(mle.Width, XUnitsToPixels!)

copyheight2 = UnitsToPixels(mle.Height, YUnitsToPixels!)

//上述代码用于坐标体系转换

 

frm.x = xpos

frm.y = ypos

 

If lw_tmp.Border <> false Then

    yDeviation = GetSystemMetrics(SM_CYCAPTION) + GetSystemMetrics(SM_CYFRAME)

    xDeviation = GetSystemMetrics(SM_CXFRAME)

Else

    yDeviation = 0

    xDeviation = 0

End If

 

if trim(lw_tmp.menuname) <> "" then

    yDeviation = yDeviation + GetSystemMetrics(SM_CYMENU)

end if

 

//也可以用CLIENTTOSCREEN进行转换

copyleft = UnitsToPixels((lw_tmp.x + xpos), XUnitsToPixels!) + xDeviation

copytop = UnitsToPixels((lw_tmp.y + ypos), YUnitsToPixels!) + yDeviation

copyleft2 = UnitsToPixels(mle.x, XUnitsToPixels!)

copytop2 = UnitsToPixels(mle.y, YUnitsToPixels!)

//上述代码用于坐标体系转换

 

hDCscr = GetDC(0)

//获取屏幕的设备句柄

hdest = CreateCompatibleDC(hDCscr)

bhandle = CreateCompatibleBitmap(hDCscr, copywidth, copyheight)

ret = SelectObject(hdest,bhandle)

frmdc = getdc(handle(frm))

mledc = getdc(handle(mle))

 

//此句可加可不加,主要是起清除原来图象目的,防止图象重叠,VB中此处必须要.cls,因为它具有AUTOREDRAW能力

//frm.setredraw(true)

//mle.setredraw(true)

 

//'此处一定要等待一段时间,否则窗体来不及hide,就已经被重新抓屏了

Sleep(100)

 

ret = BitBlt(hdest, 0, 0, copywidth, copyheight, hDCscr, copyleft , copytop , 13369376)

//上述代码即将屏幕的截图拷贝到内存缓存区域

 

//VB中FORM具有AUTOREDRAW的属性可以自动重画,PB无此能力,只好在此处就得显示出来

if ib_first then

    wf_setrgn(frm)

end if

frm.Visible = True

if ib_first then

    wf_setrgn(frm)

    ib_first = false

end if

ret = AlphaBlend(frmdc, 0, 0, copywidth, copyheight, hdest, 0, 0, copywidth, copyheight, BlendLng)

ret = AlphaBlend(mledc, 0, 0, copywidth2, copyheight2, hdest, copyleft2 , copytop2, copywidth2, copyheight2, BlendLng)

//上述代码将内存缓存区域中的截图拷贝到气泡UO和其上的MLE_1控件的HDC

 

//setnewrgn frm

wf_setrgn(frm)

 

ret = ReleaseDC(0, hDCscr)

ret = ReleaseDC(handle(frm), frmdc)

ret = ReleaseDC(handle(mle), mledc)

ret = DeleteDC(hdest)

ret = DeleteObject(bhandle)

//最后释放或删除获取的内存对象

四、气泡形状效果实现

1、声明本地外部函数:

Function ulong CreateRectRgn(ulong X1,ulong Y1,ulong X2,ulong Y2) LIBRARY "gdi32.dll"

Function ulong CreateRoundRectRgn(ulong X1,ulong Y1,ulong X2,ulong Y2,ulong X3,ulong Y3) LIBRARY "gdi32.dll"

Function ulong CreatePolygonRgn(ref POINTAPI lpPoint[],ulong nCount,ulong nPolyFillMode) LIBRARY "gdi32.dll"

Function ulong CombineRgn(ulong hDestRgn,ulong hSrcRgn1,ulong hSrcRgn2,ulong nCombineMode) LIBRARY "gdi32.dll"

Function ulong CreateSolidBrush(ulong crColor) LIBRARY "gdi32.dll"

Function ulong FrameRgn(ulong hdc,ulong hRgn,ulong hBrush,ulong nWidth,ulong nHeight) LIBRARY "gdi32.dll"

Function ulong SetWindowRgn(ulong hWnd,ulong hRgn,boolean bRedraw) LIBRARY "user32.dll"

2、创建用户函数wf_setrgn,用于创建气泡形状控件,该函数在上一小节的用户函数wf_maketrans中予以调用:

long rgn_1,rgn_2,myrgn,hhbr,w,h,ret

POINTAPI shapev[]

   

    //初始化长、宽边距

    w = UnitsToPixels(frm.Width, XUnitsToPixels!)

    h = UnitsToPixels(frm.Height, YUnitsToPixels!)

   

    //初始化右下脚三角顶点坐标

    shapev[1].X = w * (1 / 8)

    shapev[1].Y = h - 30

    shapev[2].X = 0

    shapev[2].Y = h

    shapev[3].X = w * (3 / 8)

    shapev[3].Y = h - 30

     

    //开始创建指定图形区域

    myrgn = CreateRectRgn(0, 0, 0, 0)

    rgn_1 = CreateRoundRectRgn(0, 0, w, h - 20, 20, 20)

//创建椭圆角矩形区域

    rgn_2 = CreatePolygonRgn(shapev[],3,1)

    //创建任意多边形区域

 

    //合并最终图形

    ret = CombineRgn(myrgn, rgn_1, rgn_2, 2)

   

    // 创建用户自定义颜色刷子

    hhbr = CreateSolidBrush(16479614)

//对最终图形画边框

    ret = FrameRgn(getdc(handle(frm)), myrgn, hhbr, 1, 1)

   

    //设置当前窗体使用此区域

    ret = SetWindowRgn(handle(frm), myrgn, True)

     

    //释放各对象

    ret = DeleteObject(myrgn)

    ret = DeleteObject(rgn_1)

    ret = DeleteObject(rgn_2)

    ret = DeleteObject(hhbr)

2、利用上述代码可以轻松实现任务栏右下脚提示效果,如图:

http://blog.csdn.net/images/blog_csdn_net/balloonman2002/17312/r_BALLOON-2.JPG

 

至此,树型列表动态半透明效果提示全部完成,效果图见:

http://blog.csdn.net/images/blog_csdn_net/balloonman2002/17312/r_BALLOON-1.JPG

如需要进一步资料,请联系QQ:27855043,MSN:WEIYIN2001@MSN.COM

如有不当之处,敬盼您的指点。

原文转自:http://www.ltesting.net