aboutsummaryrefslogtreecommitdiff
path: root/src/win/gui/WindowClass.cpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
committercrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
commit7f15a1ff9a2007e119798053083a0a87d042990a (patch)
treecb35c01a7eaee867376d959b96c9bbd15df939e5 /src/win/gui/WindowClass.cpp
parent74956951ee663012df0c3fe4ebe29799cb2f7732 (diff)
parent7703063a5816b089483e78ccd74bb9902ccfbea8 (diff)
downloadcru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.gz
cru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.bz2
cru-7f15a1ff9a2007e119798053083a0a87d042990a.zip
Merge branch 'master' of https://github.com/crupest/CruUI
Diffstat (limited to 'src/win/gui/WindowClass.cpp')
-rw-r--r--src/win/gui/WindowClass.cpp28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/win/gui/WindowClass.cpp b/src/win/gui/WindowClass.cpp
new file mode 100644
index 00000000..a033d091
--- /dev/null
+++ b/src/win/gui/WindowClass.cpp
@@ -0,0 +1,28 @@
+#include "cru/win/gui/WindowClass.hpp"
+
+#include "cru/win/gui/Exception.hpp"
+
+namespace cru::platform::gui::win {
+WindowClass::WindowClass(std::wstring name, WNDPROC window_proc,
+ HINSTANCE h_instance)
+ : name_(std::move(name)) {
+ WNDCLASSEXW window_class;
+ window_class.cbSize = sizeof(WNDCLASSEXW);
+
+ window_class.style = CS_HREDRAW | CS_VREDRAW;
+ window_class.lpfnWndProc = window_proc;
+ window_class.cbClsExtra = 0;
+ window_class.cbWndExtra = 0;
+ window_class.hInstance = h_instance;
+ window_class.hIcon = LoadIcon(NULL, IDI_APPLICATION);
+ window_class.hCursor = LoadCursor(NULL, IDC_ARROW);
+ window_class.hbrBackground = GetSysColorBrush(COLOR_BTNFACE);
+ window_class.lpszMenuName = NULL;
+ window_class.lpszClassName = name_.c_str();
+ window_class.hIconSm = NULL;
+
+ atom_ = ::RegisterClassExW(&window_class);
+ if (atom_ == 0)
+ throw Win32Error(::GetLastError(), "Failed to create window class.");
+}
+} // namespace cru::platform::gui::win