|
| БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО! |
|
|
Dragging Images
The Win32 API includes functions for dragging an image on the screen. The dragging functions move an image smoothly, in color, and without any flashing of the cursor. Both masked and unmasked images can be dragged.
The ImageList_BeginDrag function begins a drag operation. The parameters include the handle of the image list, the index of the image to drag, and the location of the hot spot within the image. The hot spot is a single pixel that the dragging functions recognize as the exact screen location of the image. Typically, an application sets the hot spot so that it coincides with the hot spot of the mouse cursor. The ImageList_DragMove function moves the image to a new location.
The ImageList_DragEnter function sets the initial position of the drag image within a window and draws the image at the position. The parameters include the handle of the window in which to draw the image and the coordinates of the initial position within the window. The coordinates are relative to the window's upper-left corner, not the client area. The same is true for all of the image dragging functions that take coordinates as parameters. This means you must compensate for the widths of window elements, such as the border, title bar, and menu bar, when specifying the coordinates. If you specify a NULL window handle when calling ImageList_DragEnter, the dragging functions draw the image in the device context associated with the desktop window, and the coordinates are relative to the upper-left corner of the screen.
ImageList_DragEnter locks all other updates to the given window during the drag operation. If you need to do any drawing during a drag operation, such as highlighting the target of a drag and drop operation, you can temporarily hide the dragged image by using the ImageList_DragLeave function. Another method is to use the GetDCEx function with the DCX_LOCKWINDOWUPDATE value to retrieve a device context that allows you to draw. You must be careful, however, not to obliterate the dragged image.
The ImageList_SetDragCursorImage creates a new drag image by combining the given image (typically a mouse cursor image) with the current drag image. Because the dragging functions use the new image during a drag operation, you should use the ShowCursor function to hide the actual mouse cursor after calling ImageList_SetDragCursorImage. Otherwise, the system may appear to have two mouse cursors for the duration of the drag operation.
When an application calls ImageList_BeginDrag, the system creates an temporary, internal image list can copies the specified drag image to the internal list. You can retrieves the handle of the temporary drag image list by using the ImageList_GetDragImage function. The function also retrieves the current drag position, and the offset of the drag image relative to the drag position.
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
Перемещение Образов
Win32 API Включает функции для перемещения образа на экране. Перемещение функционирует перемещению образ гладко, в цвете, и без любого мигания курсора. Как замаскированное так и демаскировавшее образы может быть потащено.
Функция ImageList_BeginDrag начинает действие помехи. Параметры включают ручку списка образа, индекс образа, чтобы помеха, и позиция горячей точки в пределах образа. Горячая точка является единственным пикселем, что перемещение функций признает в качестве точной экранной позиции образа. Обычно, приложение устанавливает горячую точку чтобы оно совпадало с горячей точкой курсора мыши. Функция ImageList_DragMove перемещает образ на новую позицию.
Функция ImageList_DragEnter устанавливает начальную позицию образа помехи в пределах окна и делает образом в позиции. Параметры включают ручку окна, чтобы делать образом и координаты инициала позиционируются в пределах окна. Координаты - относительно верхнего левого угла окна, не область клиента. Тот же - истина для всего образа, тащащего функции, что брать координаты как параметры. Это означает, что Вы должны компенсировать за ширину элементов окна, как например, граничная, зона названия, и зона меню, при определении координат. Если Вы определяете НЕДЕЙСТВИТЕЛЬНАЯ ручка окна при вызове ImageList_DragEnter, перемещение функций делает образом в контексте устройства связанном настольным окном, и координаты - относительно верхнего левого угла экрана.
ImageList_DragEnter запирает всю другую коррекцию в данное окно в течение операции помехи. Если Вам нужно делать любым чертежом в течение операции помехи, как например, выделенный объект операции перераспределения, Вы можете временно спрятать потащенный образ используя функцию ImageList_DragLeave. Другой метод должен использовать функцию GetDCEx с величиной DCX_LOCKWINDOWUPDATE, чтобы извлекать контекст устройства, который позволяет Вам, чтобы делать. Вы по-видимому осторожными, тем не менее, не, чтобы уничтожить потащенный образ.
ImageList_SetDragCursorImage Создает новый образ помехи объединяя данный образ (обычно образ курсора мыши) с текущим образом помехи. Поскольку перемещение функционирует использованию новый образ в течение операции помехи, Вы должны использовать функцию ShowCursor, чтобы прятать фактический курсор мыши после вызова ImageList_SetDragCursorImage. В противном случае, система может оказывается иметь два курсора мыши в течение операции помехи.
Когда приложение называет ImageList_BeginDrag, система создает временный, внутренний список образа может скопировать определенный образ помехи во внутренний список. Вы можете извлечь ручку списка образа временной помехи используя функцию ImageList_GetDragImage. Функция также извлекает текущую позицию помехи, и смещение образа помехи относительно позиции помехи.
|
|
|
|
| |