您的位置:逆风者 VB 正文
原作者:www.upwinder.com 添加时间:2007-09-02 原文发表:2007-08-31 人气:6 来源:未知

每次开机都面对同样的墙纸,真让人感到单调乏味。是不是可以在每次开机的时候,都能给你一个意外的惊喜,自动地更换墙纸呢?笔者用VB 5.0编了一个小程序,可以轻松地解决这个问题。而其关键在于一个WINDOWS API函数的使用,该函数的功能是用来设置或询问系统范围参数的,其表达形式如下:
逆@风@者
   Declare Function SystemParametersInfo Lib “user32"Alias “SystemParametersInfoA"(ByVal uAction As Long,ByVal uParam As Long, ByVal lpvParam As Any,ByVal fuWinIni As Long) As Long
   1、第一个参数uAction是用来动作设置的,该参数分GET和SET两种行动,有约80种不同的参数设置,其中设置墙纸的参数为SPI_SETDESKWALLPAPER=20。
   2、第二个参数uParam的设置是随第一个参数的设置作相应调整的。这里置空值。
   3、第三个参数lpvParam是用来设置要更换上去的图片路径。该参数的设置也是随第一个参数作相应调整的。
   4、第四个参数fulWIni规定了在设置系统参数的时候,是否应更新用户设置参数。
   可以是零(禁止更新),或下述任何一个参数:
   SPIF-UPDATEINIFILE:更新WIN.INI和注册表中的用户配置文件。
   SPIF-SENDWININICHANGE:倘若也设置了SPIF-UPDATEINIFILE,将一条WM-WININICHANGE消息发给所有应用程序,否则没有作用。这条消息告诉应用程序已经改变了用户配置设置。
   自动更换墙纸的具体实现如下:
   1、启动VB,选择STANDARD.EXE创建一个新项目,删除FORM1的同时添加一个模块(MODULE1)。
   2、在模块代码窗口填代码如下:(假设墙纸文件都在D:JX目录下按1-20的序号命名,每次开机自动抽取墙纸)
   Private Const SPI_SETDESKWALLPAPER  =20
   Private Const SPIF_SENDWININICHANGE  =&H2
   Private Const SPIF_UPDATEINIFILE=&H1
   Private Declare FunctionSystemParametersInfo Lib "user32"Alias "SystemParametersInfoA"
(ByVal uAction As Long, ByVal uParam As Long,ByVal lpvParam As Any, ByValfuWinIni As Long)As Long
   Sub Main()
   Dim myvalue
   SPIFlags%=()
   Ramdomize
   myvalue=20*Rnd
   bmpfiles=“D:JXx”+CStr(Int(1+myvalue))+“.bmp"
   ret&=SystemParametersInfo(SPI_SETDES
   KWALLPAPER,0,ByVal bmpfiles,SPIFlags)
   End Sub
   3、在文件菜单下生成可执行文件,并把该可执行程序移入启动目录,便大功告成。

相关文章

利用VB6.0设计屏幕保护程序
怎样接收电子邮件(POP3协议简介)
在VB环境中操作三维模型的实现方法
用VB制作TopMost类型窗口
VB 从零开始编外挂(十一)
利用Winsock控件实现局域网通信
在VB中实现文件上传
用VB实现象Windows记事本的一些功能
如何在VB中实现绘图区的大十字光标
VB中API菜單編輯器的實現````
用VB编写记事本
建立无模式窗口
在VB中使用UDP协议
封面的设计
把Outlook信箱中的附件另存为
VB 从零开始编外挂(四)
在VB中如何创建闪烁(标语)屏
利用VB产生屏幕变暗的效果
怎样用VB得知系统当前是否处于internet链结
用VB6.0编写手机短信发送

相关评论


本文章所属分类:首页 VB

  热门关键字: