#include <tizen.h>
#include <service_app.h>
-#include <iotcon.h> // Please remove this after test
-
#include "log.h"
#include "resource.h"
#include "connectivity.h"
#include "controller.h"
+#include "controller_util.h"
+#include "webutil.h"
-#define GPIO_ULTRASONIC_TRIG_NUM_1 20
-#define GPIO_ULTRASONIC_ECHO_NUM_1 21
-#define MULTIPLE_SENSOR_NUMBER 5
#define CONNECTIVITY_KEY "opened"
+#define SENSORING_TIME_INTERVAL 5.0f
+#define CAMERA_TIME_INTERVAL 2
+#define TEST_CAMERA_SAVE 0
+#define CAMERA_ENABLED 0
typedef struct app_data_s {
Ecore_Timer *getter_timer;
connectivity_resource_s *resource_info;
} app_data;
+static void __resource_camera_capture_completed_cb(const void *image, unsigned int size, void *user_data)
+{
+ /* TODO */
+ const char *path = NULL;
+ const char *url = NULL;
+
+ controller_util_get_path(&path);
+
+ controller_util_get_image_address(&url);
+
+ web_util_noti_post_image_data(url, path, image, size);
+
+#if TEST_CAMERA_SAVE
+ FILE *fp = NULL;
+ char *data_path = NULL;
+ char file[256];
+
+ data_path = app_get_data_path();
+
+ snprintf(file, sizeof(file), "%sjjoggoba.jpg", data_path);
+ free(data_path);
+ _D("File : %s", file);
+
+ fp = fopen(file, "w");
+ if (!fp) {
+ _E("Failed to open file: %s", file);
+ return;
+ }
+
+ if (fwrite(image, size, 1, fp) != 1) {
+ _E("Failed to write image to file");
+ return;
+ }
+
+ fclose(fp);
+#endif
+}
+
static Eina_Bool control_sensors_cb(void *data)
{
- int value[MULTIPLE_SENSOR_NUMBER] = { 0, };
- int total = 0;
- int gpio_num[MULTIPLE_SENSOR_NUMBER] = { 5, 6, 13, 19, 26 };
- int i = 0;
app_data *ad = data;
+ int value = 1;
+ int ret = 0;
+#if CAMERA_ENABLED
+ static unsigned int count = 0;
- /**
- * This is the case when a number of the same sensors are installed.
- * Each of the five infrared motion sensors will receive the value.
- */
- for (i = 0; i < MULTIPLE_SENSOR_NUMBER; i++) {
- /**
- * Infrared motion sensor outputs 1 if motion is detected, or 0 if motion is not detected.
- */
- if (resource_read_infrared_motion_sensor(gpio_num[i], &value[i]) == -1) {
- _E("Failed to get Infrared Motion value [GPIO:%d]", gpio_num[i]);
- continue;
- }
- /**
- * If at least one of the five infrared motion sensors detects motion (1),
- * it is judged that there is a person (total == 1).
- */
- total |= value[i];
+ if (count % CAMERA_TIME_INTERVAL == 0) {
+ ret = resource_capture_camera(__resource_camera_capture_completed_cb, NULL);
+ if (ret < 0)
+ _E("Failed to capture camera");
}
- _I("[5:%d] | [6:%d] | [13:%d] | [19:%d] | [26:%d] = [Total:%d]", value[0], value[1], value[2], value[3], value[4], total);
- /**
- * Notifies specific clients that resource's attributes have changed.
- */
- if (connectivity_notify_bool(ad->resource_info, CONNECTIVITY_KEY, total) == -1)
+ count++;
+#endif
+
+ /* This is example, get value from sensors first */
+ if (connectivity_notify_int(ad->resource_info, "Motion", value) == -1)
_E("Cannot notify message");
return ECORE_CALLBACK_RENEW;
{
app_data *ad = data;
int ret = -1;
+ const char *path = NULL;
/**
* No modification required!!!
/**
* Create a connectivity resource and registers the resource in server.
*/
- ret = connectivity_set_resource("/door/1", "org.tizen.door", &ad->resource_info);
+ connectivity_set_protocol(CONNECTIVITY_PROTOCOL_HTTP);
+
+ controller_util_get_path(&path);
+ if (path == NULL) {
+ _E("Failed to get path");
+ return false;
+ }
+
+ ret = connectivity_set_resource(path, "org.tizen.door", &ad->resource_info);
if (ret == -1) _E("Cannot broadcast resource");
/**
* Creates a timer to call the given function in the given period of time.
* In the control_sensors_cb(), each sensor reads the measured value or writes a specific value to the sensor.
*/
- ad->getter_timer = ecore_timer_add(0.5f, control_sensors_cb, ad);
+ ad->getter_timer = ecore_timer_add(SENSORING_TIME_INTERVAL, control_sensors_cb, ad);
if (!ad->getter_timer) {
_E("Failed to add infrared motion getter timer");
return false;
}
- return true;
+ return true;
}
static void service_app_terminate(void *data)
{
app_data *ad = (app_data *)data;
- for (int i = 0; i < PIN_MAX; i++) {
- if (ad->getter_timer) {
- ecore_timer_del(ad->getter_timer);
- }
- }
+ if (ad->getter_timer)
+ ecore_timer_del(ad->getter_timer);
+
/**
* Releases the resource about connectivity.
static void service_app_control(app_control_h app_control, void *data)
{
- // Todo: add your code here.
+ // Todo: add your code here.
}
static void service_app_lang_changed(app_event_info_h event_info, void *user_data)