win32_window.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. #ifndef RUNNER_WIN32_WINDOW_H_
  2. #define RUNNER_WIN32_WINDOW_H_
  3. #include <windows.h>
  4. #include <functional>
  5. #include <memory>
  6. #include <string>
  7. // A class abstraction for a high DPI-aware Win32 Window. Intended to be
  8. // inherited from by classes that wish to specialize with custom
  9. // rendering and input handling
  10. class Win32Window
  11. {
  12. public:
  13. struct Point
  14. {
  15. unsigned int x;
  16. unsigned int y;
  17. Point(unsigned int x, unsigned int y) : x(x), y(y) {}
  18. };
  19. struct Size
  20. {
  21. unsigned int width;
  22. unsigned int height;
  23. Size(unsigned int width, unsigned int height)
  24. : width(width), height(height) {}
  25. };
  26. Win32Window();
  27. virtual ~Win32Window();
  28. // Creates and shows a win32 window with |title| and position and size using
  29. // |origin| and |size|. New windows are created on the default monitor. Window
  30. // sizes are specified to the OS in physical pixels, hence to ensure a
  31. // consistent size to will treat the width height passed in to this function
  32. // as logical pixels and scale to appropriate for the default monitor. Returns
  33. // true if the window was created successfully.
  34. bool CreateAndShow(const std::wstring &title,
  35. const Point &origin,
  36. const Size &size);
  37. // Release OS resources associated with window.
  38. void Destroy();
  39. // Inserts |content| into the window tree.
  40. void SetChildContent(HWND content);
  41. // Returns the backing Window handle to enable clients to set icon and other
  42. // window properties. Returns nullptr if the window has been destroyed.
  43. HWND GetHandle();
  44. // If true, closing this window will quit the application.
  45. void SetQuitOnClose(bool quit_on_close);
  46. // Return a RECT representing the bounds of the current client area.
  47. RECT GetClientArea();
  48. protected:
  49. // Processes and route salient window messages for mouse handling,
  50. // size change and DPI. Delegates handling of these to member overloads that
  51. // inheriting classes can handle.
  52. virtual LRESULT MessageHandler(HWND window,
  53. UINT const message,
  54. WPARAM const wparam,
  55. LPARAM const lparam) noexcept;
  56. // Called when CreateAndShow is called, allowing subclass window-related
  57. // setup. Subclasses should return false if setup fails.
  58. virtual bool OnCreate();
  59. // Called when Destroy is called.
  60. virtual void OnDestroy();
  61. private:
  62. friend class WindowClassRegistrar;
  63. // OS callback called by message pump. Handles the WM_NCCREATE message which
  64. // is passed when the non-client area is being created and enables automatic
  65. // non-client DPI scaling so that the non-client area automatically
  66. // responsponds to changes in DPI. All other messages are handled by
  67. // MessageHandler.
  68. static LRESULT CALLBACK WndProc(HWND const window,
  69. UINT const message,
  70. WPARAM const wparam,
  71. LPARAM const lparam) noexcept;
  72. // Retrieves a class instance pointer for |window|
  73. static Win32Window *GetThisFromHandle(HWND const window) noexcept;
  74. // Dispatches link if any.
  75. // This method enables our app to be with a single instance too.
  76. bool SendAppLinkToInstance(const std::wstring &title);
  77. bool quit_on_close_ = false;
  78. // window handle for top level window.
  79. HWND window_handle_ = nullptr;
  80. // window handle for hosted content.
  81. HWND child_content_ = nullptr;
  82. };
  83. #endif // RUNNER_WIN32_WINDOW_H_