mirror of
				https://github.com/gnif/LookingGlass.git
				synced 2025-10-25 00:38:09 +00:00 
			
		
		
		
	[all] update KVMFR to provide cursor hotspot information
This commit bumps the KVMFR protocol version as it adds additional hotspot x & y fields to the KVMFRCursor struct. This corrects the issue of invalid alignment of the local mouse when the shape has an offset such as the 'I' beam.
This commit is contained in:
		| @@ -67,6 +67,7 @@ typedef struct CapturePointer | ||||
|  | ||||
|   bool          shapeUpdate; | ||||
|   CaptureFormat format; | ||||
|   unsigned int  hx, hy; | ||||
|   unsigned int  width, height; | ||||
|   unsigned int  pitch; | ||||
| } | ||||
|   | ||||
| @@ -827,7 +827,26 @@ static CaptureResult dxgi_capture() | ||||
|           return CAPTURE_RESULT_ERROR; | ||||
|       } | ||||
|  | ||||
|       CURSORINFO ci = { .cbSize = sizeof(CURSORINFO) }; | ||||
|       if (!GetCursorInfo(&ci)) | ||||
|       { | ||||
|         DEBUG_ERROR("GetCursorInfo failed"); | ||||
|         return CAPTURE_RESULT_ERROR; | ||||
|       } | ||||
|  | ||||
|       ICONINFO ii; | ||||
|       if (!GetIconInfo(ci.hCursor, &ii)) | ||||
|       { | ||||
|         DEBUG_ERROR("GetIconInfo failed"); | ||||
|         return CAPTURE_RESULT_ERROR; | ||||
|       } | ||||
|  | ||||
|       DeleteObject(ii.hbmMask); | ||||
|       DeleteObject(ii.hbmColor); | ||||
|  | ||||
|       pointer.shapeUpdate = true; | ||||
|       pointer.hx          = ii.xHotspot; | ||||
|       pointer.hy          = ii.yHotspot; | ||||
|       pointer.width       = shapeInfo.Width; | ||||
|       pointer.height      = shapeInfo.Height; | ||||
|       pointer.pitch       = shapeInfo.Pitch; | ||||
|   | ||||
| @@ -352,8 +352,8 @@ static int pointerThread(void * unused) | ||||
|       } | ||||
|  | ||||
|       this->mouseVisible = pointer.visible; | ||||
|       this->mouseHotX    = pointer.x; | ||||
|       this->mouseHotY    = pointer.y; | ||||
|       this->mouseHotX    = pointer.hx; | ||||
|       this->mouseHotY    = pointer.hy; | ||||
|     } | ||||
|  | ||||
|     if (events[0]) | ||||
|   | ||||
| @@ -288,8 +288,8 @@ CaptureResult NvFBCToSysGetCursor(NvFBCHandle handle, CapturePointer * pointer, | ||||
|     return CAPTURE_RESULT_ERROR; | ||||
|   } | ||||
|  | ||||
|   pointer->x           = params.dwXHotSpot; | ||||
|   pointer->y           = params.dwYHotSpot; | ||||
|   pointer->hx          = params.dwXHotSpot; | ||||
|   pointer->hy          = params.dwYHotSpot; | ||||
|   pointer->width       = params.dwWidth; | ||||
|   pointer->height      = params.dwHeight; | ||||
|   pointer->pitch       = params.dwPitch; | ||||
| @@ -327,4 +327,4 @@ CaptureResult NvFBCToSysGetCursor(NvFBCHandle handle, CapturePointer * pointer, | ||||
|  | ||||
|   memcpy(buffer, params.pBits, params.dwBufferSize); | ||||
|   return CAPTURE_RESULT_OK; | ||||
| } | ||||
| } | ||||
|   | ||||
| @@ -336,7 +336,8 @@ static void sendPointer(bool newClient) | ||||
|  | ||||
|   if (app.pointerInfo.shapeUpdate) | ||||
|   { | ||||
|     // remember which slot has the latest shape | ||||
|     cursor->hx     = app.pointerInfo.hx; | ||||
|     cursor->hy     = app.pointerInfo.hy; | ||||
|     cursor->width  = app.pointerInfo.width; | ||||
|     cursor->height = app.pointerInfo.height; | ||||
|     cursor->pitch  = app.pointerInfo.pitch; | ||||
| @@ -489,6 +490,7 @@ int app_main(int argc, char * argv[]) | ||||
|       DEBUG_ERROR("lgmpHostMemAlloc Failed (Pointer): %s", lgmpStatusString(status)); | ||||
|       goto fail; | ||||
|     } | ||||
|     memset(lgmpHostMemPtr(app.pointerMemory[i]), 0, MAX_POINTER_SIZE); | ||||
|   } | ||||
|  | ||||
|   app.pointerShapeValid = false; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Geoffrey McRae
					Geoffrey McRae