reflexion 0.1.12 → 0.1.17

Sign up to get free protection for your applications and to get access to all the features.
Files changed (333) hide show
  1. checksums.yaml +5 -5
  2. data/.doc/ext/reflex/application.cpp +9 -5
  3. data/.doc/ext/reflex/capture_event.cpp +4 -9
  4. data/.doc/ext/reflex/contact_event.cpp +17 -13
  5. data/.doc/ext/reflex/draw_event.cpp +3 -8
  6. data/.doc/ext/reflex/ellipse_shape.cpp +51 -24
  7. data/.doc/ext/reflex/event.cpp +0 -4
  8. data/.doc/ext/reflex/filter.cpp +81 -0
  9. data/.doc/ext/reflex/focus_event.cpp +9 -13
  10. data/.doc/ext/reflex/frame_event.cpp +47 -14
  11. data/.doc/ext/reflex/image_view.cpp +1 -10
  12. data/.doc/ext/reflex/key_event.cpp +9 -14
  13. data/.doc/ext/reflex/line_shape.cpp +99 -0
  14. data/.doc/ext/reflex/motion_event.cpp +73 -0
  15. data/.doc/ext/reflex/native.cpp +18 -18
  16. data/.doc/ext/reflex/pointer_event.cpp +27 -25
  17. data/.doc/ext/reflex/polygon_shape.cpp +65 -0
  18. data/.doc/ext/reflex/rect_shape.cpp +102 -23
  19. data/.doc/ext/reflex/reflex.cpp +24 -3
  20. data/.doc/ext/reflex/scroll_event.cpp +8 -15
  21. data/.doc/ext/reflex/selector.cpp +43 -15
  22. data/.doc/ext/reflex/shape.cpp +211 -0
  23. data/.doc/ext/reflex/style.cpp +359 -185
  24. data/.doc/ext/reflex/style_length.cpp +163 -35
  25. data/.doc/ext/reflex/timer.cpp +101 -0
  26. data/.doc/ext/reflex/timer_event.cpp +123 -0
  27. data/.doc/ext/reflex/update_event.cpp +12 -8
  28. data/.doc/ext/reflex/view.cpp +548 -144
  29. data/.doc/ext/reflex/wheel_event.cpp +5 -28
  30. data/.doc/ext/reflex/window.cpp +7 -15
  31. data/LICENSE +21 -0
  32. data/README.md +1 -1
  33. data/Rakefile +14 -12
  34. data/VERSION +1 -1
  35. data/ext/reflex/application.cpp +10 -5
  36. data/ext/reflex/capture_event.cpp +4 -9
  37. data/ext/reflex/contact_event.cpp +18 -13
  38. data/ext/reflex/defs.h +5 -2
  39. data/ext/reflex/draw_event.cpp +3 -8
  40. data/ext/reflex/ellipse_shape.cpp +56 -25
  41. data/ext/reflex/event.cpp +0 -4
  42. data/ext/reflex/extconf.rb +1 -2
  43. data/ext/reflex/filter.cpp +86 -0
  44. data/ext/reflex/focus_event.cpp +11 -15
  45. data/ext/reflex/frame_event.cpp +52 -14
  46. data/ext/reflex/image_view.cpp +1 -10
  47. data/ext/reflex/key_event.cpp +9 -14
  48. data/ext/reflex/line_shape.cpp +104 -0
  49. data/ext/reflex/motion_event.cpp +77 -0
  50. data/ext/reflex/native.cpp +18 -18
  51. data/ext/reflex/pointer_event.cpp +27 -25
  52. data/ext/reflex/polygon_shape.cpp +68 -0
  53. data/ext/reflex/rect_shape.cpp +113 -24
  54. data/ext/reflex/reflex.cpp +24 -3
  55. data/ext/reflex/scroll_event.cpp +8 -15
  56. data/ext/reflex/selector.cpp +46 -16
  57. data/ext/reflex/selector.h +130 -0
  58. data/ext/reflex/shape.cpp +231 -0
  59. data/ext/reflex/style.cpp +363 -192
  60. data/ext/reflex/style_length.cpp +164 -37
  61. data/ext/reflex/timer.cpp +108 -0
  62. data/ext/reflex/timer_event.cpp +133 -0
  63. data/ext/reflex/update_event.cpp +13 -8
  64. data/ext/reflex/view.cpp +594 -150
  65. data/ext/reflex/wheel_event.cpp +5 -30
  66. data/ext/reflex/window.cpp +7 -15
  67. data/include/reflex.h +5 -4
  68. data/include/reflex/application.h +2 -0
  69. data/include/reflex/debug.h +22 -0
  70. data/include/reflex/defs.h +45 -2
  71. data/include/reflex/event.h +55 -11
  72. data/include/reflex/exception.h +17 -2
  73. data/include/reflex/filter.h +56 -0
  74. data/include/reflex/image_view.h +1 -1
  75. data/include/reflex/ruby.h +6 -4
  76. data/include/reflex/ruby/application.h +17 -9
  77. data/include/reflex/ruby/event.h +22 -0
  78. data/include/reflex/ruby/filter.h +69 -0
  79. data/include/reflex/ruby/reflex.h +1 -0
  80. data/include/reflex/ruby/selector.h +1 -1
  81. data/include/reflex/ruby/shape.h +140 -0
  82. data/include/reflex/ruby/style.h +1 -1
  83. data/include/reflex/ruby/timer.h +69 -0
  84. data/include/reflex/ruby/view.h +43 -76
  85. data/include/reflex/ruby/window.h +17 -32
  86. data/include/reflex/selector.h +54 -2
  87. data/include/reflex/shape.h +211 -0
  88. data/include/reflex/style.h +136 -76
  89. data/include/reflex/timer.h +73 -0
  90. data/include/reflex/view.h +181 -59
  91. data/include/reflex/window.h +4 -3
  92. data/lib/reflex.rb +13 -6
  93. data/lib/reflex/application.rb +6 -3
  94. data/lib/reflex/button.rb +2 -2
  95. data/lib/reflex/{texture.rb → camera.rb} +2 -2
  96. data/lib/reflex/capture_event.rb +7 -6
  97. data/lib/reflex/contact_event.rb +10 -12
  98. data/lib/reflex/draw_event.rb +6 -1
  99. data/lib/reflex/ellipse_shape.rb +27 -0
  100. data/lib/reflex/filter.rb +18 -0
  101. data/lib/reflex/fixture.rb +4 -0
  102. data/lib/reflex/focus_event.rb +10 -12
  103. data/lib/reflex/frame_event.rb +1 -1
  104. data/lib/reflex/helper.rb +17 -29
  105. data/lib/reflex/key_event.rb +13 -11
  106. data/lib/reflex/line_shape.rb +18 -0
  107. data/lib/reflex/matrix.rb +13 -0
  108. data/lib/reflex/module.rb +4 -19
  109. data/lib/reflex/pointer_event.rb +28 -35
  110. data/lib/reflex/polygon.rb +14 -0
  111. data/lib/reflex/polygon_shape.rb +23 -0
  112. data/lib/reflex/polyline.rb +13 -0
  113. data/lib/reflex/rect_shape.rb +20 -0
  114. data/lib/reflex/reflex.rb +1 -3
  115. data/lib/reflex/scroll_event.rb +1 -1
  116. data/lib/reflex/selector.rb +2 -2
  117. data/lib/reflex/shape.rb +62 -0
  118. data/lib/reflex/style.rb +78 -11
  119. data/lib/reflex/style_length.rb +0 -11
  120. data/lib/reflex/text_view.rb +7 -24
  121. data/lib/reflex/timer.rb +30 -0
  122. data/lib/reflex/timer_event.rb +29 -0
  123. data/lib/reflex/update_event.rb +1 -1
  124. data/lib/reflex/view.rb +127 -32
  125. data/lib/reflex/wheel_event.rb +9 -1
  126. data/lib/reflex/window.rb +29 -9
  127. data/lib/reflexion.rb +23 -7
  128. data/reflex.gemspec +8 -10
  129. data/samples/bats.rb +4 -4
  130. data/samples/camera.rb +45 -0
  131. data/samples/fans.rb +1 -1
  132. data/samples/fps.rb +5 -3
  133. data/samples/hello.rb +4 -6
  134. data/samples/image.rb +5 -4
  135. data/samples/ios/hello/hello.xcodeproj/project.pbxproj +0 -2
  136. data/samples/layout.rb +16 -7
  137. data/samples/model.rb +10 -7
  138. data/samples/physics.rb +22 -20
  139. data/samples/reflexion/breakout.rb +4 -5
  140. data/samples/reflexion/hello.rb +2 -2
  141. data/samples/reflexion/jump_action.rb +191 -0
  142. data/samples/reflexion/noise.rb +23 -0
  143. data/samples/reflexion/paint.rb +7 -6
  144. data/samples/reflexion/physics.rb +15 -8
  145. data/samples/reflexion/pulse.rb +24 -10
  146. data/samples/shader.rb +8 -6
  147. data/samples/shapes.rb +79 -14
  148. data/samples/tree.rb +9 -10
  149. data/samples/views.rb +3 -3
  150. data/samples/visuals.rb +2 -5
  151. data/src/body.cpp +146 -345
  152. data/src/body.h +91 -0
  153. data/src/event.cpp +65 -15
  154. data/src/exception.cpp +13 -3
  155. data/src/filter.cpp +76 -0
  156. data/src/fixture.cpp +164 -39
  157. data/src/fixture.h +85 -0
  158. data/src/image_view.cpp +4 -4
  159. data/src/ios/app_delegate.h +5 -10
  160. data/src/ios/app_delegate.mm +79 -41
  161. data/src/ios/application.h +32 -0
  162. data/src/ios/application.mm +35 -25
  163. data/src/ios/event.mm +8 -4
  164. data/src/ios/reflex.mm +0 -7
  165. data/src/ios/view_controller.h +37 -0
  166. data/src/ios/view_controller.mm +424 -0
  167. data/src/ios/window.h +40 -0
  168. data/src/ios/window.mm +59 -250
  169. data/src/osx/app_delegate.h +5 -10
  170. data/src/osx/app_delegate.mm +52 -55
  171. data/src/osx/application.h +32 -0
  172. data/src/osx/application.mm +44 -39
  173. data/src/osx/native_window.h +0 -15
  174. data/src/osx/native_window.mm +127 -127
  175. data/src/osx/opengl_view.h +0 -2
  176. data/src/osx/opengl_view.mm +12 -3
  177. data/src/osx/reflex.mm +0 -9
  178. data/src/osx/window.h +42 -0
  179. data/src/osx/window.mm +45 -252
  180. data/src/selector.cpp +232 -7
  181. data/src/selector.h +52 -0
  182. data/src/shape.cpp +1191 -0
  183. data/src/shape.h +61 -0
  184. data/src/style.cpp +573 -376
  185. data/src/style.h +39 -0
  186. data/src/timer.cpp +288 -0
  187. data/src/timer.h +55 -0
  188. data/src/view.cpp +1624 -984
  189. data/src/view.h +56 -0
  190. data/src/win32/window.cpp +3 -4
  191. data/src/window.cpp +302 -20
  192. data/src/window.h +94 -0
  193. data/src/world.cpp +112 -111
  194. data/src/world.h +34 -53
  195. data/task/box2d.rake +31 -10
  196. data/test/test_capture_event.rb +8 -6
  197. data/test/test_pointer_event.rb +130 -0
  198. data/test/test_selector.rb +1 -1
  199. data/test/test_shape.rb +71 -0
  200. data/test/test_style.rb +77 -11
  201. data/test/test_style_length.rb +42 -13
  202. data/test/test_view.rb +138 -14
  203. metadata +115 -213
  204. data/.doc/ext/reflex/arc_shape.cpp +0 -89
  205. data/.doc/ext/reflex/body.cpp +0 -299
  206. data/.doc/ext/reflex/fixture.cpp +0 -101
  207. data/.doc/ext/reflex/shape_view.cpp +0 -153
  208. data/ext/reflex/arc_shape.cpp +0 -94
  209. data/ext/reflex/body.cpp +0 -328
  210. data/ext/reflex/fixture.cpp +0 -108
  211. data/ext/reflex/shape_view.cpp +0 -161
  212. data/include/reflex/bitmap.h +0 -20
  213. data/include/reflex/body.h +0 -128
  214. data/include/reflex/bounds.h +0 -20
  215. data/include/reflex/color.h +0 -20
  216. data/include/reflex/color_space.h +0 -20
  217. data/include/reflex/fixture.h +0 -117
  218. data/include/reflex/font.h +0 -20
  219. data/include/reflex/image.h +0 -20
  220. data/include/reflex/matrix.h +0 -20
  221. data/include/reflex/painter.h +0 -20
  222. data/include/reflex/point.h +0 -24
  223. data/include/reflex/ruby/body.h +0 -41
  224. data/include/reflex/ruby/fixture.h +0 -41
  225. data/include/reflex/ruby/shape_view.h +0 -96
  226. data/include/reflex/shader.h +0 -20
  227. data/include/reflex/shape_view.h +0 -146
  228. data/include/reflex/texture.h +0 -20
  229. data/lib/reflex/body.rb +0 -22
  230. data/lib/reflex/flags.rb +0 -18
  231. data/lib/reflex/shape_view.rb +0 -25
  232. data/src/ios/application_data.h +0 -45
  233. data/src/ios/native_window.h +0 -39
  234. data/src/ios/native_window.mm +0 -224
  235. data/src/ios/opengl_view.h +0 -13
  236. data/src/ios/opengl_view.mm +0 -139
  237. data/src/ios/window_data.h +0 -75
  238. data/src/osx/application_data.h +0 -45
  239. data/src/osx/window_data.h +0 -75
  240. data/src/physics/Box2D/Box2D.h +0 -68
  241. data/src/physics/Box2D/Collision/Shapes/b2ChainShape.cpp +0 -193
  242. data/src/physics/Box2D/Collision/Shapes/b2ChainShape.h +0 -105
  243. data/src/physics/Box2D/Collision/Shapes/b2CircleShape.cpp +0 -99
  244. data/src/physics/Box2D/Collision/Shapes/b2CircleShape.h +0 -91
  245. data/src/physics/Box2D/Collision/Shapes/b2EdgeShape.cpp +0 -138
  246. data/src/physics/Box2D/Collision/Shapes/b2EdgeShape.h +0 -74
  247. data/src/physics/Box2D/Collision/Shapes/b2PolygonShape.cpp +0 -467
  248. data/src/physics/Box2D/Collision/Shapes/b2PolygonShape.h +0 -101
  249. data/src/physics/Box2D/Collision/Shapes/b2Shape.h +0 -101
  250. data/src/physics/Box2D/Collision/b2BroadPhase.cpp +0 -119
  251. data/src/physics/Box2D/Collision/b2BroadPhase.h +0 -257
  252. data/src/physics/Box2D/Collision/b2CollideCircle.cpp +0 -154
  253. data/src/physics/Box2D/Collision/b2CollideEdge.cpp +0 -698
  254. data/src/physics/Box2D/Collision/b2CollidePolygon.cpp +0 -239
  255. data/src/physics/Box2D/Collision/b2Collision.cpp +0 -252
  256. data/src/physics/Box2D/Collision/b2Collision.h +0 -277
  257. data/src/physics/Box2D/Collision/b2Distance.cpp +0 -603
  258. data/src/physics/Box2D/Collision/b2Distance.h +0 -141
  259. data/src/physics/Box2D/Collision/b2DynamicTree.cpp +0 -778
  260. data/src/physics/Box2D/Collision/b2DynamicTree.h +0 -289
  261. data/src/physics/Box2D/Collision/b2TimeOfImpact.cpp +0 -486
  262. data/src/physics/Box2D/Collision/b2TimeOfImpact.h +0 -58
  263. data/src/physics/Box2D/Common/b2BlockAllocator.cpp +0 -215
  264. data/src/physics/Box2D/Common/b2BlockAllocator.h +0 -62
  265. data/src/physics/Box2D/Common/b2Draw.cpp +0 -44
  266. data/src/physics/Box2D/Common/b2Draw.h +0 -86
  267. data/src/physics/Box2D/Common/b2GrowableStack.h +0 -85
  268. data/src/physics/Box2D/Common/b2Math.cpp +0 -94
  269. data/src/physics/Box2D/Common/b2Math.h +0 -720
  270. data/src/physics/Box2D/Common/b2Settings.cpp +0 -44
  271. data/src/physics/Box2D/Common/b2Settings.h +0 -151
  272. data/src/physics/Box2D/Common/b2StackAllocator.cpp +0 -83
  273. data/src/physics/Box2D/Common/b2StackAllocator.h +0 -60
  274. data/src/physics/Box2D/Common/b2Timer.cpp +0 -101
  275. data/src/physics/Box2D/Common/b2Timer.h +0 -50
  276. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndCircleContact.cpp +0 -53
  277. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndCircleContact.h +0 -39
  278. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndPolygonContact.cpp +0 -53
  279. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndPolygonContact.h +0 -39
  280. data/src/physics/Box2D/Dynamics/Contacts/b2CircleContact.cpp +0 -52
  281. data/src/physics/Box2D/Dynamics/Contacts/b2CircleContact.h +0 -39
  282. data/src/physics/Box2D/Dynamics/Contacts/b2Contact.cpp +0 -247
  283. data/src/physics/Box2D/Dynamics/Contacts/b2Contact.h +0 -349
  284. data/src/physics/Box2D/Dynamics/Contacts/b2ContactSolver.cpp +0 -838
  285. data/src/physics/Box2D/Dynamics/Contacts/b2ContactSolver.h +0 -95
  286. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndCircleContact.cpp +0 -49
  287. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndCircleContact.h +0 -39
  288. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndPolygonContact.cpp +0 -49
  289. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndPolygonContact.h +0 -39
  290. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonAndCircleContact.cpp +0 -49
  291. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonAndCircleContact.h +0 -38
  292. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonContact.cpp +0 -52
  293. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonContact.h +0 -39
  294. data/src/physics/Box2D/Dynamics/Joints/b2DistanceJoint.cpp +0 -260
  295. data/src/physics/Box2D/Dynamics/Joints/b2DistanceJoint.h +0 -169
  296. data/src/physics/Box2D/Dynamics/Joints/b2FrictionJoint.cpp +0 -251
  297. data/src/physics/Box2D/Dynamics/Joints/b2FrictionJoint.h +0 -119
  298. data/src/physics/Box2D/Dynamics/Joints/b2GearJoint.cpp +0 -419
  299. data/src/physics/Box2D/Dynamics/Joints/b2GearJoint.h +0 -125
  300. data/src/physics/Box2D/Dynamics/Joints/b2Joint.cpp +0 -211
  301. data/src/physics/Box2D/Dynamics/Joints/b2Joint.h +0 -226
  302. data/src/physics/Box2D/Dynamics/Joints/b2MotorJoint.cpp +0 -304
  303. data/src/physics/Box2D/Dynamics/Joints/b2MotorJoint.h +0 -133
  304. data/src/physics/Box2D/Dynamics/Joints/b2MouseJoint.cpp +0 -222
  305. data/src/physics/Box2D/Dynamics/Joints/b2MouseJoint.h +0 -129
  306. data/src/physics/Box2D/Dynamics/Joints/b2PrismaticJoint.cpp +0 -629
  307. data/src/physics/Box2D/Dynamics/Joints/b2PrismaticJoint.h +0 -196
  308. data/src/physics/Box2D/Dynamics/Joints/b2PulleyJoint.cpp +0 -348
  309. data/src/physics/Box2D/Dynamics/Joints/b2PulleyJoint.h +0 -152
  310. data/src/physics/Box2D/Dynamics/Joints/b2RevoluteJoint.cpp +0 -502
  311. data/src/physics/Box2D/Dynamics/Joints/b2RevoluteJoint.h +0 -204
  312. data/src/physics/Box2D/Dynamics/Joints/b2RopeJoint.cpp +0 -241
  313. data/src/physics/Box2D/Dynamics/Joints/b2RopeJoint.h +0 -114
  314. data/src/physics/Box2D/Dynamics/Joints/b2WeldJoint.cpp +0 -344
  315. data/src/physics/Box2D/Dynamics/Joints/b2WeldJoint.h +0 -126
  316. data/src/physics/Box2D/Dynamics/Joints/b2WheelJoint.cpp +0 -419
  317. data/src/physics/Box2D/Dynamics/Joints/b2WheelJoint.h +0 -210
  318. data/src/physics/Box2D/Dynamics/b2Body.cpp +0 -549
  319. data/src/physics/Box2D/Dynamics/b2Body.h +0 -860
  320. data/src/physics/Box2D/Dynamics/b2ContactManager.cpp +0 -296
  321. data/src/physics/Box2D/Dynamics/b2ContactManager.h +0 -52
  322. data/src/physics/Box2D/Dynamics/b2Fixture.cpp +0 -303
  323. data/src/physics/Box2D/Dynamics/b2Fixture.h +0 -345
  324. data/src/physics/Box2D/Dynamics/b2Island.cpp +0 -539
  325. data/src/physics/Box2D/Dynamics/b2Island.h +0 -93
  326. data/src/physics/Box2D/Dynamics/b2TimeStep.h +0 -70
  327. data/src/physics/Box2D/Dynamics/b2World.cpp +0 -1339
  328. data/src/physics/Box2D/Dynamics/b2World.h +0 -354
  329. data/src/physics/Box2D/Dynamics/b2WorldCallbacks.cpp +0 -36
  330. data/src/physics/Box2D/Dynamics/b2WorldCallbacks.h +0 -155
  331. data/src/physics/Box2D/Rope/b2Rope.cpp +0 -259
  332. data/src/physics/Box2D/Rope/b2Rope.h +0 -115
  333. data/src/shape_view.cpp +0 -306
@@ -4,8 +4,6 @@
4
4
 
5
5
  @interface OpenGLView : NSOpenGLView
6
6
 
7
- {}
8
-
9
7
  - (id) initWithFrame: (NSRect) frame;
10
8
 
11
9
  - (id) initWithFrame: (NSRect) frame antiAlias: (int) nsample;
@@ -63,11 +63,12 @@ make_pixelformat (int antialias_nsample = 0)
63
63
  self = [super initWithFrame: frame pixelFormat: make_pixelformat(nsample)];
64
64
  if (!self) return nil;
65
65
 
66
+ [self setWantsBestResolutionOpenGLSurface: YES];
66
67
  [self activateContext];
67
68
 
68
- GLint swapinterval = 1;
69
+ GLint swapInterval = 1;
69
70
  [[self openGLContext]
70
- setValues: &swapinterval
71
+ setValues: &swapInterval
71
72
  forParameter: NSOpenGLCPSwapInterval];
72
73
 
73
74
  #ifdef TRANSPARENT_BACKGROUND
@@ -130,7 +131,7 @@ make_pixelformat (int antialias_nsample = 0)
130
131
 
131
132
  - (void) keyDown: (NSEvent*) event
132
133
  {
133
- [self interpretKeyEvents: [NSArray arrayWithObject: event]];
134
+ //[self interpretKeyEvents: [NSArray arrayWithObject: event]];
134
135
 
135
136
  NativeWindow* win = (NativeWindow*) [self window];
136
137
  if (!win) return;
@@ -146,6 +147,14 @@ make_pixelformat (int antialias_nsample = 0)
146
147
  [win keyUp: event];
147
148
  }
148
149
 
150
+ - (void) flagsChanged: (NSEvent*) event
151
+ {
152
+ NativeWindow* win = (NativeWindow*) [self window];
153
+ if (!win) return;
154
+
155
+ [win flagsChanged: event];
156
+ }
157
+
149
158
  - (void) mouseDown: (NSEvent*) event
150
159
  {
151
160
  NativeWindow* win = (NativeWindow*) [self window];
@@ -4,7 +4,6 @@
4
4
 
5
5
  #import <Cocoa/Cocoa.h>
6
6
  #include "reflex/exception.h"
7
- #import "app_delegate.h"
8
7
 
9
8
 
10
9
  namespace Reflex
@@ -19,12 +18,6 @@ namespace Reflex
19
18
  }// global
20
19
 
21
20
 
22
- bool
23
- initialized ()
24
- {
25
- return global::pool;
26
- }
27
-
28
21
  void
29
22
  init ()
30
23
  {
@@ -32,8 +25,6 @@ namespace Reflex
32
25
  reflex_error(__FILE__, __LINE__, "already initialized.");
33
26
 
34
27
  global::pool = [[NSAutoreleasePool alloc] init];
35
-
36
- [[NSApplication sharedApplication] setDelegate: [[[AppDelegate alloc] init] autorelease]];
37
28
  }
38
29
 
39
30
  void
@@ -0,0 +1,42 @@
1
+ // -*- c++ -*-
2
+ #pragma once
3
+ #ifndef __REFLEX_SRC_OSX_WINDOW_H__
4
+ #define __REFLEX_SRC_OSX_WINDOW_H__
5
+
6
+
7
+ #include "../window.h"
8
+
9
+
10
+ @class NativeWindow;
11
+
12
+
13
+ namespace Reflex
14
+ {
15
+
16
+
17
+ struct WindowData : public Window::Data
18
+ {
19
+
20
+ NativeWindow* native;
21
+
22
+ mutable String title_tmp;
23
+
24
+ WindowData ();
25
+
26
+ bool is_valid () const
27
+ {
28
+ return native;
29
+ }
30
+
31
+ };// WindowData
32
+
33
+
34
+ WindowData& Window_get_data (Window* window);
35
+
36
+ const WindowData& Window_get_data (const Window* window);
37
+
38
+
39
+ }// Reflex
40
+
41
+
42
+ #endif//EOH
@@ -1,217 +1,110 @@
1
1
  // -*- objc -*-
2
- #include "reflex/window.h"
2
+ #include "window.h"
3
3
 
4
4
 
5
5
  #import <Cocoa/Cocoa.h>
6
- #include "reflex/event.h"
7
6
  #include "reflex/exception.h"
8
- #include "window_data.h"
9
7
  #import "native_window.h"
10
8
 
11
9
 
12
- namespace Reflex
13
- {
14
-
15
-
16
- void set_window (View* view, Window* window);
17
-
18
- void call_key_event (View* v, const KeyEvent& e);
19
-
20
- void call_pointer_event (View* v, const PointerEvent& e);
21
-
22
- void call_wheel_event (View* v, const WheelEvent& e);
23
-
24
-
25
- void
26
- set_focus (Window* window, View* view)
27
- {
28
- if (!window || !view)
29
- argument_error(__FILE__, __LINE__);
30
-
31
- View* current = window->self->focus.get();
32
- if (current == view) return;
10
+ @interface NativeWindow (Bind)
11
+ - (void) bind: (Reflex::Window*) window;
12
+ @end
33
13
 
34
- window->self->focus.reset(view);
35
14
 
36
- FocusEvent e(FocusEvent::BLUR, view, current);
37
-
38
- if (current)
39
- {
40
- current->on_blur(&e);
41
- current->redraw();
42
- }
15
+ namespace Reflex
16
+ {
43
17
 
44
- if (view)
45
- {
46
- e.type = FocusEvent::FOCUS;
47
- view->on_focus(&e);
48
- view->redraw();
49
- }
50
- }
51
18
 
52
- void
53
- register_capture (View* view)
19
+ WindowData&
20
+ Window_get_data (Window* window)
54
21
  {
55
- if (!view)
56
- argument_error(__FILE__, __LINE__);
57
-
58
- const Window* window = view->window();
59
22
  if (!window)
60
- invalid_state_error(__FILE__, __LINE__, "this view does not belong to any Window.");
61
-
62
- window->self->capturing_views[view] = true;
63
- }
64
-
65
- void
66
- unregister_capture (View* view)
67
- {
68
- if (!view)
69
23
  argument_error(__FILE__, __LINE__);
70
24
 
71
- const Window* window = view->window();
72
- if (!window) return;
73
-
74
- CapturingViews::iterator it = window->self->capturing_views.find(view);
75
- if (it == window->self->capturing_views.end()) return;
76
-
77
- it->second = false;
25
+ return (WindowData&) *window->self;
78
26
  }
79
27
 
80
- void
81
- cleanup_capturing_views (Window* window)
28
+ const WindowData&
29
+ Window_get_data (const Window* window)
82
30
  {
83
- CapturingViews::iterator end = window->self->capturing_views.end();
84
- for (CapturingViews::iterator it = window->self->capturing_views.begin(); it != end;)
85
- {
86
- CapturingViews::iterator t = it++;
87
- if (!t->second) window->self->capturing_views.erase(t);
88
- }
31
+ return Window_get_data(const_cast<Window*>(window));
89
32
  }
90
33
 
91
-
92
- Window::Window ()
34
+ static NativeWindow*
35
+ get_native (const Window* window)
93
36
  {
94
- [[[NativeWindow alloc] init] bind: this];
95
-
96
- set_window(self->root.get(), this);
37
+ NativeWindow* p = Window_get_data(const_cast<Window*>(window)).native;
38
+ if (!p)
39
+ invalid_state_error(__FILE__, __LINE__);
97
40
 
98
- self->painter.canvas(0, 0, 1, 1);
41
+ return p;
99
42
  }
100
43
 
101
- Window::~Window ()
102
- {
103
- //close();
104
44
 
105
- set_window(self->root.get(), NULL);
45
+ Window::Data*
46
+ Window_create_data ()
47
+ {
48
+ return new WindowData();
106
49
  }
107
50
 
108
51
  void
109
- Window::show ()
52
+ Window_initialize (Window* window)
110
53
  {
111
- if (!*this)
112
- invalid_state_error(__FILE__, __LINE__);
113
-
114
- int new_count = self->hide_count - 1;
115
- if (new_count == 0)
116
- {
117
- Event e;
118
- on_show(&e);
119
- if (e.is_blocked()) return;
120
-
121
- [self->native makeKeyAndOrderFront: nil];
122
- }
123
-
124
- self->hide_count = new_count;
54
+ [[[NativeWindow alloc] init] bind: window];
125
55
  }
126
56
 
127
57
  void
128
- Window::hide ()
58
+ Window_show (Window* window)
129
59
  {
130
- if (!*this)
131
- invalid_state_error(__FILE__, __LINE__);
132
-
133
- int new_count = self->hide_count + 1;
134
- if (new_count == 1)
135
- {
136
- Event e;
137
- on_hide(&e);
138
- if (e.is_blocked()) return;
139
-
140
- [self->native orderOut: self->native];
141
- }
142
-
143
- self->hide_count = new_count;
60
+ [get_native(window) makeKeyAndOrderFront: nil];
144
61
  }
145
62
 
146
63
  void
147
- Window::close ()
64
+ Window_hide (Window* window)
148
65
  {
149
- if (!*this)
150
- invalid_state_error(__FILE__, __LINE__);
151
-
152
- Event e;
153
- on_close(&e);
154
- if (e.is_blocked()) return;
155
-
156
- [self->native close];
66
+ NativeWindow* native = get_native(window);
67
+ [native orderOut: native];
157
68
  }
158
69
 
159
70
  void
160
- Window::redraw ()
71
+ Window_close (Window* window)
161
72
  {
162
- if (!*this)
163
- invalid_state_error(__FILE__, __LINE__);
164
-
165
- self->redraw = true;
73
+ [get_native(window) close];
166
74
  }
167
75
 
168
76
  void
169
- Window::set_title (const char* title)
77
+ Window_set_title (Window* window, const char* title)
170
78
  {
171
79
  if (!title)
172
80
  argument_error(__FILE__, __LINE__);
173
81
 
174
- if (!*this)
175
- invalid_state_error(__FILE__, __LINE__);
176
-
177
- [self->native setTitle: [NSString stringWithUTF8String: title]];
82
+ [get_native(window) setTitle: [NSString stringWithUTF8String: title]];
178
83
  }
179
84
 
180
85
  const char*
181
- Window::title () const
86
+ Window_get_title (const Window& window)
182
87
  {
183
- if (!*this)
184
- invalid_state_error(__FILE__, __LINE__);
88
+ const WindowData& data = Window_get_data(&window);
185
89
 
186
- NSString* s = [self->native title];
187
- self->title_tmp = s ? [s UTF8String] : "";
188
- return self->title_tmp.c_str();
90
+ NSString* s = [get_native(&window) title];
91
+ data.title_tmp = s ? [s UTF8String] : "";
92
+ return data.title_tmp.c_str();
189
93
  }
190
94
 
191
95
  void
192
- Window::set_frame (coord x, coord y, coord width, coord height)
96
+ Window_set_frame (Window* window, coord x, coord y, coord width, coord height)
193
97
  {
194
- if (!*this)
195
- invalid_state_error(__FILE__, __LINE__);
196
-
197
98
  NSRect frame =
198
99
  [NativeWindow frameRectForContentRect: NSMakeRect(x, y, width, height)];
199
- [self->native setFrame: frame display: NO animate: NO];
200
- }
201
-
202
- void
203
- Window::set_frame (const Bounds& bounds)
204
- {
205
- set_frame(bounds.x, bounds.y, bounds.width, bounds.height);
100
+ [get_native(window) setFrame: frame display: NO animate: NO];
206
101
  }
207
102
 
208
103
  Bounds
209
- Window::frame () const
104
+ Window_get_frame (const Window& window)
210
105
  {
211
- if (!*this)
212
- invalid_state_error(__FILE__, __LINE__);
213
-
214
- NSRect rect = [self->native contentRectForFrameRect: [self->native frame]];
106
+ NativeWindow* native = get_native(&window);
107
+ NSRect rect = [native contentRectForFrameRect: [native frame]];
215
108
  return Bounds(
216
109
  rect.origin.x,
217
110
  rect.origin.y,
@@ -219,110 +112,10 @@ namespace Reflex
219
112
  rect.size.height);
220
113
  }
221
114
 
222
- bool
223
- Window::hidden () const
224
- {
225
- if (!*this)
226
- invalid_state_error(__FILE__, __LINE__);
227
-
228
- return self->hide_count > 0;
229
- }
230
-
231
- View*
232
- Window::root ()
233
- {
234
- if (!*this)
235
- invalid_state_error(__FILE__, __LINE__);
236
-
237
- return self->root.get();
238
- }
239
-
240
- View*
241
- Window::focus ()
242
- {
243
- if (!*this)
244
- invalid_state_error(__FILE__, __LINE__);
245
-
246
- return self->focus.get();
247
- }
248
-
249
- Painter*
250
- Window::painter ()
251
- {
252
- if (!*this)
253
- invalid_state_error(__FILE__, __LINE__);
254
-
255
- return &self->painter;
256
- }
257
-
258
- void
259
- Window::on_key (KeyEvent* e)
260
- {
261
- if (!e)
262
- argument_error(__FILE__, __LINE__);
263
-
264
- switch (e->type)
265
- {
266
- case KeyEvent::DOWN: on_key_down(e); break;
267
- case KeyEvent::UP: on_key_up(e); break;
268
- case KeyEvent::NONE: break;
269
- }
270
-
271
- CapturingViews::iterator end = self->capturing_views.end();
272
- for (CapturingViews::iterator it = self->capturing_views.begin(); it != end; ++it)
273
- {
274
- KeyEvent event = *e;
275
- event.capture = true;
276
- call_key_event(const_cast<View*>(it->first.get()), event);
277
- }
278
-
279
- if (self->focus)
280
- call_key_event(self->focus.get(), *e);
281
-
282
- cleanup_capturing_views(this);
283
- }
284
-
285
- void
286
- Window::on_pointer (PointerEvent* e)
287
- {
288
- if (!e)
289
- argument_error(__FILE__, __LINE__);
290
-
291
- switch (e->type)
292
- {
293
- case PointerEvent::DOWN: on_pointer_down(e); break;
294
- case PointerEvent::UP: on_pointer_up(e); break;
295
- case PointerEvent::MOVE: on_pointer_move(e); break;
296
- case PointerEvent::NONE: break;
297
- }
298
-
299
- CapturingViews::iterator end = self->capturing_views.end();
300
- for (CapturingViews::iterator it = self->capturing_views.begin(); it != end; ++it)
301
- {
302
- PointerEvent event = *e;
303
- event.capture = true;
304
- for (size_t i = 0; i < event.size; ++i)
305
- event[i] = it->first.get()->from_window(event[i]);
306
- call_pointer_event(const_cast<View*>(it->first.get()), event);
307
- }
308
-
309
- call_pointer_event(root(), *e);
310
-
311
- cleanup_capturing_views(this);
312
- }
313
-
314
- void
315
- Window::on_wheel (WheelEvent* e)
316
- {
317
- if (!e)
318
- argument_error(__FILE__, __LINE__);
319
-
320
- call_wheel_event(root(), *e);
321
- }
322
115
 
323
- Window::operator bool () const
116
+ WindowData::WindowData ()
324
117
  {
325
- return self && *self;
118
+ native = nil;
326
119
  }
327
120
 
328
121