Хранитель Экрана на Visual Basic
Хорош Visual Basic тем, что он позволяет создавать хранители экрана. Для этого нужно всего лишь создать проект с одной или несколькими формами, простым кодом, и откомпилировать его в файл с расширением *.Scr в рабочий каталог Windows.
Как я думаю уже понятно, весь фокус состоит в коде. Его мы сейчас разберём, но сначала создадим форму. Разместим на ней таймер, и установим некоторые cвойства. (BorderStyle = None, WindowState = Maximized,Name = frmSSaver).Теперь приступаем к созданию кода. Сначала, как и всегда нам нужно объявить все необходимые переменные:
Option Explicit Private DDC As Long 'Переменная для хранения хэндла Рабочего стола Private BlockX As Long 'Размер закрашиваемого кусочка по горизонтали Private BlockY As Long 'Размер закрашиваемого кусочка по вертикали Private Quit As Boolean 'Флаг завершения Private OldX As Single 'переменные для хранения Private OldY As Single 'координат мыши Const AppName = "VB Screen Saver" 'Имя программы в реестре
Так как вся работа выполняется в цикле таймера, для выхода используется флаг Quit. Кстати о самой работе. Весь основной код Хранителя экрана прост как всё гениальное(какой я скромный правда?):
Private Sub Timer1_Timer() 'Код работы Хранителя экрана Dim X As Long, Y As Long X = (Rnd * Screen.Width) / Screen.TwipsPerPixelX Y = (Rnd * Screen.Height) / Screen.TwipsPerPixelY Me.Line (X, Y)-Step(BlockX, BlockY), Me.BackColor, BF If Quit Then 'Если Выход то... Form_Unload 0 End If End Sub
Таймер обеспечивает рисование на форме и выход если флаг Quit установлен, но перед тем как рисовать необходимо сохранить изображение экрана на форме и "спрятать" мышь:
Private Sub Form_Load() 'Гашение курсора ShowCursor False 'Чтение установок If CLng(GetSetting(AppName, Chr$(0), "BackColor", "-1")) = -1 Then Me.BackColor = GetSysColor(COLOR_BACKGROUND) Else Me.BackColor = CLng(GetSetting(AppName, Chr$(0), "BackColor", "0")) End If BlockX = CLng(GetSetting(AppName, Chr$(0), "XSize", 16)) BlockY = CLng(GetSetting(AppName, Chr$(0), "YSize", 8)) Timer1.Interval = CLng(GetSetting(AppName, Chr$(0), "Time", "100")) 'Получение описателя рабочего стола DDC = GetWindowDC(GetDesktopWindow) 'Сохранение экрана на форме BitBlt Me.hdc,0,0,XtoP(Screen.Width),YtoP(Screen.Height),DDC,0,0,vbSrcCopy End Sub
При загрузке формы, программа читает из реестра параметры с помощью функций VB и, с помощью Windows API, убирает с экрана курсор мыши(мышь всё равно активна) и сохраняет экран на форме. Все объявления функций API, я разместил в отдельном модуле . Кстати этот модуль отвечает ещё за кое-какие операции, но об этом позже.
Итак у нас есть код для подготовки формы, и код цикла рисования. Но если не установить флаг выхода цикл будет бесконечен. Поэтому используятся события формы MouseMove и KeyDown.
Private Sub Form_MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single) 'Выход если двигалась мышь If OldX = 0 Or OldY = 0 Then OldX = X: OldY = Y If OldX <> X Or OldY <> Y Then Quit = True End Sub Private Sub Form_KeyDown(KeyCode As Integer, Shift As Integer) Quit = True 'Выход если нажата клавиша End Sub
Я думаю особо сложного в этом коде ничего нет. Вот только переменные OldX и OldY я объявил как доступные по всему модулю. Но чтобы эти переменные не сбрасывались при завершении процедуры обработки MouseMove, можно объявить их внутри неё с помощью оператора Static я не использовал его просто потому что он мне не очень нравиться.
Продолжим: флаг Quit у нас устанавливается. Как Вы, надеюсь, помните при этом в цикле таймера вызывается процедура Form_Unload. В этой процедуре, отменяются все установки сделанные при загрузке формы.
Private Sub Form_Unload(Cancel As Integer) ShowCursor True 'Восстановление курсора ReleaseDC GetDesktopWindow, DDC 'Освобожление Хэндла экрана End 'Собственно выход End Sub
В итоге получили работающий (во всяком случае у меня) код простенького Хранителя экрана. Но если его сейчас откомпилировать в *.scr файл, получим суррогат, который будет сложно использовать(Если хотите попробуйте выбрать такой "Хранитель" в окне свойств Рабочего стола.
Особенность в том, что при запуске Хранителя экрана Windows передаёт ему параметры запуска в командной строке.
Параметры командной строки передаваемые Windows
- /p - Хранитель экрана выбран в окне свойств рабочего стола. (На "мониторе" в окне должна демонстрироваться заставка)
- /c - Пользователь щёлкнул кнопку настройки параметров Хранителя экрана
- /s - Стандартный запуск, или щелчок по кнопке "Просмотр"
- /a - Пользователь хочет установить пароль.
Именно для того чтобы разбирать тип запуска Хранителя экрана и существует модуль SSaver. (API-функции можно поместить и в код формы.)
Public Sub Main() If App.PrevInstance Then Exit Sub Select Case Left(LCase(Trim(Command$)), 2) Case "/s": frmSSaver.Show Case "/c": frmProperties.Show Case Else: End End Select End Sub
В процедуре Main(не забудьте сделать её стартовой) как раз и разбираются эти параметры. Я использовал функцию Left, тем самым проигнорировав оставшиеся символы командной строки. На самом деле эти символы имеют важное значение. К примеру с параметром /p передаётся манипулятор(handle) "монитора" на окне свойств, что позволяет выводить изображение на него. Эту возможность предлагаю изучить Вам.
В завершении (как обычно) добавлю: весь код проверен на моём компьютере в VB 5.0 Enterprise Edition.
Оставить комментарий
Комментарии
Suren.