mirror of
				https://github.com/gnif/LookingGlass.git
				synced 2025-10-25 16:58:10 +00:00 
			
		
		
		
	[client] Added window positional options
This commit is contained in:
		| @@ -54,7 +54,11 @@ struct AppState | |||||||
|  |  | ||||||
| struct AppParams | struct AppParams | ||||||
| { | { | ||||||
|  |   bool         autoResize; | ||||||
|   bool         borderless; |   bool         borderless; | ||||||
|  |   bool         center; | ||||||
|  |   int          x, y; | ||||||
|  |   unsigned int w, h; | ||||||
|   const char * ivshmemSocket; |   const char * ivshmemSocket; | ||||||
|   bool         useBufferStorage; |   bool         useBufferStorage; | ||||||
|   bool         useSpice; |   bool         useSpice; | ||||||
| @@ -65,7 +69,13 @@ struct AppParams | |||||||
| struct AppState  state; | struct AppState  state; | ||||||
| struct AppParams params = | struct AppParams params = | ||||||
| { | { | ||||||
|   .borderless       = true, |   .autoResize       = false, | ||||||
|  |   .borderless       = false, | ||||||
|  |   .center           = true, | ||||||
|  |   .x                = 0, | ||||||
|  |   .y                = 0, | ||||||
|  |   .w                = 100, | ||||||
|  |   .h                = 100, | ||||||
|   .ivshmemSocket    = "/tmp/ivshmem_socket", |   .ivshmemSocket    = "/tmp/ivshmem_socket", | ||||||
|   .useBufferStorage = true, |   .useBufferStorage = true, | ||||||
|   .useSpice         = true, |   .useSpice         = true, | ||||||
| @@ -195,7 +205,10 @@ int renderThread(void * unused) | |||||||
|       } |       } | ||||||
|  |  | ||||||
|       // update the window size and create the render texture |       // update the window size and create the render texture | ||||||
|  |       if (params.autoResize) | ||||||
|         SDL_SetWindowSize(state.window, state.shm->width, state.shm->height); |         SDL_SetWindowSize(state.window, state.shm->width, state.shm->height); | ||||||
|  |  | ||||||
|  |       if (params.center) | ||||||
|         SDL_SetWindowPosition(state.window, SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED); |         SDL_SetWindowPosition(state.window, SDL_WINDOWPOS_CENTERED, SDL_WINDOWPOS_CENTERED); | ||||||
|  |  | ||||||
|       if (state.hasBufferStorage) |       if (state.hasBufferStorage) | ||||||
| @@ -260,6 +273,7 @@ int renderThread(void * unused) | |||||||
|       state.windowChanged = true; |       state.windowChanged = true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     SDL_RenderClear(state.renderer); | ||||||
|     if (state.hasBufferStorage) |     if (state.hasBufferStorage) | ||||||
|     { |     { | ||||||
|       // copy the buffer to the texture and let the guest advance |       // copy the buffer to the texture and let the guest advance | ||||||
| @@ -548,10 +562,15 @@ int run() | |||||||
|  |  | ||||||
|   state.window = SDL_CreateWindow( |   state.window = SDL_CreateWindow( | ||||||
|     "KVM-GFX Test", |     "KVM-GFX Test", | ||||||
|       SDL_WINDOWPOS_CENTERED, |     params.center ? SDL_WINDOWPOS_CENTERED : params.x, | ||||||
|       SDL_WINDOWPOS_CENTERED, |     params.center ? SDL_WINDOWPOS_CENTERED : params.y, | ||||||
|       100, 100, |     params.w, | ||||||
|       params.borderless ? SDL_WINDOW_BORDERLESS : 0 |     params.h, | ||||||
|  |     ( | ||||||
|  |       SDL_WINDOW_SHOWN | | ||||||
|  |       (!params.autoResize ? SDL_WINDOW_RESIZABLE  : 0) | | ||||||
|  |       ( params.borderless ? SDL_WINDOW_BORDERLESS : 0) | ||||||
|  |     ) | ||||||
|   ); |   ); | ||||||
|  |  | ||||||
|   if (!state.window) |   if (!state.window) | ||||||
| @@ -680,23 +699,39 @@ int run() | |||||||
|  |  | ||||||
| void doHelp(char * app) | void doHelp(char * app) | ||||||
| { | { | ||||||
|  |   char x[8], y[8]; | ||||||
|  |   snprintf(x, sizeof(x), "%d", params.x); | ||||||
|  |   snprintf(y, sizeof(y), "%d", params.y); | ||||||
|  |  | ||||||
|   fprintf(stderr, |   fprintf(stderr, | ||||||
|     "Usage: %s [OPTION]...\n" |     "Usage: %s [OPTION]...\n" | ||||||
|     "Example: %s -h\n" |     "Example: %s -h\n" | ||||||
|     "\n" |     "\n" | ||||||
|     "  -h        Print out this help\n" |     "  -h        Print out this help\n" | ||||||
|     "  -f PATH   Specify the path to the ivshmem socket [current: %s]\n" |     "  -f PATH   Specify the path to the ivshmem socket [current: %s]\n" | ||||||
|     "  -d       Disable OpenGL 4.3 Buffer Storage (GL_ARB_buffer_storage)\n" |     "  -g        Disable OpenGL 4.3 Buffer Storage (GL_ARB_buffer_storage)\n" | ||||||
|     "  -s        Disable spice client\n" |     "  -s        Disable spice client\n" | ||||||
|     "  -c HOST   Specify the spice host [current: %s]\n" |     "  -c HOST   Specify the spice host [current: %s]\n" | ||||||
|     "  -p PORT   Specify the spice port [current: %d]\n" |     "  -p PORT   Specify the spice port [current: %d]\n" | ||||||
|  |     "\n" | ||||||
|  |     "  -a        Auto resize the window to the guest\n" | ||||||
|  |     "  -d        Borderless mode\n" | ||||||
|  |     "  -x XPOS   Initial window X position [current: %s]\n" | ||||||
|  |     "  -y YPOS   Initial window Y position [current: %s]\n" | ||||||
|  |     "  -w WIDTH  Initial window width [current: %u]\n" | ||||||
|  |     "  -b HEIGHT Initial window height [current: %u]\n" | ||||||
|  |     "\n" | ||||||
|     "  -l        License information\n" |     "  -l        License information\n" | ||||||
|     "\n", |     "\n", | ||||||
|     app, |     app, | ||||||
|     app, |     app, | ||||||
|     params.ivshmemSocket, |     params.ivshmemSocket, | ||||||
|     params.spiceHost, |     params.spiceHost, | ||||||
|     params.spicePort |     params.spicePort, | ||||||
|  |     params.center ? "center" : x, | ||||||
|  |     params.center ? "center" : y, | ||||||
|  |     params.w, | ||||||
|  |     params.h | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -726,7 +761,7 @@ void doLicense() | |||||||
| int main(int argc, char * argv[]) | int main(int argc, char * argv[]) | ||||||
| { | { | ||||||
|   int c; |   int c; | ||||||
|   while((c = getopt(argc, argv, "hf:dsc:p:l")) != -1) |   while((c = getopt(argc, argv, "hf:gsc:p:adx:y:w:b:l")) != -1) | ||||||
|     switch(c) |     switch(c) | ||||||
|     { |     { | ||||||
|       case '?': |       case '?': | ||||||
| @@ -739,7 +774,7 @@ int main(int argc, char * argv[]) | |||||||
|         params.ivshmemSocket = optarg; |         params.ivshmemSocket = optarg; | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|       case 'd': |       case 'g': | ||||||
|         params.useBufferStorage = false; |         params.useBufferStorage = false; | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
| @@ -755,10 +790,35 @@ int main(int argc, char * argv[]) | |||||||
|         params.spicePort = atoi(optarg); |         params.spicePort = atoi(optarg); | ||||||
|         break; |         break; | ||||||
|  |  | ||||||
|  |       case 'a': | ||||||
|  |         params.autoResize = true; | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |       case 'd': | ||||||
|  |         params.borderless = true; | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |       case 'x': | ||||||
|  |         params.center = false; | ||||||
|  |         params.x = atoi(optarg); | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |       case 'y': | ||||||
|  |         params.center = false; | ||||||
|  |         params.y = atoi(optarg); | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |       case 'w': | ||||||
|  |         params.w = atoi(optarg); | ||||||
|  |         break; | ||||||
|  |  | ||||||
|  |       case 'b': | ||||||
|  |         params.h = atoi(optarg); | ||||||
|  |         break; | ||||||
|  |  | ||||||
|       case 'l': |       case 'l': | ||||||
|         doLicense(); |         doLicense(); | ||||||
|         return 0; |         return 0; | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   return run(); |   return run(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Geoffrey McRae
					Geoffrey McRae