vbnet屏保代碼 vbnet控件

誰(shuí)能用VB做個(gè)屏保???

1.啟動(dòng)VB 6.0,新建一個(gè)標(biāo)準(zhǔn)工程。

成都創(chuàng)新互聯(lián)公司主要從事做網(wǎng)站、網(wǎng)站設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)東西湖,十載網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):18982081108

2.在Form1中添加一個(gè)定時(shí)器控件(Timer),把Timer1的Interval屬性設(shè)置為“1”,然后把Form1的AutoRedraw屬性設(shè)置為“True”,ScaleMode屬性設(shè)置為“3”,BorderStyle屬性設(shè)置為“0”,WindowState屬性設(shè)置為“2”。

3.程序代碼如下:

Option Explicit

Private Declare Function ShowCursor Lib "user32" (ByVal bShow As Long) As Long

Private Declare Function Ellipse Lib "gdi32" (ByVal hdc As Long, ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long

Private Declare Function BitBlt Lib "gdi32" (ByVal hDestDC As Long, ByVal X As Long, ByVal Y As Long, ByVal nWidth As Long, ByVal nHeight As Long, ByVal hSrcDC As Long, ByVal xSrc As Long, ByVal ySrc As Long, ByVal dwRop As Long) As Long

' 定義小星星

Private Type Star

X As Long

Y As Long

Speed As Long

Size As Long

Color As Long

End Type

Dim Stars(49) As Star

Const MaxSize As Long = 5

Const MaxSpeed As Long = 25

Private Sub Form_KeyDown(KeyCode As Integer, Shift As Integer)

Unload Me

End Sub

Private Sub Form_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)

' 判斷鼠標(biāo)是否移動(dòng)

Static currentX, currentY As Single

Dim orignX, orignY As Single

orignX = X

orignY = Y

If currentX = 0 And currentY = 0 Then

currentX = orignX

currentY = orignY

Exit Sub

End If

If Abs(orignX - currentX)1 Or Abs(orignY - currentY)1 Then

X = ShowCursor(True)

End

End If

End Sub

Private Sub Form_Load()'窗體載入

Dim I As Long

Randomize

' 產(chǎn)生100個(gè)小星星

For I = LBound(Stars) To UBound(Stars)

Stars(I).X = Me.ScaleWidth * Rnd + 1

Stars(I).Y = Me.ScaleHeight * Rnd + 1

Stars(I).Size = MaxSize * Rnd + 1

Stars(I).Speed = MaxSpeed * Rnd + 1

Stars(I).Color = RGB(Rnd * 255 + 1, Rnd * 255 + 1, Rnd * 255 + 1)

Next I

End Sub

Private Sub Timer1_Timer()

Dim I As Long

' 清屏

BitBlt Me.hdc, 0, 0, Me.ScaleWidth, Me.ScaleHeight, 0, 0, 0, vbBlackness

For I = 0 To UBound(Stars)

' 移動(dòng)小星星

Stars(I).Y = (Stars(I).Y Mod Me.ScaleHeight) + Stars(I).Speed

' 重定位X位置

If Stars(I).Y Me.ScaleHeight Then

Stars(I).X = Me.ScaleWidth * Rnd + 1

Stars(I).Speed = MaxSpeed * Rnd + 1

End If

' 設(shè)置小星星顏色

Me.FillColor = Stars(I).Color

Me.ForeColor = Stars(I).Color

' 繪制小星星顏色

Ellipse Me.hdc, Stars(I).X, Stars(I).Y, Stars(I).X + Stars(I).Size, Stars(I).Y + Stars(I).Size

Next I

Me.Refresh

End Sub

如何用VB.NET寫一個(gè)簡(jiǎn)單的屏幕保護(hù)程序?

在窗體上建立2個(gè)文本框text1和text2,一個(gè)按鈕command1,text1里面輸入你要轉(zhuǎn)換的字符串,text2里面顯示結(jié)果,代碼如下:

Dim MyString As String

Dim EveryStr(50) As String

Dim TargetStr As String

Private Sub Command1_Click()

MyString = Text1

For i = 1 To Len(MyString)

EveryStr(i) = Right(Left(MyString, i), 1)

If Asc(EveryStr(i)) 123 And Asc(EveryStr(i)) 96 Then EveryStr(i) = \"_\"

If Asc(EveryStr(i)) 91 And Asc(EveryStr(i)) 64 Then EveryStr(i) = \"_\"

TargetStr = TargetStr EveryStr(i)

Next i

Text2 = TargetStr

TargetStr = \"\"

End Sub

引號(hào)前面怎么自動(dòng)給加了個(gè)“\”?用的時(shí)候請(qǐng)手動(dòng)把那幾個(gè)“\”去掉

用VB制做可換圖片的屏幕保護(hù)程序

VC++可謂神通廣大,如果學(xué)到家了,或者就掌握了那么一點(diǎn)MFC,你也會(huì)感到它的方便快捷,當(dāng)然最重要的是功能強(qiáng)大。不是嗎,從最基本的應(yīng)用程序.EXE到動(dòng)態(tài)連接庫(kù)DLL,再由風(fēng)靡網(wǎng)上的ActiveX控件到Internet Server API,當(dāng)然,還有數(shù)據(jù)庫(kù)應(yīng)用程序……瞧,我都用它來(lái)做屏幕保護(hù)程序了。一般的屏幕保護(hù)程序都是以SCR作為擴(kuò)展名,并且要放在c:\windows 目錄或 c:\windows\system 目錄下,由Windows 98內(nèi)部程序調(diào)用(Windows NT 是在 c:\windows\system32 目錄下)。怎么調(diào)用?不用說(shuō)了,這誰(shuí)不知道。

好了,我們來(lái)作一個(gè)簡(jiǎn)單的。選擇MFC AppWizard(exe),Project Name 為MyScreensaver,[NEXT],對(duì)話框,再后面隨你了。打開菜單Project、Settings,在Debug頁(yè)、Executable for debug session項(xiàng),以及Link頁(yè)中Output file name項(xiàng)改為c:\windows\MyScreensaver.scr,這樣,你可以調(diào)試完后,直接在VC中運(yùn)行(Ctrl+F5),便可看到結(jié)果。當(dāng)然,這樣做的唯一缺點(diǎn)是你必須手動(dòng)清除Windows 目錄下的垃圾文件(當(dāng)然是在看到滿意結(jié)果后;還有,你可借助SafeClean 這個(gè)小東東來(lái)幫你清除,除非你的硬盤大的讓你感到無(wú)所謂……快快快回來(lái),看我跑到那里去了)。接下來(lái)用Class Wizard生成CMyWnd類,其基類為CWnd(在Base Class 中為generic CWnd)。這個(gè)類是我們所要重點(diǎn)研究的。創(chuàng)建滿屏窗口、計(jì)時(shí)器,隱藏鼠標(biāo),展示圖片,響應(yīng)鍵盤、鼠標(biāo)等等,這家伙全包了。至于MyScreensaverDlg.h與MyScreensaverDlg.cpp文件我們暫時(shí)不管。打開MyScreensaver.cpp,修改InitInstance()函數(shù):

BOOL CMyScreensaverApp::InitInstance()

{

AfxEnableControlContainer();

#ifdef _AFXDLL

Enable3dControls(); // Call this when using MFC in a shared DLL

#else

Enable3dControlsStatic(); // Call this when linking to MFC statically

#endif

CMyWnd* pWnd = new CMyWnd;

pWnd-Create();

m_pMainWnd = pWnd;

return TRUE;

}

當(dāng)然,再這之前得先 #include “MyWnd.h" 。后面要做的都在MyWnd.h 與 MyWnd.cpp 兩文件中了。

下面給出CMyWnd 的說(shuō)明:

class CMyWnd : public CWnd

{

public:

CMyWnd();

static LPCSTR lpszClassName; //注冊(cè)類名

public:

BOOL Create();

public:

// ClassWizard generated virtual function overrides

//{{AFX_VIRTUAL(CMyWnd)

protected:

virtual void PostNcDestroy();

//}}AFX_VIRTUAL

public:

virtual ~CMyWnd();

protected:

CPoint m_prePoint; //檢測(cè)鼠標(biāo)移動(dòng)

void DrawBitmap(CDC& dc, int nIndexBit);

//{{AFX_MSG(CMyWnd)

afx_msg void OnPaint();

afx_msg void OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);

afx_msg void OnLButtonDown(UINT nFlags, CPoint point);

afx_msg void OnMButtonDown(UINT nFlags, CPoint point);

afx_msg void OnMouseMove(UINT nFlags, CPoint point);

afx_msg void OnRButtonDown(UINT nFlags, CPoint point);

afx_msg void OnSysKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);

afx_msg void OnDestroy();

afx_msg void OnTimer(UINT nIDEvent);

afx_msg void OnActivate(UINT nState, CWnd* pWndOther, BOOL bMinimized);

afx_msg void OnActivateApp(BOOL bActive, HTASK hTask);

//}}AFX_MSG

DECLARE_MESSAGE_MAP()

};

MyWnd.cpp 文件:

……

CMyWnd::CMyWnd()

{

m_prePoint=CPoint(-1, -1);

}

LPCSTR CMyWnd::lpszClassName=NULL;

BOOL CMyWnd::Create()

{

if(lpszClassName==NULL)

{

lpszClassName=AfxRegisterWndClass(CS_HREDRAW CS_VREDRAW,

::LoadCursor(AfxGetResourceHandle(),MAKEINTRESOURCE(IDC_NOCURSOR)));

//注冊(cè)類;IDC_NOCURSOR為新建光標(biāo)的ID,這個(gè)光標(biāo)沒有任何圖案

}

CRect rect(0, 0, ::GetSystemMetrics(SM_CXSCREEN),

::GetSystemMetrics(SM_CYSCREEN));

CreateEx(WS_EX_TOPMOST, lpszClassName, _T(“”), WS_VISIBLE WS_POPUP,

rect.left, rect.top, rect.right - rect.left, rect.bottom - rect.top,

GetSafeHwnd(), NULL, NULL); //創(chuàng)建一個(gè)全屏窗口

SetTimer(ID_TIMER, 500, NULL);//計(jì)時(shí)器,ID_TIMER別忘了定義

return TRUE;

}

為了防止同時(shí)運(yùn)行兩個(gè)相同的程序,下面兩個(gè)函數(shù)是必需的:

void CMyWnd::OnActivate(UINT nState, CWnd* pWndOther, BOOL bMinimized)

{

CWnd::OnActivate(nState,pWndOther,bMinimized);

if (nState==WA_INACTIVE)

PostMessage(WM_CLOSE);

}

void CMyWnd::OnActivateApp(BOOL bActive, HTASK hTask)

{

CWnd::OnActivateApp(bActive, hTask);

if (!bActive) //is being deactivated

PostMessage(WM_CLOSE);

}

OnPaint()函數(shù)將全屏窗口置為黑色:

void CMyWnd::OnPaint()

{

CPaintDC dc(this);

CBrush brush(RGB(0,0,0));

CRect rect;

GetClientRect(rect);

dc.FillRect(&rect, &brush);

}

由計(jì)數(shù)器調(diào)用DrawBitmap()函數(shù),切換圖片;注意,下面兩個(gè)函數(shù)中的IDB_BITMAP1, dc.BitBlt(0,0,800,600……以及if(nIndexBit=5)中的有關(guān)數(shù)據(jù)依據(jù)你的bmp圖片個(gè)數(shù)、尺寸、位置不同而不同,我是選擇了5張800x600的bmp圖片。注意,ID值是連續(xù)的,IDB_BITMAP1最小。

void CMyWnd::DrawBitmap(CDC &dc, int nIndexBit)

{

CDC dcmem;

dcmem.CreateCompatibleDC(&dc);

CBitmap m_Bitmap;

m_Bitmap.LoadBitmap(IDB_BITMAP1+nIndexBit);

dcmem.SelectObject(m_Bitmap);

dc.BitBlt(0,0,800,600,&dcmem,0,0,SRCCOPY);

}

void CMyWnd::OnTimer(UINT nIDEvent)

{

CClientDC dc(this);

static nIndexBit=0;

if(nIndexBit=5)

nIndexBit=0;

DrawBitmap(dc, nIndexBit++);

CWnd::OnTimer(nIDEvent);

}

響應(yīng)鍵盤、鼠標(biāo)是屏幕保護(hù)程序不可缺少的,在OnKeyDown()、 OnLButtonDown()、 OnMButtonDown()、OnRButtonDown()、OnSysKeyDown()函數(shù)中都加入:

PostMessage(WM_CLOSE);

OnMouseMove()函數(shù)比較特殊,它應(yīng)加的代碼為:

if(m_prePoint == CPoint(-1,-1))

m_prePoint = point;

else if(m_prePoint!=point)

PostMessage(WM_CLOSE);

快要完工了。在OnDestroy()函數(shù)中刪掉計(jì)時(shí)器:KillTimer(ID_TIMER);

還有啦,在CMyWnd::PostNcDestroy() 中加入: delete this;

哎呀,腰酸背疼,眼球發(fā)澀,手背奇麻(不會(huì)吧)!不過(guò),相信你一定會(huì)迫不及待地按下Ctrl+F5, 看著一幅幅圖片在你面前輪番展示,啊,自己的屏幕保護(hù)程序!趕快趕快,換上自制的屏保,感覺就是不一樣:圖片任你挑,時(shí)間間隔任你改,鼠標(biāo)?鍵盤?我想響應(yīng)誰(shuí)就響應(yīng)誰(shuí)……哎呀,誰(shuí)扔的紙團(tuán):(。

其實(shí),上面的程序還有很多可以改進(jìn)的地方,比如圖片總是單一地顯示;bmp 文件太大,導(dǎo)致生成的屏幕保護(hù)程序也很大,遠(yuǎn)沒有jpg合算;沒有密碼,沒有可直接控制的界面。由于InitInstance()函數(shù)的簡(jiǎn)單處理(直接調(diào)用CMyWnd類),你會(huì)發(fā)現(xiàn)當(dāng)你在桌面上右擊,選擇“屬性”、“屏幕保護(hù)程序”頁(yè)、“屏幕保護(hù)程序”下拉菜單、選中MyScreensaver時(shí),MyScreensaver就直接預(yù)覽了(或是直接運(yùn)行了);假設(shè)你確定MyScreensaver作為你的屏幕保護(hù)程序,等你第二次進(jìn)入“屏幕保護(hù)程序”頁(yè)時(shí),就直接預(yù)覽。Why? 回頭看看InitInstance()函數(shù)就明白了。為了讓它更聽話地工作,可修改InitInstance()函數(shù):

LPTSTR lpszArgv = __argv[1];

if (lpszArgv[0] ==‘/’)

lpszArgv++;

if (lstrcmpi(lpszArgv, _T(“s”))==0)

{

CMyWnd* pWnd=new CMyWnd;

pWnd-Create();

m_pMainWnd=pWnd;

return TRUE;

}

return FALSE;

不過(guò)現(xiàn)在你要是再在VC中運(yùn)行這個(gè)程序,“該程序執(zhí)行了非法操作,即將關(guān)閉。將會(huì)伴隨著一超重低音供你欣賞。(???)原因是我們加了一句return FALSE; 還有,別忘了還有一個(gè)CMyScreensaverDlg類沒有用上,用它來(lái)與你的屏保直接對(duì)話再好不過(guò)了。例如,為了方便地確定時(shí)間間隔,選取圖片,加上一個(gè)編輯框和幾個(gè)按鈕就可以了。重申一點(diǎn),由于生成文件較大,占用的內(nèi)存也多,如果不能運(yùn)行,很可能是開的窗口太多了。這時(shí)你可以換較小的圖片。

關(guān)于VB屏幕保護(hù)問(wèn)題--求助

熟悉Windows操作系統(tǒng)的朋友一定對(duì)Windows的屏幕保護(hù)程序不陌生吧。如何自己編寫Windows屏幕保護(hù)程序呢?當(dāng)你看完下面的講解后便可以輕易地編寫一標(biāo)準(zhǔn)的Windows屏幕保護(hù)程序了!

一個(gè)標(biāo)準(zhǔn)的屏保有以下幾個(gè)特點(diǎn):

一:它是以.SCR作為文件的擴(kuò)展名!

二:它有三種運(yùn)行方式。

(1)運(yùn)行在預(yù)覽框中(用于預(yù)覽屏保的效果。在“顯示屬性”→“屏幕保護(hù)程序”→“小屏幕”)。(見圖)

(2)運(yùn)行設(shè)置程序(用于設(shè)置一些相關(guān)的樣式。在“顯示屬性”→“屏幕保護(hù)程序”→“點(diǎn)擊設(shè)置按鈕”)。

(3)真正的運(yùn)行屏保(屏保運(yùn)行時(shí)的效果。在“顯示屬性”→“屏幕保護(hù)程序”→“點(diǎn)擊預(yù)覽”或鼠標(biāo)、鍵盤在指定的時(shí)間內(nèi)無(wú)動(dòng)作時(shí))。

如何讓屏保識(shí)別當(dāng)前需要運(yùn)行哪一種方式呢?答案很簡(jiǎn)單——分析Windows調(diào)用屏保的參數(shù)。下面以Windows 98為例向大家分析一下調(diào)用屏保的參數(shù)。

當(dāng)Windows需要屏保顯示在“小屏幕”中時(shí)會(huì)在調(diào)用屏保的后面加上兩個(gè)參數(shù)。

如:myscr.scr /p 7981(參數(shù)一:/p 表示讓程序顯示在“小屏幕”里,參數(shù)二:7981表示“小屏幕”的句柄hWnd。這樣屏保就會(huì)得知Windows要它顯示在“小屏幕”中。)

當(dāng)Windows需要屏保顯示設(shè)置對(duì)話框時(shí)會(huì)在調(diào)用屏保的后面不加或加上兩個(gè)參數(shù)。

如:myscr.scr或myscr.scr /C 7987(參數(shù)一:/C表示讓程序顯示設(shè)置對(duì)話框,參數(shù)二:7987表示該屬性頁(yè)的句柄。)

當(dāng)Windows需要運(yùn)行屏保時(shí)會(huì)在調(diào)用屏保的后面加上一個(gè)參數(shù)。

如:myscr.scr /S(參數(shù):/S表示讓屏保運(yùn)行。)

好了,知道了Windows如何讓屏保運(yùn)行的三種方式后,接下來(lái)就要討論如何實(shí)現(xiàn)它們了。

實(shí)現(xiàn)原理:Windows通過(guò)某種方式調(diào)用屏保,屏保知道了它此時(shí)要干什么便會(huì)在當(dāng)前環(huán)境中搜索是否有相同的實(shí)例存在。如果該實(shí)例的運(yùn)行方式與此次要啟動(dòng)的運(yùn)行方式不同則關(guān)閉前個(gè)實(shí)例,如果該實(shí)例的運(yùn)行方式與此次要啟動(dòng)的運(yùn)行方式相同則關(guān)閉此次運(yùn)行的實(shí)例。

顯然要實(shí)現(xiàn)這種方法靠VB的App.PrevInstance是不可行的。因?yàn)槲覀円_(dá)到的目的是:偵測(cè)到前一個(gè)實(shí)例后要關(guān)閉它然后啟動(dòng)程序。而App.PrevInstance屬性只能返回當(dāng)前是否已啟動(dòng)一個(gè)應(yīng)用程序的實(shí)例而不能對(duì)前個(gè)實(shí)例做些什么。(實(shí)例 簡(jiǎn)單地說(shuō)就是相同的對(duì)象集合——同一程序。)在實(shí)現(xiàn)此方法之前首先向大家介紹三條API函數(shù):GetClassName、FindWindow和SendMessage。其原型如下:

Declare Function GetClassName Lib “user32” Alias “GetClassNameA” (ByVal hwnd As Long, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long

Declare Function FindWindow Lib “user32” Alias “FindWindowA” (ByVal lpClassName As String, ByVal lpWindowName As String) As Long

Declare Function SendMessage Lib “user32” Alias “SendMessageA” (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long

GetClassName用于取得窗體的類名。調(diào)用成功后返回類名長(zhǎng)度,失敗返回零。函數(shù)需要三個(gè)參數(shù):參數(shù)一.窗體的句柄,參數(shù)二.存放類名的緩沖,參數(shù)三.緩沖的大小。

FindWindow用于尋找窗體。調(diào)用成功后返回窗體的句柄,失敗返回零。函數(shù)需要兩個(gè)參數(shù):參數(shù)一.窗體的類名,參數(shù)二.窗體的標(biāo)題。

SendMessage用于向窗體發(fā)送一消息。函數(shù)需要四個(gè)參數(shù):參數(shù)一.窗體的句柄,參數(shù)二:發(fā)送的消息名稱,參數(shù)三、四.分別表示消息所附帶的參數(shù)。

使用了這三個(gè)函數(shù)便可輕易地實(shí)現(xiàn)關(guān)閉前有一個(gè)已啟動(dòng)的實(shí)例從而達(dá)到我們的目的。

其次我們要實(shí)現(xiàn)如何讓屏幕保護(hù)程序顯示在預(yù)覽框中(“小屏幕”)。

要讓屏幕保護(hù)程序在預(yù)覽框中顯示必須動(dòng)態(tài)地改變窗口的樣式使之成為“小屏幕”的子窗體,這樣才能使預(yù)覽框關(guān)閉時(shí)得到關(guān)閉消息。動(dòng)態(tài)地改變窗口的樣式可以使用GetWindowLong、SetWindowLong和SetParent。

它們的原型如下:

Public Declare Function GetWindowLong Lib “user32” Alias “GetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long) As Long Public Declare Function SetWindowLong Lib “user32” Alias “SetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long Declare Function SetParent Lib “user32” (ByVal hWndChild As Long, ByVal hWndNewParent As Long) As Long

GetWindowLong的作用用于得到窗體的樣式。調(diào)用成功后返回窗體的樣式。函數(shù)需要兩個(gè)參數(shù):參數(shù)一.窗體的句柄,參數(shù)二.要取得窗體的樣式只需使用常數(shù)GWL_STYLE。

SetWindowLong的作用用于設(shè)置窗體的樣式。函數(shù)需要三個(gè)參數(shù):參數(shù)一.窗體的句柄,參數(shù)二.要設(shè)置窗體的樣式只需用常數(shù)GWL_STYLE,參數(shù)三.要設(shè)置窗體的樣式。

SetParent的作用用于設(shè)置子窗體屬于哪個(gè)父窗體。函數(shù)需要兩個(gè)參數(shù):參數(shù)一.子窗體的句柄,參數(shù)二.父窗體的句柄。

知道了以上兩點(diǎn)就可編寫出標(biāo)準(zhǔn)的屏保。(關(guān)于效果就看你自己的了?。┘埳险劚艘魂嚲鸵鋵?shí)到真正的編程上了。為了著重講解屏保的實(shí)現(xiàn)方法故將屏保的效果簡(jiǎn)單化。

首先新建一工程再添加一窗口,各屬性設(shè)置如下:

窗口 名稱 Caption BorderStyle

Form1 Frm_Setup 無(wú) 1 - None

Form2 Frm_Run 任意 1 - Fixed Single

其余屬性均缺省。再在Frm_Run中添加一Timer控件,將該控件的名稱改為Timer_Mov,Interval屬性制改為500。

添加兩個(gè)模塊,將Module1的名稱改為Mod_Const,Module2的名稱改為Mod_Main,添加以下代碼:

Mod_Const:

Option Explicit

Public Const WM_LOOK=“屏保預(yù)覽(demo)”

Public Const WM_SET=“屏保設(shè)置(demo)”

Public Const WM_RUN=“屏保運(yùn)行(demo)”

Public Const HWND_TOP=0&

Public Const WS_CHILD=&H40000000

Public Const GWL_STYLE=(-16)

Type RECT

Left As Long

Top As Long

Right As Long

Bottom As Long

End Type

Public Const SWP_NOZORDER=&H4

Public Const SWP_NOACTIVATE=&H10

Public Const SWP_SHOWWINDOW=&H40

Public Const WM_CLOSE=&H10

Declare Function GetClientRect Lib “user32” (ByVal hwnd As Long, lpRect As RECT) As Long

Declare Function GetClassName Lib “user32” Alias “GetClassNameA” (ByVal hwnd As Long, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long

Declare Function FindWindow Lib “user32” Alias “FindWindowA” (ByVal lpClassName As String, ByVal lpWindowName As String) As Long

Declare Function SendMessage Lib “user32” Alias “SendMessageA” (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long

Declare Function SetParent Lib “user32” (ByVal hWndChild As Long, ByVal hWndNewParent As Long) As Long

Public Declare Function GetWindowLong Lib “user32” Alias “GetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long) As Long

Public Declare Function SetWindowLong Lib “user32” Alias “SetWindowLongA” (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long

Declare Function SetWindowPos Lib “user32” (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal X As Long, ByVal Y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long

Declare Function ShowCursor Lib “user32” (ByVal bShow As Long) As Long

Mod_Main:

Option Explicit

Sub Main() '程序運(yùn)行入口

Dim ClassName As String * 64 ’存放窗口的類名

Dim ExeCmd As String '存放命令行參數(shù)

GetClassName Frm_Setup.hwnd, ClassName, 64 ’取得窗口的類名

ExeCmd=UCase(Command$) ’將調(diào)用的屏保的參數(shù)轉(zhuǎn)換成大寫后存放在變量ExeCmd里

If Not (InStr(ExeCmd,“/P”)=0)Then ’檢查屏保的調(diào)用參數(shù)中是否有“/P”參數(shù)

If Not (FindWindow(ClassName, WM_LOOK)=0)Then End ’如果找到已有同一個(gè)運(yùn)行方式的實(shí)例存在則程序結(jié)束

ClosePreWindow ClassName, WM_SET ’關(guān)閉前面已啟動(dòng)的其他運(yùn)行方式的實(shí)例

ClosePreWindow ClassName, WM_RUN ’同上

SCR_Look

ElseIf Not (InStr(ExeCmd,“/S”)=0)Then

If Not (FindWindow(ClassName,WM_RUN)=0) Then End

ClosePreWindow ClassName, WM_LOOK ’同上

ClosePreWindow ClassName, WM_SET ’同上

Scr_Run

Else

If Not (FindWindow(ClassName, WM_SET)=0) Then End

ClosePreWindow ClassName, WM_LOOK ’同上

ClosePreWindow ClassName, WM_RUN ’同上

Scr_Setup

End If

End Sub

Public Sub ClosePreWindow(ClassName As String, WinCaption As String)

Dim PreWnd As Long

PreWnd=FindWindow(ClassName, WinCaption) ’尋找類名為ClassName,標(biāo)題為WinCaption的窗口

If Not (PreWnd = 0) Then Call SendMessage(PreWnd, WM_CLOSE, 0, 0) ’如果窗口已找到則關(guān)閉它

End Sub

Public Sub SCR_Look()

Dim LookScrWnd As Long

Dim Style As Long

Dim LookRect As RECT

Frm_Run.Caption=WM_LOOK ’賦上具有相應(yīng)運(yùn)行方式的標(biāo)題

LookScrWnd=Val(Right(Command$, Len(Command$) - 2)) ’取得小屏幕的窗口句柄

Style=GetWindowLong(Frm_Run.hwnd, GWL_STYLE) ’取得窗口的樣式

Style=Style Or WS_CHILD ’在窗口的樣式中加入子窗體常數(shù)

SetWindowLong Frm_Run.hwnd, GWL_STYLE, Style ’改變窗體的樣式

SetParent Frm_Run.hwnd, LookScrWnd ’設(shè)置窗體的父窗體

GetClientRect LookScrWnd, LookRect ’取得小屏幕的大小

SetWindowPos Frm_Run.hwnd, HWND_TOP, 0, 0, LookRect.Right, LookRect.Bottom, SWP_

NOZORDER Or SWP_NOACTIVATE Or SWP_SHOWWINDOW

'顯示窗體并將窗體的大小設(shè)置為小屏幕的大小以便覆蓋小屏幕

End Sub

Public Sub Scr_Setup()

Frm_Run.Caption=WM_SET ’賦上具有相應(yīng)運(yùn)行方式的標(biāo)題

Frm_Setup.Show

End Sub

Public Sub Scr_Run()

Frm_Run.Caption = WM_RUN ’賦上具有相應(yīng)運(yùn)行方式的標(biāo)題

ShowCursor False ’隱藏鼠標(biāo)

Frm_Run.Move 0, 0, Screen.Width, Screen.Height

Frm_Run.Show

End Sub

Public Sub CloseSCR()

ShowCursor True ’顯示鼠標(biāo)

Unload Frm_Setup ’卸載窗體關(guān)閉屏保

Unload Frm_Run ’同上

End Sub

Public Function Scan_RUN() As Boolean’偵測(cè)當(dāng)前屏保的運(yùn)行方式

If (Frm_Run.Caption = WM_RUN) Then ’如果屏保是以運(yùn)行方式在運(yùn)行則返回“真”,否則返回“假”

Scan_RUN=True

Else

Scan_RUN=False

End If

End Function

Frm_Run:

Option Explicit

Dim i As Integer ’定義循環(huán)變量

Dim OldX As Integer ’定義存放舊的鼠標(biāo)水平坐標(biāo)

Dim OldY As Integer ’定義存放舊的鼠標(biāo)垂直坐標(biāo)

Dim Pic(1) As New StdPicture ’定義一個(gè)圖片類的數(shù)組

Private Sub Form_KeyDown(KeyCode As Integer, Shift As Integer)

If Mod_Main.Scan_RUN Then ’如果此時(shí)是在運(yùn)行屏保則關(guān)閉屏保

Mod_Main.CloseSCR

End If

End Sub

Private Sub Form_Load()

i=1 ’為循環(huán)變量賦初值

OldX=-1 ’為舊鼠標(biāo)水平坐標(biāo)賦初值

OldY=-1 ’為舊鼠標(biāo)垂直坐標(biāo)賦初值

Set Pic(0)=LoadPicture(請(qǐng)寫入圖片一的路徑和名稱) ’讀取圖片一

Set Pic(1)=LoadPicture(請(qǐng)寫入圖片二的路徑和名稱) ’讀取圖片二

End Sub

Private Sub Form_MouseDown(Button As Integer, Shift As Integer, X As Single, Y A

s Single)

If Mod_Main.Scan_RUN Then ’如果此時(shí)是在運(yùn)行屏保則關(guān)閉屏保

Mod_Main.CloseSCR

End If

End Sub

Private Sub Form_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)

If Mod_Main.Scan_RUN Then

If (OldX=-1) And (OldY=-1) Then

OldX=X

OldY=Y

Else

If (ScaleX(Abs(X-OldX),vbTwips,vbPixels)= 3) Then

Mod_Main.CloseSCR ’將鼠標(biāo)當(dāng)前的水平坐標(biāo)和垂直坐標(biāo)與舊鼠標(biāo)的水平坐標(biāo)和垂直坐標(biāo)相減其絕對(duì)值如果大于3個(gè)像素則退出屏保

End If

End If

End If

End Sub

Private Sub Form_Unload(Cancel As Integer)

Mod_Main.CloseSCR ’關(guān)閉屏保

End Sub

Private Sub Timer_Mov_Timer()

If (i=2) Then

i=1 ’如果循環(huán)變量大于圖片的數(shù)量則變量賦為1

Else

i=i+1 ’否則循環(huán)變量加一

End If

Frm_Run.PaintPicture Pic(i-1),0,0,Width,Height,0,0,ScaleX(Pic(i-1).Width,vbHimetric,vbTwips),ScaleY(Pic(i-1).Height,vbHimetric,vbTwips)’在Frm_Run上畫圖

End Sub

Frm_Setup:

Option Explicit

Private Sub Com_OK_Click()

Mod_Main.CloseSCR

End Sub

Private Sub Form_Unload(Cancel As Integer)

Mod_Main.CloseSCR

End Sub

好了,一個(gè)標(biāo)準(zhǔn)的屏幕保護(hù)程序就編寫好了。按下F5運(yùn)行試試看。不要忘了生成EXE文件時(shí)一定要將屏保的擴(kuò)展名改為SCR并將其拷貝到Windows的System目錄里才可在屏保設(shè)置中見到喔?。ǔ绦蛟赩B 5.0中編寫并運(yùn)行通過(guò)。)

vb.net 屏幕保護(hù)程序

系統(tǒng)就有這個(gè)屏保啊!~!

Option EXPlicit

Dim quitflag As Boolean '聲明終止程序標(biāo)志變量

Dim lleft

'聲明隱藏或顯示鼠標(biāo)的API函數(shù)

Private Declare Function ShowCursor Lib "user32"

(ByVal bShow As Long) As Long

'檢測(cè)鼠標(biāo)單擊或移動(dòng)

Private Sub Form_Click()

quitflag = True

End Sub

Private Sub Form_MouseMove(Button As Integer,Shift As Integer, X As Single, Y As Single)

Static xlast, ylast

Dim xnow As Single

Dim ynow As Single

xnow = X

ynow = Y

If xlast = 0 And ylast = 0 Then

xlast = xnow

ylast = ynow

Exit Sub

End If

If xnow xlast Or ynow ylast Then

quitflag = True

End If

End Sub

'檢測(cè)按鍵

Private Sub Form_KeyDown(KeyCode As Integer,Shift As Integer)

quitflag = True

End Sub

Private Sub Form_Load()

Dim X As Long

lleft = 0

'橫向滾動(dòng)文字的起始X坐標(biāo)

If App.PrevInstance = True Then

'用APP對(duì)象的PrevInstance屬性

Unload Me

'防止同時(shí)運(yùn)行屏幕保護(hù)程序的兩個(gè)實(shí)例

Exit Sub

End If

Select Case Ucase$(Left$(Command$, 2))

'裝載命令行參數(shù)

Case "/S" '在顯示器屬性對(duì)話框中單擊了

預(yù)覽按鈕或屏幕保護(hù)程序被系統(tǒng)正常調(diào)用。

Show

'全屏顯示Form1窗體

Randomize

'初始化隨機(jī)數(shù)生成器

X = ShowCursor(False)

'隱藏鼠標(biāo)

BackColor = VBBlack

Do

Timer2.Enabled = True

'啟動(dòng)Timer2 ,顯示屏幕保護(hù)滾動(dòng)文字

DoEvents

'轉(zhuǎn)讓控制權(quán),以便檢測(cè)鼠標(biāo)和按鍵行為

Loop Until quitflag = True

'運(yùn)行屏幕保護(hù)滾動(dòng)文字直至有鼠標(biāo)和按鍵行為

Timer2.Enabled = False

'終止?jié)L動(dòng)文字

Timer1.Enabled = True

'啟動(dòng)Timer1,退出屏幕保護(hù)程序

Case Else

Unload Me

Exit Sub

End Select

End Sub

Private Sub Form_Unload(Cancel As Integer)

Dim X

X = ShowCursor(True)

'顯示鼠標(biāo)

End Sub

Private Sub Timer1_Timer()

Unload Me

'退出屏幕保護(hù)程序

End Sub

Private Sub Timer2_Timer()

顯示橫向滾動(dòng)文字

lleft = lleft + 100

If lleft = 11810 Then

lleft = 0

Lab1.Top = Int(Rnd * 7000)

End If

Lab1.Left = lleft

Timer2.Enabled = False

End Sub

名稱欄目:vbnet屏保代碼 vbnet控件
標(biāo)題來(lái)源:http://www.muchs.cn/article40/hggeeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、面包屑導(dǎo)航、響應(yīng)式網(wǎng)站軟件開發(fā)、企業(yè)建站、網(wǎng)站營(yíng)銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管