4 * Copyright 2012 Samsung Electronics Co., Ltd
6 * Licensed under the Flora License, Version 1.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.tizenopensource.org/license
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
21 #include <sensor_internal.h>
22 #include <vconf-keys.h>
27 #include <Elementary.h>
29 #include <ui-gadget-module.h>
31 #include "wfd_motion_control.h"
32 #include "wfd_ug_view.h"
33 #include "wfd_client.h"
36 static int motion_handle = -1;
38 static TARGET_VIEW_FOCUS __motion_target_view_focus_get(void *data)
40 struct ug_data *ugd = (struct ug_data *)data;
42 if ((ugd == NULL) || (ugd->naviframe == NULL)) {
43 return MOTION_TARGET_VIEW_FOCUS_OFF;
46 if (elm_object_focus_get(ugd->naviframe)) {
47 return MOTION_TARGET_VIEW_FOCUS_ON;
49 return MOTION_TARGET_VIEW_FOCUS_OFF;
54 static void __motion_shake_cb(unsigned int event_type, sensor_event_data_t *event_data, void *data)
58 gboolean motion_activated = FALSE;
59 struct ug_data *ugd = (struct ug_data *) data;
61 DBG(LOG_ERROR,"NULL pointer!");
64 TARGET_VIEW_FOCUS focus_state = __motion_target_view_focus_get(ugd);
66 DBG(LOG_DEBUG, "event type: %d, focus state: %d\n", event_type, focus_state);
68 if (focus_state != MOTION_TARGET_VIEW_FOCUS_ON) {
72 if (vconf_get_bool(VCONFKEY_SETAPPL_MOTION_ACTIVATION,
73 (void *)&motion_activated)) {
74 DBG(LOG_ERROR,"Get motion activation status fail");
78 if (FALSE == motion_activated) {
79 DBG(LOG_INFO,"Motion value is false");
83 if (vconf_get_bool(VCONFKEY_SETAPPL_USE_SHAKE,
84 (void *)&motion_activated)) {
85 DBG(LOG_ERROR, "Get use shake status fail");
89 if (FALSE == motion_activated) {
90 DBG(LOG_INFO,"Shake status is false");
95 const char *btn_text = NULL;
98 DBG(LOG_ERROR, "Incorrect parameter(NULL)\n");
102 wfd_refresh_wifi_direct_state(ugd);
104 if (NULL == ugd->scan_toolbar) {
105 DBG(LOG_ERROR, "NULL == ugd->scan_toolbar\n");
109 btn_text = elm_object_part_text_get(ugd->scan_toolbar, "default");
110 if (NULL == btn_text) {
111 DBG(LOG_ERROR, "Incorrect button text(NULL)\n");
115 GList *iterator = NULL;
117 if (0 == strcmp(btn_text, _("IDS_WIFI_SK4_SCAN"))) {
118 if (WIFI_DIRECT_STATE_CONNECTED == ugd->wfd_status) {
119 ret = wfd_client_disconnect(NULL);
120 if (ret != WIFI_DIRECT_ERROR_NONE) {
121 DBG(LOG_ERROR, "Failed wfd_client_disconnect() [%d]\n", ret);
126 if (ugd->multi_connect_mode != WFD_MULTI_CONNECT_MODE_NONE) {
127 wfd_free_multi_selected_peers(ugd);
129 /* update the connecting icon */
130 for (iterator = ugd->raw_discovered_peer_list; iterator; iterator = iterator->next) {
131 ((device_type_s *)iterator->data)->conn_status = PEER_CONN_STATUS_DISCONNECTED;
132 wfd_ug_view_refresh_glitem(((device_type_s *)iterator->data)->gl_item);
135 } else if (WIFI_DIRECT_STATE_DEACTIVATED == ugd->wfd_status) {
136 wfd_client_switch_on(ugd);
137 } else if ((WIFI_DIRECT_STATE_DISCOVERING == ugd->wfd_status) || (WIFI_DIRECT_STATE_ACTIVATED == ugd->wfd_status)) {
138 ugd->wfd_discovery_status = WIFI_DIRECT_DISCOVERY_SOCIAL_CHANNEL_START;
139 ret = wifi_direct_start_discovery_specific_channel(false, 1, WIFI_DIRECT_DISCOVERY_SOCIAL_CHANNEL);
140 if (ret != WIFI_DIRECT_ERROR_NONE) {
141 ugd->wfd_discovery_status = WIFI_DIRECT_DISCOVERY_NONE;
142 DBG(LOG_ERROR, "Failed to start discovery. [%d]\n", ret);
143 wifi_direct_cancel_discovery();
151 void motion_create(struct ug_data *ugd)
155 motion_handle = sf_connect(MOTION_SENSOR);
156 if (motion_handle < 0) {
157 DBG(LOG_ERROR, "Failed Operation sf_connect.\n");
160 ret = sf_register_event(motion_handle, MOTION_ENGINE_EVENT_SHAKE, NULL,
161 __motion_shake_cb, ugd);
163 DBG(LOG_ERROR, "Failed Operation sf_register_event. [%d]\n", ret);
166 ret = sf_start(motion_handle, 0);
168 DBG(LOG_ERROR, "Failed Operation sf_start. [%d]\n", ret);
172 DBG(LOG_INFO, "Succesfully, Init Sensor Handle\n");
176 ret = sf_disconnect(motion_handle);
178 DBG(LOG_ERROR, "Failed Operation sf_disconnect. [%d]\n", ret);
182 void motion_destroy(void)
186 if (motion_handle < 0) {
187 DBG(LOG_ERROR, "Motion Handle Not valid !!!");
191 ret = sf_stop(motion_handle);
193 DBG(LOG_ERROR, "Failed Operation sf_stop. [%d]\n", ret);
195 ret = sf_unregister_event(motion_handle, MOTION_ENGINE_EVENT_SHAKE);
197 DBG(LOG_ERROR, "Failed Operation sf_unregister_event. [%d]\n", ret);
199 ret = sf_disconnect(motion_handle);
201 DBG(LOG_ERROR, "Failed Operation sf_disconnect. [%d]\n", ret);