Если старшее слово lpFileName равно нулю, нижнее слово представляет собой идентификатор системного курсора. Затем функция просматривает секцию [ Cursors ] в файле WIN . INI на предмет файла, связанного с именем указанного системного курсора. Ниже приводится список имен системных курсоров и идентификаторов:
Имена системных курсоров
|
Идентификаторы системных курсоров
|
"Arrow"
|
OCR_NORMAL
|
"IBeam"
|
OCR_IBEAM
|
"Wait"
|
OCR_WAIT
|
"Crosshair"
|
OCR_CROSS
|
"UpArrow"
|
OCR_UP
|
"Size"
|
OCR_SIZE
|
"Icon"
|
OCR_ICON
|
"SizeNWSE"
|
OCR_SIZENWSE
|
"SizeNESW"
|
OCR_SIZENESW
|
"SizeWE"
|
OCR_SIZEWE
|
"SizeNS"
|
OCR_SIZENS
|
"SizeAll"
|
OCR_SIZEALL
|
"No"
|
OCR_NO
|
"AppStarting"
|
OCR_APPSTARTING
|
Например, если в WIN . INI содержится следующее:
[Cursors]
Arrow = "arrow.ani"
то вызов LoadCursorFromFile(( LPWSTR) OCR _ NORMAL ) заставит функцию LoadCursorFromFileполучить данные из файла ARROW . ANI . Если WIN . INI не содержит строки для указанного системного курсора, вызов функции завершится неудачей и функция вернет NULL .
Возвращаемые значения
В случае успеха возвращается дескриптор нового курсора.
В случае неудачи возвращается NULL . Для получения дополнительной информации об ошибке вызовите функцию GetLastError. GetLastErrorможет вернуть следующее значение: ERROR _ FILE _ NOT _ FOUND - указанный файл не может быть найден.
См. также
LoadCursor, SetCursor, SetSystemCursor.
Функция SetCursorустанавливает курсор.
HCURSOR SetCursor(
HCURSOR hCursor // дескриптор курсора
);
Параметры
hCursor - идентифицирует курсор. Курсор должен быть создан функцией CreateCursorили загружен функциями LoadCursorили LoadImage. Если значение этого параметра равно NULL, курсор убирается с экрана.
Windows 95:Ширина и высота курсора должны быть значениями, возвращаемые функцией GetSystemMetricsдля параметров SM _ CXCURSOR и SM _ CYCURSOR . В дополнение, глубина цвета курсора должна совпадать с глубиной цвета экрана, или курсор будет монохромным.
Возвращаемые значения
Возвращается дескриптор предыдущего курсора, если таковой имеется.
Если предыдущего курсора нет, возвращается NULL .
Комментарии
Курсор устанавливается, только если он отличен от предыдущего курсора. В противном случае, функция возвращает управление немедленно.
Курсор является разделяемым ресурсом. Окно должно устанавливать курсор только в том случае, если он находится в его клиентской области и окно перехватывает ввод мыши. В системах без мыши, окно должно восстанавливать предыдущий курсор перед тем, как он покинет клиентскую область окна.
Если ваше приложение должно устанавливать курсор, когда он находится в окне, будьте уверены, что курсор класса для указанного класса окна установлен в NULL . Если курсор класса не NULL, система восстанавливает курсор класса каждый раз, когда перемещается мышь.
Курсор не отображается на экране, если внутренний счетчик отображений меньше нуля. Это происходит, если приложение использует функцию ShowCursorдля скрытия курсора большее число раз, чем оно показывает курсор.
См. также
CreateCursor, Ge tCursor, GetSystemMetrics, LoadCursor, LoadImage, SetCursorPos, ShowCursor.
Функция SetCursorPosперемещает курсор в указанные экранные координаты. Если новые координаты находятся вне экранного прямоугольника, установленного последним вызовом функции ClipCursor, Windows автоматически устанавливает координаты, так что курсор остается внутри прямоугольника.
BOOL SetCursorPos(
int X , // горизонтальное положение
int Y // вертикальное положение
);
Параметры
X - определяет новую x -координату курсора в экранных координатах.
Y - определяет новую y -координату курсора в экранных координатах.
Возвращаемые значения
В случае успеха возвращается ненулевое значение.
В случае неудачи возвращается нуль. Для дополнительной информации об ошибке вызовите функцию GetLastError.
Комментарии
Курсор является разделяемым ресурсом. Окно должно перемещать курсор, только если он находится в его клиентской области.
Вызывающий процесс должен иметь доступ WINSTA _ READATTRIBUTES к оконной станции ( window station ). Разъяснение термина window station смотрите в описании функции CreateWindowStation.
Читать дальше