mirror of
				https://github.com/AxioDL/boo.git
				synced 2025-10-26 19:50:28 +00:00 
			
		
		
		
	IWindow: Use std::array where applicable
Allows for more flexible copying/manipulation within using code. While we're at it, we can make the interface of SWindowRect and SScrollData constexpr, given they only manipulate primitives.
This commit is contained in:
		
							parent
							
								
									4f4250baf7
								
							
						
					
					
						commit
						794a680797
					
				| @ -1,8 +1,8 @@ | |||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
|  | #include <array> | ||||||
| #include <memory> | #include <memory> | ||||||
| #include <cstring> |  | ||||||
| 
 | 
 | ||||||
| #include "boo/System.hpp" | #include "boo/System.hpp" | ||||||
| 
 | 
 | ||||||
| @ -17,36 +17,30 @@ struct IAudioVoiceEngine; | |||||||
| enum class EMouseButton { None = 0, Primary = 1, Secondary = 2, Middle = 3, Aux1 = 4, Aux2 = 5 }; | enum class EMouseButton { None = 0, Primary = 1, Secondary = 2, Middle = 3, Aux1 = 4, Aux2 = 5 }; | ||||||
| 
 | 
 | ||||||
| struct SWindowCoord { | struct SWindowCoord { | ||||||
|   int pixel[2]; |   std::array<int, 2> pixel; | ||||||
|   int virtualPixel[2]; |   std::array<int, 2> virtualPixel; | ||||||
|   float norm[2]; |   std::array<float, 2> norm; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct SWindowRect { | struct SWindowRect { | ||||||
|   int location[2]; |   std::array<int, 2> location{}; | ||||||
|   int size[2]; |   std::array<int, 2> size{}; | ||||||
| 
 | 
 | ||||||
|   SWindowRect() { std::memset(this, 0, sizeof(SWindowRect)); } |   constexpr SWindowRect() noexcept = default; | ||||||
|  |   constexpr SWindowRect(int x, int y, int w, int h) noexcept : location{x, y}, size{w, h} {} | ||||||
| 
 | 
 | ||||||
|   SWindowRect(int x, int y, int w, int h) { |   constexpr bool operator==(const SWindowRect& other) const noexcept { | ||||||
|     location[0] = x; |     return location[0] == other.location[0] && location[1] == other.location[1] && size[0] == other.size[0] && | ||||||
|     location[1] = y; |            size[1] == other.size[1]; | ||||||
|     size[0] = w; |  | ||||||
|     size[1] = h; |  | ||||||
|   } |   } | ||||||
|  |   constexpr bool operator!=(const SWindowRect& other) const noexcept { return !operator==(other); } | ||||||
| 
 | 
 | ||||||
|   bool operator!=(const SWindowRect& other) const { |   constexpr bool coordInRect(const SWindowCoord& coord) const noexcept { | ||||||
|     return location[0] != other.location[0] || location[1] != other.location[1] || size[0] != other.size[0] || |  | ||||||
|            size[1] != other.size[1]; |  | ||||||
|   } |  | ||||||
|   bool operator==(const SWindowRect& other) const { return !(*this != other); } |  | ||||||
| 
 |  | ||||||
|   bool coordInRect(const SWindowCoord& coord) const { |  | ||||||
|     return coord.pixel[0] >= location[0] && coord.pixel[0] < location[0] + size[0] && coord.pixel[1] >= location[1] && |     return coord.pixel[0] >= location[0] && coord.pixel[0] < location[0] + size[0] && coord.pixel[1] >= location[1] && | ||||||
|            coord.pixel[1] < location[1] + size[1]; |            coord.pixel[1] < location[1] + size[1]; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   SWindowRect intersect(const SWindowRect& other) const { |   constexpr SWindowRect intersect(const SWindowRect& other) const noexcept { | ||||||
|     if (location[0] < other.location[0] + other.size[0] && location[0] + size[0] > other.location[0] && |     if (location[0] < other.location[0] + other.size[0] && location[0] + size[0] > other.location[0] && | ||||||
|         location[1] < other.location[1] + other.size[1] && location[1] + size[1] > other.location[1]) { |         location[1] < other.location[1] + other.size[1] && location[1] + size[1] > other.location[1]) { | ||||||
|       SWindowRect ret; |       SWindowRect ret; | ||||||
| @ -61,15 +55,15 @@ struct SWindowRect { | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct STouchCoord { | struct STouchCoord { | ||||||
|   double coord[2]; |   std::array<double, 2> coord; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct SScrollDelta { | struct SScrollDelta { | ||||||
|   double delta[2] = {}; |   std::array<double, 2> delta{}; | ||||||
|   bool isFine = false;        /* Use system-scale fine-scroll (for scrollable-trackpads) */ |   bool isFine = false;        /* Use system-scale fine-scroll (for scrollable-trackpads) */ | ||||||
|   bool isAccelerated = false; /* System performs acceleration computation */ |   bool isAccelerated = false; /* System performs acceleration computation */ | ||||||
| 
 | 
 | ||||||
|   SScrollDelta operator+(const SScrollDelta& other) const { |   constexpr SScrollDelta operator+(const SScrollDelta& other) const noexcept { | ||||||
|     SScrollDelta ret; |     SScrollDelta ret; | ||||||
|     ret.delta[0] = delta[0] + other.delta[0]; |     ret.delta[0] = delta[0] + other.delta[0]; | ||||||
|     ret.delta[1] = delta[1] + other.delta[1]; |     ret.delta[1] = delta[1] + other.delta[1]; | ||||||
| @ -77,7 +71,7 @@ struct SScrollDelta { | |||||||
|     ret.isAccelerated = isAccelerated || other.isAccelerated; |     ret.isAccelerated = isAccelerated || other.isAccelerated; | ||||||
|     return ret; |     return ret; | ||||||
|   } |   } | ||||||
|   SScrollDelta operator-(const SScrollDelta& other) const { |   constexpr SScrollDelta operator-(const SScrollDelta& other) const noexcept { | ||||||
|     SScrollDelta ret; |     SScrollDelta ret; | ||||||
|     ret.delta[0] = delta[0] - other.delta[0]; |     ret.delta[0] = delta[0] - other.delta[0]; | ||||||
|     ret.delta[1] = delta[1] - other.delta[1]; |     ret.delta[1] = delta[1] - other.delta[1]; | ||||||
| @ -85,18 +79,15 @@ struct SScrollDelta { | |||||||
|     ret.isAccelerated = isAccelerated || other.isAccelerated; |     ret.isAccelerated = isAccelerated || other.isAccelerated; | ||||||
|     return ret; |     return ret; | ||||||
|   } |   } | ||||||
|   SScrollDelta& operator+=(const SScrollDelta& other) { |   constexpr SScrollDelta& operator+=(const SScrollDelta& other) noexcept { | ||||||
|     delta[0] += other.delta[0]; |     delta[0] += other.delta[0]; | ||||||
|     delta[1] += other.delta[1]; |     delta[1] += other.delta[1]; | ||||||
|     isFine |= other.isFine; |     isFine |= other.isFine; | ||||||
|     isAccelerated |= other.isAccelerated; |     isAccelerated |= other.isAccelerated; | ||||||
|     return *this; |     return *this; | ||||||
|   } |   } | ||||||
|   void zeroOut() { |   constexpr void zeroOut() noexcept { delta = {}; } | ||||||
|     delta[0] = 0.0; |   constexpr bool isZero() const noexcept { return delta[0] == 0.0 && delta[1] == 0.0; } | ||||||
|     delta[1] = 0.0; |  | ||||||
|   } |  | ||||||
|   bool isZero() const { return delta[0] == 0.0 && delta[1] == 0.0; } |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| enum class ESpecialKey { | enum class ESpecialKey { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user