reflexion 0.1.12 → 0.1.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (329) hide show
  1. checksums.yaml +5 -5
  2. data/.doc/ext/reflex/application.cpp +9 -5
  3. data/.doc/ext/reflex/capture_event.cpp +0 -4
  4. data/.doc/ext/reflex/contact_event.cpp +17 -10
  5. data/.doc/ext/reflex/draw_event.cpp +1 -5
  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 +40 -6
  11. data/.doc/ext/reflex/image_view.cpp +1 -10
  12. data/.doc/ext/reflex/key_event.cpp +2 -6
  13. data/.doc/ext/reflex/line_shape.cpp +99 -0
  14. data/.doc/ext/reflex/motion_event.cpp +75 -0
  15. data/.doc/ext/reflex/native.cpp +18 -18
  16. data/.doc/ext/reflex/pointer_event.cpp +5 -11
  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 +21 -2
  20. data/.doc/ext/reflex/scroll_event.cpp +0 -6
  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 +11 -6
  28. data/.doc/ext/reflex/view.cpp +548 -144
  29. data/.doc/ext/reflex/wheel_event.cpp +0 -22
  30. data/.doc/ext/reflex/window.cpp +7 -15
  31. data/README.md +1 -1
  32. data/Rakefile +14 -12
  33. data/VERSION +1 -1
  34. data/ext/reflex/application.cpp +10 -5
  35. data/ext/reflex/capture_event.cpp +1 -5
  36. data/ext/reflex/contact_event.cpp +19 -11
  37. data/ext/reflex/defs.h +5 -2
  38. data/ext/reflex/draw_event.cpp +2 -6
  39. data/ext/reflex/ellipse_shape.cpp +56 -25
  40. data/ext/reflex/event.cpp +0 -4
  41. data/ext/reflex/extconf.rb +1 -2
  42. data/ext/reflex/filter.cpp +86 -0
  43. data/ext/reflex/focus_event.cpp +11 -15
  44. data/ext/reflex/frame_event.cpp +46 -7
  45. data/ext/reflex/image_view.cpp +1 -10
  46. data/ext/reflex/key_event.cpp +3 -7
  47. data/ext/reflex/line_shape.cpp +104 -0
  48. data/ext/reflex/motion_event.cpp +79 -0
  49. data/ext/reflex/native.cpp +18 -18
  50. data/ext/reflex/pointer_event.cpp +6 -12
  51. data/ext/reflex/polygon_shape.cpp +68 -0
  52. data/ext/reflex/rect_shape.cpp +113 -24
  53. data/ext/reflex/reflex.cpp +21 -2
  54. data/ext/reflex/scroll_event.cpp +1 -7
  55. data/ext/reflex/selector.cpp +46 -16
  56. data/ext/reflex/selector.h +130 -0
  57. data/ext/reflex/shape.cpp +231 -0
  58. data/ext/reflex/style.cpp +363 -192
  59. data/ext/reflex/style_length.cpp +164 -37
  60. data/ext/reflex/timer.cpp +108 -0
  61. data/ext/reflex/timer_event.cpp +133 -0
  62. data/ext/reflex/update_event.cpp +13 -7
  63. data/ext/reflex/view.cpp +594 -150
  64. data/ext/reflex/wheel_event.cpp +1 -25
  65. data/ext/reflex/window.cpp +7 -15
  66. data/include/reflex/application.h +2 -0
  67. data/include/reflex/debug.h +22 -0
  68. data/include/reflex/defs.h +45 -0
  69. data/include/reflex/event.h +60 -16
  70. data/include/reflex/exception.h +9 -0
  71. data/include/reflex/filter.h +56 -0
  72. data/include/reflex/image_view.h +1 -1
  73. data/include/reflex/ruby/application.h +17 -9
  74. data/include/reflex/ruby/event.h +22 -0
  75. data/include/reflex/ruby/filter.h +69 -0
  76. data/include/reflex/ruby/selector.h +1 -1
  77. data/include/reflex/ruby/shape.h +140 -0
  78. data/include/reflex/ruby/style.h +1 -1
  79. data/include/reflex/ruby/timer.h +69 -0
  80. data/include/reflex/ruby/view.h +43 -76
  81. data/include/reflex/ruby/window.h +17 -32
  82. data/include/reflex/ruby.h +6 -4
  83. data/include/reflex/selector.h +54 -2
  84. data/include/reflex/shape.h +211 -0
  85. data/include/reflex/style.h +111 -77
  86. data/include/reflex/timer.h +73 -0
  87. data/include/reflex/view.h +181 -59
  88. data/include/reflex/window.h +4 -3
  89. data/include/reflex.h +5 -4
  90. data/lib/reflex/application.rb +6 -3
  91. data/lib/reflex/button.rb +2 -2
  92. data/lib/reflex/capture_event.rb +7 -6
  93. data/lib/reflex/contact_event.rb +10 -12
  94. data/lib/reflex/draw_event.rb +6 -1
  95. data/lib/reflex/ellipse_shape.rb +27 -0
  96. data/lib/reflex/filter.rb +18 -0
  97. data/lib/reflex/fixture.rb +4 -0
  98. data/lib/reflex/focus_event.rb +10 -12
  99. data/lib/reflex/frame_event.rb +1 -1
  100. data/lib/reflex/helper.rb +17 -29
  101. data/lib/reflex/key_event.rb +13 -11
  102. data/lib/reflex/line_shape.rb +18 -0
  103. data/lib/reflex/{texture.rb → matrix.rb} +2 -2
  104. data/lib/reflex/module.rb +4 -19
  105. data/lib/reflex/pointer_event.rb +26 -37
  106. data/lib/reflex/polygon.rb +14 -0
  107. data/lib/reflex/polygon_shape.rb +23 -0
  108. data/lib/reflex/polyline.rb +13 -0
  109. data/lib/reflex/rect_shape.rb +20 -0
  110. data/lib/reflex/reflex.rb +1 -3
  111. data/lib/reflex/scroll_event.rb +1 -1
  112. data/lib/reflex/selector.rb +2 -2
  113. data/lib/reflex/shape.rb +62 -0
  114. data/lib/reflex/style.rb +78 -11
  115. data/lib/reflex/style_length.rb +0 -11
  116. data/lib/reflex/text_view.rb +7 -24
  117. data/lib/reflex/timer.rb +30 -0
  118. data/lib/reflex/timer_event.rb +29 -0
  119. data/lib/reflex/update_event.rb +1 -1
  120. data/lib/reflex/view.rb +127 -32
  121. data/lib/reflex/wheel_event.rb +9 -1
  122. data/lib/reflex/window.rb +29 -9
  123. data/lib/reflex.rb +11 -5
  124. data/lib/reflexion.rb +23 -7
  125. data/reflex.gemspec +8 -10
  126. data/samples/bats.rb +4 -4
  127. data/samples/fans.rb +1 -1
  128. data/samples/fps.rb +5 -3
  129. data/samples/hello.rb +4 -6
  130. data/samples/image.rb +5 -4
  131. data/samples/ios/hello/hello.xcodeproj/project.pbxproj +0 -2
  132. data/samples/layout.rb +16 -7
  133. data/samples/model.rb +10 -7
  134. data/samples/physics.rb +22 -20
  135. data/samples/reflexion/breakout.rb +4 -5
  136. data/samples/reflexion/hello.rb +2 -2
  137. data/samples/reflexion/jump_action.rb +191 -0
  138. data/samples/reflexion/noise.rb +23 -0
  139. data/samples/reflexion/paint.rb +7 -6
  140. data/samples/reflexion/physics.rb +15 -8
  141. data/samples/reflexion/pulse.rb +24 -10
  142. data/samples/shader.rb +8 -6
  143. data/samples/shapes.rb +63 -14
  144. data/samples/tree.rb +9 -10
  145. data/samples/views.rb +3 -3
  146. data/samples/visuals.rb +2 -5
  147. data/src/body.cpp +146 -345
  148. data/src/body.h +91 -0
  149. data/src/event.cpp +66 -16
  150. data/src/exception.cpp +13 -3
  151. data/src/filter.cpp +76 -0
  152. data/src/fixture.cpp +164 -39
  153. data/src/fixture.h +85 -0
  154. data/src/image_view.cpp +4 -4
  155. data/src/ios/app_delegate.h +5 -10
  156. data/src/ios/app_delegate.mm +79 -41
  157. data/src/ios/application.h +32 -0
  158. data/src/ios/application.mm +35 -25
  159. data/src/ios/event.mm +8 -4
  160. data/src/ios/reflex.mm +0 -7
  161. data/src/ios/view_controller.h +33 -0
  162. data/src/ios/view_controller.mm +436 -0
  163. data/src/ios/window.h +40 -0
  164. data/src/ios/window.mm +59 -250
  165. data/src/osx/app_delegate.h +5 -10
  166. data/src/osx/app_delegate.mm +52 -55
  167. data/src/osx/application.h +32 -0
  168. data/src/osx/application.mm +44 -39
  169. data/src/osx/native_window.h +0 -15
  170. data/src/osx/native_window.mm +131 -115
  171. data/src/osx/opengl_view.h +0 -2
  172. data/src/osx/opengl_view.mm +12 -3
  173. data/src/osx/reflex.mm +0 -9
  174. data/src/osx/window.h +42 -0
  175. data/src/osx/window.mm +45 -252
  176. data/src/selector.cpp +232 -7
  177. data/src/selector.h +52 -0
  178. data/src/shape.cpp +1191 -0
  179. data/src/shape.h +61 -0
  180. data/src/style.cpp +571 -374
  181. data/src/style.h +39 -0
  182. data/src/timer.cpp +291 -0
  183. data/src/timer.h +55 -0
  184. data/src/view.cpp +1624 -984
  185. data/src/view.h +56 -0
  186. data/src/win32/window.cpp +3 -4
  187. data/src/window.cpp +275 -20
  188. data/src/window.h +92 -0
  189. data/src/world.cpp +112 -111
  190. data/src/world.h +34 -53
  191. data/task/box2d.rake +31 -10
  192. data/test/test_capture_event.rb +8 -6
  193. data/test/test_pointer_event.rb +85 -0
  194. data/test/test_selector.rb +1 -1
  195. data/test/test_shape.rb +71 -0
  196. data/test/test_style.rb +77 -11
  197. data/test/test_style_length.rb +42 -13
  198. data/test/test_view.rb +138 -14
  199. metadata +109 -210
  200. data/.doc/ext/reflex/arc_shape.cpp +0 -89
  201. data/.doc/ext/reflex/body.cpp +0 -299
  202. data/.doc/ext/reflex/fixture.cpp +0 -101
  203. data/.doc/ext/reflex/shape_view.cpp +0 -153
  204. data/ext/reflex/arc_shape.cpp +0 -94
  205. data/ext/reflex/body.cpp +0 -328
  206. data/ext/reflex/fixture.cpp +0 -108
  207. data/ext/reflex/shape_view.cpp +0 -161
  208. data/include/reflex/bitmap.h +0 -20
  209. data/include/reflex/body.h +0 -128
  210. data/include/reflex/bounds.h +0 -20
  211. data/include/reflex/color.h +0 -20
  212. data/include/reflex/color_space.h +0 -20
  213. data/include/reflex/fixture.h +0 -117
  214. data/include/reflex/font.h +0 -20
  215. data/include/reflex/image.h +0 -20
  216. data/include/reflex/matrix.h +0 -20
  217. data/include/reflex/painter.h +0 -20
  218. data/include/reflex/point.h +0 -24
  219. data/include/reflex/ruby/body.h +0 -41
  220. data/include/reflex/ruby/fixture.h +0 -41
  221. data/include/reflex/ruby/shape_view.h +0 -96
  222. data/include/reflex/shader.h +0 -20
  223. data/include/reflex/shape_view.h +0 -146
  224. data/include/reflex/texture.h +0 -20
  225. data/lib/reflex/body.rb +0 -22
  226. data/lib/reflex/flags.rb +0 -18
  227. data/lib/reflex/shape_view.rb +0 -25
  228. data/src/ios/application_data.h +0 -45
  229. data/src/ios/native_window.h +0 -39
  230. data/src/ios/native_window.mm +0 -224
  231. data/src/ios/opengl_view.h +0 -13
  232. data/src/ios/opengl_view.mm +0 -139
  233. data/src/ios/window_data.h +0 -75
  234. data/src/osx/application_data.h +0 -45
  235. data/src/osx/window_data.h +0 -75
  236. data/src/physics/Box2D/Box2D.h +0 -68
  237. data/src/physics/Box2D/Collision/Shapes/b2ChainShape.cpp +0 -193
  238. data/src/physics/Box2D/Collision/Shapes/b2ChainShape.h +0 -105
  239. data/src/physics/Box2D/Collision/Shapes/b2CircleShape.cpp +0 -99
  240. data/src/physics/Box2D/Collision/Shapes/b2CircleShape.h +0 -91
  241. data/src/physics/Box2D/Collision/Shapes/b2EdgeShape.cpp +0 -138
  242. data/src/physics/Box2D/Collision/Shapes/b2EdgeShape.h +0 -74
  243. data/src/physics/Box2D/Collision/Shapes/b2PolygonShape.cpp +0 -467
  244. data/src/physics/Box2D/Collision/Shapes/b2PolygonShape.h +0 -101
  245. data/src/physics/Box2D/Collision/Shapes/b2Shape.h +0 -101
  246. data/src/physics/Box2D/Collision/b2BroadPhase.cpp +0 -119
  247. data/src/physics/Box2D/Collision/b2BroadPhase.h +0 -257
  248. data/src/physics/Box2D/Collision/b2CollideCircle.cpp +0 -154
  249. data/src/physics/Box2D/Collision/b2CollideEdge.cpp +0 -698
  250. data/src/physics/Box2D/Collision/b2CollidePolygon.cpp +0 -239
  251. data/src/physics/Box2D/Collision/b2Collision.cpp +0 -252
  252. data/src/physics/Box2D/Collision/b2Collision.h +0 -277
  253. data/src/physics/Box2D/Collision/b2Distance.cpp +0 -603
  254. data/src/physics/Box2D/Collision/b2Distance.h +0 -141
  255. data/src/physics/Box2D/Collision/b2DynamicTree.cpp +0 -778
  256. data/src/physics/Box2D/Collision/b2DynamicTree.h +0 -289
  257. data/src/physics/Box2D/Collision/b2TimeOfImpact.cpp +0 -486
  258. data/src/physics/Box2D/Collision/b2TimeOfImpact.h +0 -58
  259. data/src/physics/Box2D/Common/b2BlockAllocator.cpp +0 -215
  260. data/src/physics/Box2D/Common/b2BlockAllocator.h +0 -62
  261. data/src/physics/Box2D/Common/b2Draw.cpp +0 -44
  262. data/src/physics/Box2D/Common/b2Draw.h +0 -86
  263. data/src/physics/Box2D/Common/b2GrowableStack.h +0 -85
  264. data/src/physics/Box2D/Common/b2Math.cpp +0 -94
  265. data/src/physics/Box2D/Common/b2Math.h +0 -720
  266. data/src/physics/Box2D/Common/b2Settings.cpp +0 -44
  267. data/src/physics/Box2D/Common/b2Settings.h +0 -151
  268. data/src/physics/Box2D/Common/b2StackAllocator.cpp +0 -83
  269. data/src/physics/Box2D/Common/b2StackAllocator.h +0 -60
  270. data/src/physics/Box2D/Common/b2Timer.cpp +0 -101
  271. data/src/physics/Box2D/Common/b2Timer.h +0 -50
  272. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndCircleContact.cpp +0 -53
  273. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndCircleContact.h +0 -39
  274. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndPolygonContact.cpp +0 -53
  275. data/src/physics/Box2D/Dynamics/Contacts/b2ChainAndPolygonContact.h +0 -39
  276. data/src/physics/Box2D/Dynamics/Contacts/b2CircleContact.cpp +0 -52
  277. data/src/physics/Box2D/Dynamics/Contacts/b2CircleContact.h +0 -39
  278. data/src/physics/Box2D/Dynamics/Contacts/b2Contact.cpp +0 -247
  279. data/src/physics/Box2D/Dynamics/Contacts/b2Contact.h +0 -349
  280. data/src/physics/Box2D/Dynamics/Contacts/b2ContactSolver.cpp +0 -838
  281. data/src/physics/Box2D/Dynamics/Contacts/b2ContactSolver.h +0 -95
  282. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndCircleContact.cpp +0 -49
  283. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndCircleContact.h +0 -39
  284. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndPolygonContact.cpp +0 -49
  285. data/src/physics/Box2D/Dynamics/Contacts/b2EdgeAndPolygonContact.h +0 -39
  286. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonAndCircleContact.cpp +0 -49
  287. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonAndCircleContact.h +0 -38
  288. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonContact.cpp +0 -52
  289. data/src/physics/Box2D/Dynamics/Contacts/b2PolygonContact.h +0 -39
  290. data/src/physics/Box2D/Dynamics/Joints/b2DistanceJoint.cpp +0 -260
  291. data/src/physics/Box2D/Dynamics/Joints/b2DistanceJoint.h +0 -169
  292. data/src/physics/Box2D/Dynamics/Joints/b2FrictionJoint.cpp +0 -251
  293. data/src/physics/Box2D/Dynamics/Joints/b2FrictionJoint.h +0 -119
  294. data/src/physics/Box2D/Dynamics/Joints/b2GearJoint.cpp +0 -419
  295. data/src/physics/Box2D/Dynamics/Joints/b2GearJoint.h +0 -125
  296. data/src/physics/Box2D/Dynamics/Joints/b2Joint.cpp +0 -211
  297. data/src/physics/Box2D/Dynamics/Joints/b2Joint.h +0 -226
  298. data/src/physics/Box2D/Dynamics/Joints/b2MotorJoint.cpp +0 -304
  299. data/src/physics/Box2D/Dynamics/Joints/b2MotorJoint.h +0 -133
  300. data/src/physics/Box2D/Dynamics/Joints/b2MouseJoint.cpp +0 -222
  301. data/src/physics/Box2D/Dynamics/Joints/b2MouseJoint.h +0 -129
  302. data/src/physics/Box2D/Dynamics/Joints/b2PrismaticJoint.cpp +0 -629
  303. data/src/physics/Box2D/Dynamics/Joints/b2PrismaticJoint.h +0 -196
  304. data/src/physics/Box2D/Dynamics/Joints/b2PulleyJoint.cpp +0 -348
  305. data/src/physics/Box2D/Dynamics/Joints/b2PulleyJoint.h +0 -152
  306. data/src/physics/Box2D/Dynamics/Joints/b2RevoluteJoint.cpp +0 -502
  307. data/src/physics/Box2D/Dynamics/Joints/b2RevoluteJoint.h +0 -204
  308. data/src/physics/Box2D/Dynamics/Joints/b2RopeJoint.cpp +0 -241
  309. data/src/physics/Box2D/Dynamics/Joints/b2RopeJoint.h +0 -114
  310. data/src/physics/Box2D/Dynamics/Joints/b2WeldJoint.cpp +0 -344
  311. data/src/physics/Box2D/Dynamics/Joints/b2WeldJoint.h +0 -126
  312. data/src/physics/Box2D/Dynamics/Joints/b2WheelJoint.cpp +0 -419
  313. data/src/physics/Box2D/Dynamics/Joints/b2WheelJoint.h +0 -210
  314. data/src/physics/Box2D/Dynamics/b2Body.cpp +0 -549
  315. data/src/physics/Box2D/Dynamics/b2Body.h +0 -860
  316. data/src/physics/Box2D/Dynamics/b2ContactManager.cpp +0 -296
  317. data/src/physics/Box2D/Dynamics/b2ContactManager.h +0 -52
  318. data/src/physics/Box2D/Dynamics/b2Fixture.cpp +0 -303
  319. data/src/physics/Box2D/Dynamics/b2Fixture.h +0 -345
  320. data/src/physics/Box2D/Dynamics/b2Island.cpp +0 -539
  321. data/src/physics/Box2D/Dynamics/b2Island.h +0 -93
  322. data/src/physics/Box2D/Dynamics/b2TimeStep.h +0 -70
  323. data/src/physics/Box2D/Dynamics/b2World.cpp +0 -1339
  324. data/src/physics/Box2D/Dynamics/b2World.h +0 -354
  325. data/src/physics/Box2D/Dynamics/b2WorldCallbacks.cpp +0 -36
  326. data/src/physics/Box2D/Dynamics/b2WorldCallbacks.h +0 -155
  327. data/src/physics/Box2D/Rope/b2Rope.cpp +0 -259
  328. data/src/physics/Box2D/Rope/b2Rope.h +0 -115
  329. data/src/shape_view.cpp +0 -306
@@ -1,17 +1,12 @@
1
1
  // -*- objc -*-
2
2
  #import <UIKit/UIApplication.h>
3
- #include <reflex/application.h>
3
+ #include "application.h"
4
4
 
5
5
 
6
- @interface AppDelegate : UIResponder <UIApplicationDelegate>
6
+ @interface ReflexAppDelegate : UIResponder <UIApplicationDelegate>
7
7
 
8
- {
9
- @private
10
- Reflex::Application::Ref* pref;
11
- }
8
+ - (void) bind: (Reflex::Application*) application;
12
9
 
13
- - (void) bind: (Reflex::Application*) instance;
10
+ - (BOOL) callOnStart;
14
11
 
15
- - (void) unbind: (Reflex::Application*) instance;
16
-
17
- @end// AppDelegate
12
+ @end// ReflexAppDelegate
@@ -3,86 +3,124 @@
3
3
 
4
4
 
5
5
  #include <assert.h>
6
+ #import <CoreMotion/CoreMotion.h>
6
7
  #include "reflex/event.h"
7
8
  #include "reflex/exception.h"
8
- #include "application_data.h"
9
9
 
10
10
 
11
- #define REF (*pref)
11
+ @implementation ReflexAppDelegate
12
12
 
13
-
14
- @implementation AppDelegate
13
+ {
14
+ Reflex::Application* application;
15
+ bool started;
16
+ UIWindow* window;
17
+ CMMotionManager* motion_manager;
18
+ }
15
19
 
16
20
  - (id) init
17
21
  {
18
22
  self = [super init];
19
23
  if (!self) return nil;
20
24
 
21
- pref = new Reflex::Application::Ref;
25
+ application = NULL;
26
+ started = false;
27
+ window = nil;
28
+ motion_manager = nil;
22
29
 
23
30
  return self;
24
31
  }
25
32
 
26
33
  - (void) dealloc
27
34
  {
28
- assert(pref && !REF);
35
+ assert(!application);
29
36
 
30
- delete pref;
37
+ [self stopUpdateDeviceMotion];
31
38
 
32
39
  [super dealloc];
33
40
  }
34
41
 
35
- - (void) bind: (Reflex::Application*) instance
42
+ - (void) bind: (Reflex::Application*) app
36
43
  {
37
- assert(pref);
38
-
39
- if (instance && instance->self->delegate)
44
+ if (!app)
40
45
  Reflex::argument_error(__FILE__, __LINE__);
41
46
 
42
- if (REF)
47
+ if (app->self->delegate)
43
48
  Reflex::invalid_state_error(__FILE__, __LINE__);
44
49
 
45
- REF = instance;
46
- if (REF) REF->self->delegate = [self retain];
50
+ app->self->delegate = [self retain];
51
+ app->retain();
52
+
53
+ application = app;
47
54
  }
48
55
 
49
- - (void) unbind: (Reflex::Application*) instance
56
+ - (void) unbind
50
57
  {
51
- assert(pref);
58
+ if (!application) return;
52
59
 
53
- if (!REF) return;
60
+ if (application->self->delegate)
61
+ {
62
+ [application->self->delegate release];
63
+ application->self->delegate = nil;
64
+ }
54
65
 
55
- if (instance && instance != REF.get())
56
- Reflex::invalid_state_error(__FILE__, __LINE__);
66
+ application->release();
67
+ application = NULL;
68
+ }
69
+
70
+ - (BOOL) callOnStart
71
+ {
72
+ if (!application || started)
73
+ return YES;
74
+
75
+ Reflex::Event e;
76
+ application->on_start(&e);
77
+ started = true;
57
78
 
58
- if (REF->self->delegate) [REF->self->delegate release];
59
- REF->self->delegate = nil;
60
- REF.reset();
79
+ return !e.is_blocked();
61
80
  }
62
81
 
63
82
  - (BOOL) application: (UIApplication*) application
64
83
  didFinishLaunchingWithOptions: (NSDictionary*) options
65
84
  {
66
- if (!Reflex::app())
67
- {
68
- Reflex::invalid_state_error(
69
- __FILE__, __LINE__,
70
- "no Application instance on application:didFinishLaunchingWithOptions:");
71
- }
85
+ Reflex::Application* app = Reflex::app();
86
+ if (!self->application && app)
87
+ [self bind: app];
72
88
 
73
- [self bind: Reflex::app()];
89
+ [self startUpdateDeviceMotion];
74
90
 
75
- if (REF)
76
- {
77
- Reflex::Event e;
78
- REF->on_start(&e);
79
- if (e.is_blocked())
91
+ return [self callOnStart];
92
+ }
93
+
94
+ - (void) startUpdateDeviceMotion
95
+ {
96
+ CMMotionManager* man = [[[CMMotionManager alloc] init] autorelease];
97
+ if (!man || !man.deviceMotionAvailable)
98
+ return;
99
+
100
+ man.deviceMotionUpdateInterval = 1 / 60.0;
101
+ [man
102
+ startDeviceMotionUpdatesToQueue: NSOperationQueue.currentQueue
103
+ withHandler: ^(CMDeviceMotion* motion, NSError* error)
80
104
  {
81
- return NO;
105
+ if (!application) return;
106
+
107
+ Reflex::MotionEvent e(
108
+ Reflex::Point(motion.gravity.x, -motion.gravity.y, motion.gravity.z));
109
+ application->on_motion(&e);
82
110
  }
83
- }
111
+ ];
112
+
113
+ motion_manager = [man retain];
114
+ }
115
+
116
+ - (void) stopUpdateDeviceMotion
117
+ {
118
+ if (!motion_manager || !motion_manager.deviceMotionActive)
119
+ return;
84
120
 
85
- return YES;
121
+ [motion_manager stopDeviceMotionUpdates];
122
+ [motion_manager release];
123
+ motion_manager = nil;
86
124
  }
87
125
 
88
126
  - (void) applicationWillResignActive: (UIApplication*) application
@@ -103,10 +141,10 @@
103
141
 
104
142
  - (void) applicationWillTerminate: (UIApplication*) application
105
143
  {
106
- if (REF)
144
+ if (self->application)
107
145
  {
108
146
  Reflex::Event e;
109
- REF->on_quit(&e);
147
+ self->application->on_quit(&e);
110
148
  if (e.is_blocked())
111
149
  {
112
150
  Reflex::not_implemented_error(
@@ -114,7 +152,7 @@
114
152
  }
115
153
  }
116
154
 
117
- [self unbind: NULL];
155
+ [self unbind];
118
156
  }
119
157
 
120
- @end// AppDelegate
158
+ @end// ReflexAppDelegate
@@ -0,0 +1,32 @@
1
+ // -*- c++ -*-
2
+ #pragma once
3
+ #ifndef __REFLEX_SRC_IOS_APPLICATION_H__
4
+ #define __REFLEX_SRC_IOS_APPLICATION_H__
5
+
6
+
7
+ #include <reflex/application.h>
8
+
9
+
10
+ @class ReflexAppDelegate;
11
+
12
+
13
+ namespace Reflex
14
+ {
15
+
16
+
17
+ struct Application::Data
18
+ {
19
+
20
+ ReflexAppDelegate* delegate;
21
+
22
+ String name;
23
+
24
+ Data ();
25
+
26
+ };// Application::Data
27
+
28
+
29
+ }// Reflex
30
+
31
+
32
+ #endif//EOH
@@ -1,10 +1,9 @@
1
1
  // -*- objc -*-
2
- #include "reflex/application.h"
2
+ #include "application.h"
3
3
 
4
4
 
5
5
  #include <assert.h>
6
6
  #include "reflex/exception.h"
7
- #include "application_data.h"
8
7
  #import "app_delegate.h"
9
8
 
10
9
 
@@ -18,48 +17,56 @@ namespace Reflex
18
17
  {
19
18
 
20
19
 
21
- bool initialized ();
20
+ namespace global
21
+ {
22
22
 
23
+ static Application* instance = NULL;
23
24
 
24
- static Application* instance = NULL;
25
+ }// global
25
26
 
26
27
 
27
28
  Application*
28
29
  app ()
29
30
  {
30
- return instance;
31
+ return global::instance;
31
32
  }
32
33
 
33
34
 
34
35
  Application::Application ()
35
36
  {
36
- if (!initialized())
37
- reflex_error(__FILE__, __LINE__, "not initialized.");
38
-
39
- if (instance)
37
+ if (global::instance)
40
38
  reflex_error(__FILE__, __LINE__, "multiple application instances.");
41
39
 
42
- instance = this;
40
+ global::instance = this;
43
41
  }
44
42
 
45
43
  Application::~Application ()
46
44
  {
47
- instance = NULL;
45
+ global::instance = NULL;
48
46
  }
49
47
 
50
48
  void
51
49
  Application::start ()
52
50
  {
53
- UIApplicationMain(
54
- *_NSGetArgc(), *_NSGetArgv(), nil, NSStringFromClass(AppDelegate.class));
51
+ UIApplication* app = UIApplication.sharedApplication;
52
+ id<UIApplicationDelegate> delegate = app.delegate;
53
+ if (!delegate)
54
+ {
55
+ UIApplicationMain(*_NSGetArgc(), *_NSGetArgv(), nil, @"ReflexAppDelegate");
56
+ return;
57
+ }
58
+
59
+ if ([delegate isKindOfClass: ReflexAppDelegate.class])
60
+ {
61
+ ReflexAppDelegate* reflex_delegate = (ReflexAppDelegate*) delegate;
62
+ [reflex_delegate bind: this];
63
+ [reflex_delegate callOnStart];
64
+ }
55
65
  }
56
66
 
57
67
  void
58
68
  Application::quit ()
59
69
  {
60
- if (!*this)
61
- invalid_state_error(__FILE__, __LINE__);
62
-
63
70
  not_implemented_error(__FILE__, __LINE__);
64
71
  }
65
72
 
@@ -81,34 +88,31 @@ namespace Reflex
81
88
  void
82
89
  Application::on_start (Event* e)
83
90
  {
84
- if (!*this)
85
- invalid_state_error(__FILE__, __LINE__);
86
91
  }
87
92
 
88
93
  void
89
94
  Application::on_quit (Event* e)
90
95
  {
91
- if (!*this)
92
- invalid_state_error(__FILE__, __LINE__);
96
+ }
97
+
98
+ void
99
+ Application::on_motion (MotionEvent* e)
100
+ {
93
101
  }
94
102
 
95
103
  void
96
104
  Application::on_preference (Event* e)
97
105
  {
98
- if (!*this)
99
- invalid_state_error(__FILE__, __LINE__);
100
106
  }
101
107
 
102
108
  void
103
109
  Application::on_about (Event* e)
104
110
  {
105
- if (!*this)
106
- invalid_state_error(__FILE__, __LINE__);
107
111
  }
108
112
 
109
113
  Application::operator bool () const
110
114
  {
111
- return self && *self;
115
+ return true;
112
116
  }
113
117
 
114
118
  bool
@@ -118,4 +122,10 @@ namespace Reflex
118
122
  }
119
123
 
120
124
 
125
+ Application::Data::Data ()
126
+ : delegate(nil)
127
+ {
128
+ }
129
+
130
+
121
131
  }// Reflex
data/src/ios/event.mm CHANGED
@@ -17,12 +17,16 @@ namespace Reflex
17
17
  }
18
18
 
19
19
 
20
- NativePointerEvent::NativePointerEvent (NSSet* touches, UIEvent* e, UIView* view, Type type)
20
+ NativePointerEvent::NativePointerEvent (
21
+ NSSet* touches, UIEvent* e, UIView* view, Type type)
21
22
  : PointerEvent(type, POINTER_TOUCH, (coord) 0, (coord) 0, 0, 1, type == MOVE)
22
23
  {
23
- CGPoint p = correct_point(view, [touches anyObject]);
24
- x = p.x;
25
- y = p.y;
24
+ int index = 0;
25
+ for (UITouch* touch in touches) {
26
+ CGPoint p = correct_point(view, touch);
27
+ positions[index++].reset(p.x, p.y);
28
+ }
29
+ size = index;
26
30
  }
27
31
 
28
32
 
data/src/ios/reflex.mm CHANGED
@@ -3,7 +3,6 @@
3
3
 
4
4
 
5
5
  #include "reflex/exception.h"
6
- #import "app_delegate.h"
7
6
 
8
7
 
9
8
  namespace Reflex
@@ -18,12 +17,6 @@ namespace Reflex
18
17
  }// global
19
18
 
20
19
 
21
- bool
22
- initialized ()
23
- {
24
- return global::pool;
25
- }
26
-
27
20
  void
28
21
  init ()
29
22
  {
@@ -0,0 +1,33 @@
1
+ // -*- objc -*-
2
+ #import <UIKit/UIKit.h>
3
+ #import <GLKit/GLKit.h>
4
+
5
+
6
+ @interface ReflexView : GLKView
7
+ @end
8
+
9
+
10
+ @interface ReflexViewController : UIViewController
11
+
12
+ @property(nonatomic, strong, readonly) ReflexView* reflexView;
13
+
14
+ - (ReflexView*) createReflexView;
15
+
16
+ - (void) viewDidResize;
17
+
18
+ @end// ReflexViewController
19
+
20
+
21
+ typedef ReflexViewController* (*ReflexViewController_CreateFun) ();
22
+
23
+ typedef void (*ReflexViewController_ShowFun) (
24
+ UIViewController* root_vc, ReflexViewController* reflex_vc);
25
+
26
+
27
+ void ReflexViewController_set_create_fun (ReflexViewController_CreateFun fun);
28
+
29
+ void ReflexViewController_set_show_fun (ReflexViewController_ShowFun fun);
30
+
31
+ ReflexViewController_CreateFun ReflexViewController_get_create_fun ();
32
+
33
+ ReflexViewController_ShowFun ReflexViewController_get_show_fun ();