Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/externals/g4tools/include/toolx/Windows/glarea

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /externals/g4tools/include/toolx/Windows/glarea (Version 11.3.0) and /externals/g4tools/include/toolx/Windows/glarea (Version 9.5.p1)


  1 // Copyright (C) 2010, Guy Barrand. All rights    
  2 // See the file tools.license for terms.          
  3                                                   
  4 #ifndef toolx_Windows_glarea                      
  5 #define toolx_Windows_glarea                      
  6                                                   
  7 #include <windows.h>                              
  8 #include <windowsx.h>                             
  9 #include <wingdi.h>                               
 10                                                   
 11 #include <tools/sg/device_interactor>             
 12 #include <tools/sg/keys>                          
 13 //#include <tools/log_file>                       
 14                                                   
 15 #include <string>                                 
 16                                                   
 17 #if defined(_MSC_VER) && _MSC_VER < 1900          
 18 #elif defined(__MINGW32__)                        
 19 #else                                             
 20 #define TOOLX_WINDOWS_TOUCH                       
 21 #endif                                            
 22                                                   
 23 namespace toolx {                                 
 24 namespace Windows {                               
 25                                                   
 26 #ifdef TOOLX_WINDOWS_TOUCH                        
 27 inline bool is_message_touch_event() {            
 28   // from https://stackoverflow.com/questions/    
 29   static const LONG_PTR c_SIGNATURE_MASK = 0xF    
 30   static const LONG_PTR c_MOUSEEVENTF_FROMTOUC    
 31   LONG_PTR extraInfo = ::GetMessageExtraInfo()    
 32   return ( ( extraInfo & c_SIGNATURE_MASK ) ==    
 33 }                                                 
 34 #endif                                            
 35                                                   
 36 class glarea {                                    
 37   static const std::string& s_class() {           
 38     static const std::string s_v("toolx::Windo    
 39     return s_v;                                   
 40   }                                               
 41   static void register_class(){                   
 42     static bool s_done = false; //not const, t    
 43     if(!s_done) {                                 
 44       WNDCLASS         wc;                        
 45       wc.style         = CS_HREDRAW | CS_VREDR    
 46       wc.lpfnWndProc   = (WNDPROC)proc;           
 47       wc.cbClsExtra    = 0;                       
 48       wc.cbWndExtra    = 0;                       
 49       wc.hInstance     = ::GetModuleHandle(NUL    
 50       wc.hIcon         = LoadIcon(NULL,IDI_APP    
 51       wc.hCursor       = LoadCursor(NULL,IDC_A    
 52       wc.hbrBackground = GetSysColorBrush(COLO    
 53       wc.lpszMenuName  = s_class().c_str();       
 54       wc.lpszClassName = s_class().c_str();       
 55       ::RegisterClass(&wc);                       
 56       s_done = true;                              
 57     }                                             
 58   }                                               
 59 public:                                           
 60   virtual void resize(unsigned int,unsigned in    
 61   virtual void paint(unsigned int,unsigned int    
 62   virtual void close(){}                          
 63                                                   
 64   virtual void left_button_up(unsigned int,uns    
 65   virtual void left_button_down(unsigned int,u    
 66   virtual void mouse_move(unsigned int,unsigne    
 67 public:                                           
 68   glarea(HWND a_parent)                           
 69   :m_parent(a_parent)                             
 70   ,m_hwnd(0)                                      
 71   ,m_context(0)                                   
 72   ,m_HDC(0)                                       
 73   ,m_touch_available(false)                       
 74   ,m_interactor(0)                                
 75   {                                               
 76     register_class();                             
 77     // The WS_BORDER is needed. Else probleme     
 78     RECT rect;                                    
 79     ::GetClientRect(m_parent,&rect);              
 80     //printf("debug : glarea : ca : %d %d\n",r    
 81     //toolx::log_file::get().writef("debug : g    
 82     m_hwnd = ::CreateWindow(s_class().c_str(),    
 83                              NULL,                
 84                              WS_CHILD | WS_VIS    
 85                              0,0,                 
 86                              rect.right-rect.l    
 87                              rect.bottom-rect.    
 88                              m_parent,NULL,       
 89                              GetWindowInstance    
 90                              NULL);               
 91     if(!m_hwnd) return;                           
 92     ::SetWindowLongPtr(m_hwnd,GWLP_USERDATA,LO    
 93                                                   
 94     // initialize OpenGL rendering :              
 95     m_HDC = ::GetDC(m_hwnd);                      
 96     if(m_HDC && SetWindowPixelFormat(m_HDC) )     
 97       m_context = ::wglCreateContext(m_HDC);      
 98     }                                             
 99                                                   
100 #ifdef TOOLX_WINDOWS_TOUCH                        
101    {BYTE digitizer_status = (BYTE)::GetSystemM    
102     if((digitizer_status & (0x80 + 0x40)) == 0    
103       m_touch_available = false;                  
104     } else {                                      
105       //BYTE nInputs = (BYTE)::GetSystemMetric    
106       m_touch_available = true;                   
107       if(!::RegisterTouchWindow(m_hwnd,0)) m_t    
108     }}                                            
109 #endif                                            
110                                                   
111   }                                               
112   virtual ~glarea(){                              
113     if(::wglGetCurrentContext()!=NULL) ::wglMa    
114     if(m_context)        {                        
115       ::wglDeleteContext(m_context);              
116       m_context = 0;                              
117     }                                             
118     if(m_HDC && m_hwnd) ::ReleaseDC(m_hwnd,m_H    
119     if(m_hwnd) {                                  
120       ::SetWindowLongPtr(m_hwnd,GWLP_USERDATA,    
121       ::DestroyWindow(m_hwnd);                    
122       m_hwnd = 0;                                 
123     }                                             
124   }                                               
125 protected:                                        
126   glarea(const glarea& a_from)                    
127   :m_parent(a_from.m_parent)                      
128   ,m_hwnd(0)                                      
129   ,m_context(0)                                   
130   ,m_HDC(0)                                       
131   ,m_touch_available(a_from.m_touch_available)    
132   ,m_interactor(0)                                
133   {                                               
134     if(!m_parent) return;                         
135     register_class();                             
136     RECT rect;                                    
137     ::GetClientRect(m_parent,&rect);              
138     m_hwnd = ::CreateWindow(s_class().c_str(),    
139                              NULL,                
140                              WS_CHILD | WS_VIS    
141                              0,0,                 
142                              rect.right-rect.l    
143                              rect.bottom-rect.    
144                              m_parent,NULL,       
145                              GetWindowInstance    
146                              NULL);               
147     if(!m_hwnd) return;                           
148     ::SetWindowLongPtr(m_hwnd,GWLP_USERDATA,LO    
149                                                   
150     // initialize OpenGL rendering :              
151     m_HDC = ::GetDC(m_hwnd);                      
152     if(m_HDC && SetWindowPixelFormat(m_HDC) )     
153       m_context = ::wglCreateContext(m_HDC);      
154     }                                             
155                                                   
156 #ifdef TOOLX_WINDOWS_TOUCH                        
157     if(a_from.m_touch_available) {                
158       if(!::RegisterTouchWindow(m_hwnd,0)) m_t    
159     }                                             
160 #endif                                            
161   }                                               
162 protected:                                        
163   glarea& operator=(const glarea&){return *thi    
164 public:                                           
165   void set_client_area_size(unsigned int a_w,u    
166     RECT rect;                                    
167     ::GetClientRect(m_hwnd,&rect);                
168     ::MoveWindow(m_hwnd,rect.left,rect.top,a_w    
169   }                                               
170   HWND hwnd() const {return m_hwnd;}              
171   void post_WM_PAINT() const {                    
172     ::PostMessage(m_hwnd,WM_PAINT,(WPARAM)0,(L    
173   }                                               
174   void send_WM_PAINT() const {                    
175     ::SendMessage(m_hwnd,WM_PAINT,(WPARAM)0,(L    
176   }                                               
177   void wm_paint() {                               
178     PAINTSTRUCT ps;                               
179     //HDC hDC =                                   
180     BeginPaint(m_hwnd,&ps);                       
181     if(m_HDC && m_context) {                      
182       ::wglMakeCurrent(m_HDC,m_context);          
183                                                   
184       RECT rect;                                  
185       ::GetClientRect(m_hwnd,&rect);              
186       unsigned int w = rect.right-rect.left;      
187       unsigned int h = rect.bottom-rect.top;      
188                                                   
189       //printf("debug : glarea : paint : %d %d    
190       //toolx::log_file::get().writef("debug :    
191                                                   
192       paint(w,h);                                 
193                                                   
194       ::SwapBuffers(m_HDC);                       
195       ::wglMakeCurrent(m_HDC,0);                  
196     }                                             
197     EndPaint(m_hwnd,&ps);                         
198   }                                               
199 public:                                           
200   void set_device_interactor(tools::sg::device    
201 protected:                                        
202   bool is_touch_event() {                         
203 #ifdef TOOLX_WINDOWS_TOUCH                        
204     if(!m_touch_available) return false;          
205     return is_message_touch_event();              
206 #else                                             
207     return false;                                 
208 #endif                                            
209   }                                               
210 protected:                                        
211   static LRESULT CALLBACK proc(HWND a_hwnd,UIN    
212     switch (a_msg) {                              
213     case WM_SIZE:{                                
214       int width = LOWORD(a_lparam);               
215       int height = HIWORD(a_lparam);              
216       glarea* _this = (glarea*)::GetWindowLong    
217       if(_this) {                                 
218         _this->resize(width,height);              
219       } else {                                    
220         // CreateWindow send a WM_SIZE but GWL    
221       }                                           
222     }return 0;                                    
223     case WM_PAINT:{                               
224       glarea* _this = (glarea*)::GetWindowLong    
225       if(_this) _this->wm_paint();                
226     }return 0;                                    
227                                                   
228     case WM_KEYDOWN:{                             
229       glarea* _this = (glarea*)::GetWindowLong    
230       if(_this) {                                 
231         if(_this->m_interactor) {                 
232           tools::sg::key_down_event event(_thi    
233           _this->m_interactor->key_press(event    
234         }                                         
235       }                                           
236     } return 0;                                   
237     case WM_KEYUP:{                               
238       glarea* _this = (glarea*)::GetWindowLong    
239       if(_this) {                                 
240         if(_this->m_interactor) {                 
241           tools::sg::key_up_event event(_this-    
242           _this->m_interactor->key_release(eve    
243         }                                         
244       }                                           
245     } return 0;                                   
246                                                   
247     case WM_LBUTTONDOWN:{                         
248       glarea* _this = (glarea*)::GetWindowLong    
249       if(_this) {                                 
250         if(_this->m_interactor) {                 
251           tools::sg::mouse_down_event event(LO    
252           _this->m_interactor->mouse_press(eve    
253         } else {                                  
254           RECT rect;                              
255           ::GetClientRect(a_hwnd,&rect);          
256           unsigned int h = rect.bottom-rect.to    
257           if(!_this->is_touch_event()) _this->    
258         }                                         
259       }                                           
260     }return 0;                                    
261     case WM_LBUTTONUP:{                           
262       glarea* _this = (glarea*)::GetWindowLong    
263       if(_this) {                                 
264         if(_this->m_interactor) {                 
265           tools::sg::mouse_up_event event(LOWO    
266           _this->m_interactor->mouse_release(e    
267         } else {                                  
268           RECT rect;                              
269           ::GetClientRect(a_hwnd,&rect);          
270           unsigned int h = rect.bottom-rect.to    
271     if(!_this->is_touch_event()) _this->left_b    
272         }                                         
273       }                                           
274     } return 0;                                   
275     case WM_MOUSEMOVE:{                           
276       glarea* _this = (glarea*)::GetWindowLong    
277       if(_this) {                                 
278         if(_this->m_interactor) {                 
279           tools::sg::mouse_move_event event(LO    
280           _this->m_interactor->mouse_move(even    
281         } else {                                  
282           WPARAM state = a_wparam;                
283           bool ldown = ((state & MK_LBUTTON)==    
284           RECT rect;                              
285           ::GetClientRect(a_hwnd,&rect);          
286           unsigned int h = rect.bottom-rect.to    
287           if(!_this->is_touch_event()) _this->    
288         }                                         
289       }                                           
290                                                   
291     }return 0;                                    
292                                                   
293     case WM_MOUSEWHEEL:{                          
294       glarea* _this = (glarea*)::GetWindowLong    
295       if(_this) {                                 
296         if(_this->m_interactor) {                 
297           tools::sg::wheel_rotate_event event(    
298     _this->m_interactor->wheel_rotate(event);     
299         }                                         
300       }                                           
301     } return 0;                                   
302                                                   
303 #ifdef TOOLX_WINDOWS_TOUCH                        
304     case WM_TOUCH:{                               
305       glarea* _this = (glarea*)::GetWindowLong    
306       if(_this && _this->m_touch_available) {     
307         RECT rect;                                
308         //::GetWindowRect(hwnd,&rect); ???        
309         ::GetClientRect(a_hwnd,&rect);            
310         unsigned int h = rect.bottom-rect.top;    
311                                                   
312         unsigned int num_inputs = (int)a_wpara    
313         //::printf("debug : WM_TOUCH : 001 : %    
314         TOUCHINPUT* ti = new TOUCHINPUT[num_in    
315         POINT p;                                  
316         if(::GetTouchInputInfo((HTOUCHINPUT)a_    
317           for(unsigned int i=0;i<num_inputs; +    
318             p.x = TOUCH_COORD_TO_PIXEL(ti[i].x    
319             p.y = TOUCH_COORD_TO_PIXEL(ti[i].y    
320             if(!::ScreenToClient(a_hwnd,&p)) {    
321             if(ti[i].dwFlags & TOUCHEVENTF_DOW    
322               //::printf("debug : TOUCHEVENTF_    
323               _this->left_button_down(p.x,h-p.    
324             } else if (ti[i].dwFlags & TOUCHEV    
325               //::printf("debug : TOUCHEVENTF_    
326               _this->left_button_up(p.x,h-p.y)    
327             } else if (ti[i].dwFlags & TOUCHEV    
328               bool ldown = true; //we assume t    
329               //::printf("debug : TOUCHEVENTF_    
330               _this->mouse_move(p.x,h-p.y,ldow    
331             }                                     
332           }                                       
333         }                                         
334         ::CloseTouchInputHandle((HTOUCHINPUT)a    
335         delete [] ti;                             
336       }                                           
337     }return 0;                                    
338 #endif //TOOLX_WINDOWS_TOUCH                      
339     case WM_DESTROY:wm__destroy(a_hwnd);return    
340     }                                             
341     return (DefWindowProc(a_hwnd,a_msg,a_wpara    
342   }                                               
343   static bool SetWindowPixelFormat(HDC a_HDC){    
344     PIXELFORMATDESCRIPTOR pfd;                    
345     pfd.nSize = sizeof(PIXELFORMATDESCRIPTOR);    
346     pfd.nVersion = 1;                             
347     pfd.dwFlags =                                 
348       PFD_DRAW_TO_WINDOW |                        
349       PFD_SUPPORT_OPENGL |                        
350       PFD_DOUBLEBUFFER |                          
351       PFD_STEREO_DONTCARE;                        
352     pfd.iPixelType = PFD_TYPE_RGBA;               
353     pfd.cColorBits = 32;                          
354     pfd.cRedBits = 8;                             
355     pfd.cRedShift = 16;                           
356     pfd.cGreenBits = 8;                           
357     pfd.cGreenShift = 8;                          
358     pfd.cBlueBits = 8;                            
359     pfd.cBlueShift = 0;                           
360     pfd.cAlphaBits = 0;                           
361     pfd.cAlphaShift = 0;                          
362     pfd.cAccumBits = 64;                          
363     pfd.cAccumRedBits = 16;                       
364     pfd.cAccumGreenBits = 16;                     
365     pfd.cAccumBlueBits = 16;                      
366     pfd.cAccumAlphaBits = 0;                      
367     pfd.cDepthBits = 32;                          
368     pfd.cStencilBits = 8;                         
369     pfd.cAuxBuffers = 0;                          
370     pfd.iLayerType = PFD_MAIN_PLANE;              
371     pfd.bReserved = 0;                            
372     pfd.dwLayerMask = 0;                          
373     pfd.dwVisibleMask = 0;                        
374     pfd.dwDamageMask = 0;                         
375                                                   
376     int pixelIndex = ::ChoosePixelFormat(a_HDC    
377     if (pixelIndex==0) {                          
378       // Let's choose a default index.            
379       pixelIndex = 1;                             
380       if (::DescribePixelFormat(a_HDC,            
381                                 pixelIndex,       
382                                 sizeof(PIXELFO    
383                                 &pfd)==0) {       
384         return false;                             
385       }                                           
386     }                                             
387                                                   
388     if (::SetPixelFormat(a_HDC,pixelIndex,&pfd    
389                                                   
390     return true;                                  
391   }                                               
392   static void wm__destroy(HWND a_hwnd) {          
393     glarea* _this = (glarea*)::GetWindowLongPt    
394     if(_this) { //How to be sure that we have     
395       _this->close();                             
396       if(_this->m_hwnd!=a_hwnd) {                 
397         //::printf("WinTk::Component::wm_destr    
398       }                                           
399       _this->m_hwnd = 0;                          
400     }                                             
401     ::SetWindowLongPtr(a_hwnd,GWLP_USERDATA,LO    
402   }                                               
403 protected:                                        
404   tools::key_code convert(WPARAM a_key) {         
405     if(a_key==VK_SHIFT) return tools::sg::key_    
406     return (tools::key_code)a_key;                
407   }                                               
408 protected:                                        
409   HWND m_parent;                                  
410   HWND m_hwnd;                                    
411   HGLRC m_context;                                
412   HDC m_HDC;                                      
413   bool m_touch_available;                         
414   tools::sg::device_interactor* m_interactor;     
415 };                                                
416                                                   
417 }}                                                
418                                                   
419 #endif