5
#include "ephysics_test.h"
8
_world_populate(Test_Data *test_data)
10
static const char *colors[] = {"blue-ball", "red-ball", "green-ball"};
11
Evas_Object *sphere, *shadow;
12
EPhysics_Body *fall_body;
15
for (i = 0; i < 9; i++)
20
shadow = elm_layout_add(test_data->win);
22
shadow, PACKAGE_DATA_DIR "/" EPHYSICS_TEST_THEME ".edj",
24
evas_object_move(shadow, (1 + column) * WIDTH / 4, FLOOR_Y);
25
evas_object_resize(shadow, 54, 3);
26
evas_object_show(shadow);
27
test_data->evas_objs = eina_list_append(test_data->evas_objs, shadow);
29
sphere = elm_image_add(test_data->win);
31
sphere, PACKAGE_DATA_DIR "/" EPHYSICS_TEST_THEME ".edj",
33
evas_object_move(sphere, (1 + column) * WIDTH / 4,
34
100 + row * 60 + row / 2 * 20);
35
evas_object_resize(sphere, 54, 54);
36
evas_object_show(sphere);
37
test_data->evas_objs = eina_list_append(test_data->evas_objs, sphere);
39
fall_body = ephysics_body_sphere_add(test_data->world);
40
ephysics_body_evas_object_set(fall_body, sphere, EINA_TRUE);
41
ephysics_body_event_callback_add(fall_body,
42
EPHYSICS_CALLBACK_BODY_UPDATE,
43
update_object_cb, shadow);
44
ephysics_body_restitution_set(fall_body, 0.95);
45
ephysics_body_friction_set(fall_body, 1);
46
test_data->bodies = eina_list_append(test_data->bodies, fall_body);
51
_restart(void *data, Evas_Object *obj __UNUSED__, const char *emission __UNUSED__, const char *source __UNUSED__)
53
Test_Data *test_data = data;
55
DBG("Restart pressed");
56
test_clean(test_data);
57
_world_populate(test_data);
61
test_colliding_balls(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
63
EPhysics_Body *boundary;
64
EPhysics_World *world;
70
test_data = test_data_new();
71
test_win_add(test_data, "Colliding Balls", EINA_TRUE);
72
elm_object_signal_emit(test_data->layout, "borders,show", "ephysics_test");
73
elm_layout_signal_callback_add(test_data->layout, "restart", "test-theme",
76
world = ephysics_world_new();
77
ephysics_world_render_geometry_set(world, 50, 40, -50,
78
WIDTH - 100, FLOOR_Y - 40, DEPTH);
79
test_data->world = world;
81
boundary = ephysics_body_bottom_boundary_add(test_data->world);
82
ephysics_body_restitution_set(boundary, 0.65);
83
ephysics_body_friction_set(boundary, 2);
85
ephysics_body_top_boundary_add(test_data->world);
86
ephysics_body_left_boundary_add(test_data->world);
87
ephysics_body_right_boundary_add(test_data->world);
89
_world_populate(test_data);