2 * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 #include <Elementary.h>
19 #include <Ecore_IMF.h>
21 #include <device/power.h>
22 #include <efl_assist.h>
23 #include <app_common.h>
26 #include <efl_extension.h>
30 #include "w-input-selector.h"
31 #include "w-input-smartreply.h"
32 #include "w-input-stt-voice.h"
33 #include "w-input-stt-engine.h"
34 #include "w-input-stt-ise.h"
38 #define _EDJ(x) elm_layout_edje_get(x)
41 #define GRP_PORTRAIT "mic_control"
43 #define item_append(obj, style, index, cb, udata) \
44 elm_genlist_item_append(obj, &(style), (void *)index, NULL, ELM_GENLIST_ITEM_NONE, cb, udata)
46 #define VIRTUAL_TEXT_AREA_FONT_STYLE \
47 "DEFAULT='font=Tizen:style=Regular font_size=32 color=#FFFFFF color_class=AT013 text_class=tizen wrap=mixed align=center' \
48 newline='br' b='+ font=Tizen:style=Bold'link='+ underline=on underline_color=#FFFFFF'"
50 extern App_Data* app_data;
51 extern VoiceData *my_voicedata;
53 static bool power_state = false;
55 static bool bottom_button_access_state = false;
57 static Evas_Object *radio_gp = NULL;
58 Evas_Object *g_setting_window = NULL;
59 static Evas_Object *g_setting_naviframe = NULL;
60 static Evas_Object *g_more_option_layout = NULL;
62 static Ecore_Event_Handler *g_evt_key_down = NULL;
64 static bool g_is_n66 = true;
66 static Elm_Genlist_Item_Class itc_title;
67 static Elm_Genlist_Item_Class itc_1text;
68 static Elm_Genlist_Item_Class itc_2text;
70 static bool g_send_button_clicked = false;
72 static bool g_mic_clicked = false;
74 static void set_guide_text(VoiceData *vd, const char* text, bool translatable = false);
76 char *supported_language[13] = {
92 char *supported_language_n66[7] = {
103 char *disp_lang_array[13] = {
106 "English (United Kingdom)",
107 "English (United States)",
109 "Español (América Latina)",
112 "Português (Brasil)",
119 char *disp_lang_array_n66[7] = {
121 "English (United States)",
122 "Español (América Latina)",
144 }STT_VOICE_LANGUAGE_I;
154 }STT_VOICE_LANGUAGE_N66_I;
165 static void get_stt_default_language(VoiceData *my_voicedata);
168 char* get_lang_label(char lang[])
172 if (strcmp(lang, "en_US") == 0)
173 str = disp_lang_array[3];
175 else if (strcmp(lang, "ko_KR") == 0)
176 str = disp_lang_array[12];
178 else if (strcmp(lang, "de_DE") == 0)
179 str = disp_lang_array[1];
181 else if (strcmp(lang, "fr_FR") == 0)
182 str = disp_lang_array[6];
184 else if (strcmp(lang, "it_IT") == 0)
185 str = disp_lang_array[7];
187 else if (strcmp(lang, "en_GB") == 0)
188 str = disp_lang_array[2];
190 else if (strcmp(lang, "ja_JP") == 0)
191 str = disp_lang_array[11];
193 else if (strcmp(lang, "zh_CN") == 0)
194 str = disp_lang_array[10];
196 else if (strcmp(lang, "ru_RU") == 0)
197 str = disp_lang_array[9];
199 else if (strcmp(lang, "pt_BR") == 0)
200 str = disp_lang_array[8];
202 else if (strcmp(lang, "es_ES") == 0)
203 str = disp_lang_array[4];
205 else if (strcmp(lang, "es_US") == 0)
206 str = disp_lang_array[5];
209 str = disp_lang_array[3];
214 char* get_lang_label_n66(char lang[])
218 if (strcmp (lang, "en_US") == 0)
219 str = disp_lang_array_n66[1];
221 else if (strcmp (lang, "ko_KR") == 0)
222 str = disp_lang_array_n66[6];
224 else if (strcmp (lang, "fr_FR") == 0)
225 str = disp_lang_array_n66[3];
227 else if (strcmp (lang, "ja_JP") == 0)
228 str = disp_lang_array_n66[5];
230 else if (strcmp (lang, "zh_CN") == 0)
231 str = disp_lang_array_n66[4];
233 else if (strcmp (lang, "es_US") == 0)
234 str = disp_lang_array_n66[2];
237 str = disp_lang_array_n66[1];
244 _bring_in_cb(void *data)
247 return ECORE_CALLBACK_CANCEL;
249 Evas_Coord x, y, w, h;
251 Evas_Object *scroller = (Evas_Object *)data;
252 Evas_Object *inner_layout = NULL;
254 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
256 evas_object_geometry_get(inner_layout, &x, &y, &w, &h);
257 elm_scroller_region_bring_in(scroller, x, h, w, h);
259 PRINTFUNC(NO_PRINT, "scroller %d %d %d %d", x, y, w, h);
261 return ECORE_CALLBACK_CANCEL;
264 static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
266 int calculated_height = 0;
268 int max_height = 1280;
269 int unit_width = 282;
271 Evas_Coord width, height;
274 Evas_Object *tb = NULL;
275 Evas_Textblock_Style *st = NULL;
276 Evas_Textblock_Cursor *cur = NULL;
278 tb = evas_object_textblock_add(evas_object_evas_get(obj));
279 evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
281 st = evas_textblock_style_new();
282 evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
283 evas_object_textblock_style_set(tb, st);
285 cur = evas_object_textblock_cursor_new(tb);
286 strbuf = elm_entry_utf8_to_markup(text.c_str());
287 evas_object_resize(tb, unit_width, max_height);
289 evas_object_textblock_text_markup_set(tb, strbuf);
290 evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
291 evas_object_textblock_size_formatted_get(tb, &width, &height);
292 evas_object_resize(tb, unit_width, height);
294 if(strbuf) free(strbuf);
295 if(tb) evas_object_del(tb);
296 if(st) evas_textblock_style_free(st);
297 if(cur) evas_textblock_cursor_free(cur);
302 static Eina_Bool _update_textblock_timer_cb(void *data)
305 return ECORE_CALLBACK_CANCEL;
307 VoiceData* voicedata = (VoiceData*)data;
309 voicedata->textblock_timer = NULL;
311 std::string result_text;
312 for(int i = 0; i < voicedata->stt_results.size(); i++){
313 if(i == voicedata->stt_results.size()-1){
314 result_text += voicedata->stt_results.at(i);
316 result_text += voicedata->stt_results.at(i);
321 Evas_Object *rect = NULL;
322 Evas_Object *entry = NULL;
323 Evas_Object *scroller = NULL;
324 Evas_Object *box = NULL;
325 Evas_Object *inner_layout = NULL;
328 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
331 PRINTFUNC(DLOG_ERROR, "failed to get scroller");
332 return ECORE_CALLBACK_CANCEL;
335 box = elm_object_content_get(scroller);
338 PRINTFUNC(DLOG_ERROR, "failed to get box");
339 return ECORE_CALLBACK_CANCEL;
342 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
345 PRINTFUNC(DLOG_ERROR, "failed to get inner_layout");
346 return ECORE_CALLBACK_CANCEL;
349 entry = elm_layout_content_get(inner_layout, "elm.swallow.content");
352 PRINTFUNC(DLOG_ERROR, "failed to get entry");
353 return ECORE_CALLBACK_CANCEL;
356 Evas_Object *top = (Evas_Object *) evas_object_data_get(box, "top_padding");
357 Evas_Object *bottom = (Evas_Object *) evas_object_data_get(box, "bottom_padding");
360 elm_box_unpack(box, top);
361 evas_object_del(top);
365 elm_box_unpack(box, bottom);
366 evas_object_del(bottom);
370 Evas_Coord height = get_text_block_size(box, result_text);
372 // if(height < 173) {
374 int text_area_height = 360-102; // screen H - bottom button H
375 int top_height = ((text_area_height - height) / 2);
376 if(top_height < 120) top_height = 120; // Top fade area H
378 int bottom_height = (text_area_height - top_height - height);
379 if(bottom_height < 1) bottom_height = 0;
381 PRINTFUNC(SECURE_DEBUG, "str : %s", result_text.c_str());
382 PRINTFUNC(DLOG_DEBUG, "height : %d", height);
383 PRINTFUNC(DLOG_DEBUG, "top_height : %d", top_height);
384 PRINTFUNC(DLOG_DEBUG, "bottom_height : %d", bottom_height);
386 rect = evas_object_rectangle_add(evas_object_evas_get(box));
387 evas_object_color_set(rect, 0, 0, 0, 100);
388 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
389 evas_object_size_hint_min_set(rect, 282, top_height);
390 evas_object_show(rect);
392 elm_box_pack_before(box, rect, inner_layout);
393 evas_object_data_set(box, "top_padding", (void *) rect);
395 rect = evas_object_rectangle_add(evas_object_evas_get(box));
396 evas_object_color_set(rect, 0, 0, 0, 100);
397 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
398 evas_object_size_hint_min_set(rect, 282, bottom_height);
399 evas_object_show(rect);
401 elm_box_pack_end(box, rect);
402 evas_object_data_set(box, "bottom_padding", (void *) rect);
405 elm_entry_entry_set(entry, result_text.c_str());
407 Evas_Object *panel_layout = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "left_panel_area");
408 Evas_Object *panel_left = elm_layout_content_get((Evas_Object *)panel_layout, "elm.swallow.right");
410 if (result_text.size() > 0) {
411 elm_object_signal_emit(panel_left, "elm,state,enabled", "elm");
413 elm_object_signal_emit(panel_left, "elm,state,disabled", "elm");
416 elm_object_signal_emit((Evas_Object *)voicedata->layout_main, "idle,state,guide_text,bottom", "elm");
418 if(voicedata->state == STT_STATE_VAL_LISTENING){
419 if(voicedata->guide_text_timer != NULL){
420 PRINTFUNC(DLOG_DEBUG, "Skip hide_guide_text");
421 ecore_timer_del(voicedata->guide_text_timer);
422 voicedata->guide_text_timer = NULL;
424 set_guide_text(voicedata, SK_TAP_TO_PAUSE, true);
427 elm_object_signal_emit(inner_layout, "scrolling", "entry");
429 return ECORE_CALLBACK_CANCEL;
432 void _update_textblock(void *data)
437 VoiceData *voicedata = (VoiceData *) data;
439 if(voicedata->textblock_timer == NULL){
440 voicedata->textblock_timer = ecore_timer_add(1.0, _update_textblock_timer_cb, voicedata);
442 PRINTFUNC(DLOG_DEBUG, "skip : the timer is not expired.");
448 void voice_get_string(const char *keyValue, _VoiceData *voicedata)
455 strbuf = elm_entry_utf8_to_markup(keyValue);
457 PRINTFUNC(DLOG_DEBUG, "text : %s, voicedata->partial_result=%s", strbuf, voicedata->partial_result);
460 if(voicedata->partial_result){ // partial_result is not Null so replace
461 if(strcmp(voicedata->partial_result, strbuf)){
463 PRINTFUNC(DLOG_DEBUG, "different replace");
465 voicedata->stt_results.pop_back();
466 voicedata->stt_results.push_back(strbuf);
468 free(voicedata->partial_result);
469 voicedata->partial_result = strdup(strbuf);
471 } else { // partial_result is Null so first case
472 PRINTFUNC(DLOG_DEBUG, "first push");
473 voicedata->stt_results.push_back(strbuf);
474 voicedata->partial_result = strdup(strbuf);
478 _update_textblock(voicedata);
483 PRINTFUNC(DLOG_DEBUG, "ends");
486 static Eina_Bool _recognition_failure_cb(void *data)
489 VoiceData *voicedata = (VoiceData *) data;
491 voicedata->state = STT_STATE_VAL_INIT;
492 set_animation_state(voicedata);
493 voicedata->refresh_timer = NULL;
495 return ECORE_CALLBACK_CANCEL;
498 void start_by_press(VoiceData *voicedata)
500 PRINTFUNC(DLOG_DEBUG, "");
502 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
507 static void on_mic_button_press_cb(void *data, Evas_Object *obj, void *event_info)
509 PRINTFUNC(NO_PRINT, "");
511 VoiceData *voicedata = (VoiceData *)data;
512 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
517 static char *_left_cue_access_info_cb(void *data, Evas_Object *obj)
521 snprintf(text, sizeof(text), "%s, %s", gettext(TTS_SEND), gettext(TTS_BUTTON));
526 static void _left_cue_access_activate_cb(void * data, Evas_Object *part_obj, Elm_Object_Item *item)
528 Evas_Object *obj = (Evas_Object *)data;
529 elm_layout_signal_emit(obj, "cue,clicked", "elm");
531 elm_panel_toggle(obj);
535 static void _send_button_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
537 PRINTFUNC(DLOG_DEBUG, "");
538 VoiceData* voicedata = (VoiceData*)data;
540 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
541 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
544 std::string text = std::string(gettext(TTS_SEND));
545 text = text +" "+ gettext(TTS_BUTTON);
546 if (elm_object_disabled_get(obj))
547 text = text + " " + gettext(TTS_DISABLED);
549 elm_access_say(text.c_str());
552 static Eina_Bool _mic_button_enable_cb(void *data)
554 PRINTFUNC(DLOG_DEBUG, "");
557 return ECORE_CALLBACK_CANCEL;
559 VoiceData* voicedata = (VoiceData*)data;
561 voicedata->btn_disabling_timer = NULL;
563 Evas_Object *button = (Evas_Object *)voicedata->mic_button;
565 elm_object_disabled_set(button, EINA_FALSE);
567 return ECORE_CALLBACK_CANCEL;
570 static void _mic_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
572 PRINTFUNC(DLOG_DEBUG, "");
573 VoiceData* voicedata = (VoiceData*)data;
575 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
576 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
579 elm_object_disabled_set(voicedata->mic_button, EINA_TRUE);
581 if(voicedata->btn_disabling_timer == NULL){
582 ecore_timer_del(voicedata->btn_disabling_timer);
584 voicedata->btn_disabling_timer = ecore_timer_add(3.0, _mic_button_enable_cb, voicedata);
586 elm_access_say(gettext(SK_DOUBLE_TAP_TO_SPEAK));
589 static char *_mic_access_info_cb(void *data, Evas_Object *obj)
591 if (data) return strdup((const char*)data);
596 static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *event_info)
598 if(g_send_button_clicked == true){
599 PRINTFUNC(DLOG_DEBUG, "skipped seding STT result");
603 g_send_button_clicked = true;
608 VoiceData* voicedata = (VoiceData*)data;
610 std::string result_text;
611 for(int i = 0; i < voicedata->stt_results.size(); i++){
612 result_text += voicedata->stt_results.at(i);
613 if(i != voicedata->stt_results.size()-1)
617 PRINTFUNC(DLOG_DEBUG, "result_text = %s", result_text.c_str());
618 input_smartreply_send_feedback(result_text.c_str());
620 if(app_data->reply_type == REPLY_APP_CONTROL){
621 reply_to_sender_by_appcontrol((void*)app_data, result_text.c_str(), "voice");
623 reply_to_sender_by_callback(result_text.c_str(), "voice");
633 _panel_cue_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
635 PRINTFUNC(DLOG_DEBUG, "left cue clicked!!");
637 on_confirm_button_clicked_cb(data, NULL, NULL);
642 void stt_feedback_initialize()
646 ret = feedback_initialize();
649 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
655 void stt_feedback(FeedbackType type)
659 ret = feedback_initialize();
662 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
666 if (type == VIBRATION_START){
667 // feedback_play(FEEDBACK_PATTERN_VOICE_START);
668 } else if (type == VIBRATION_STOP){
669 // feedback_play(FEEDBACK_PATTERN_VOICE_STOP);
672 ret = feedback_deinitialize();
675 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
680 void stt_feedback_deinitialize()
684 ret = feedback_deinitialize();
687 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
693 static Eina_Bool _idler_cb(void *data)
695 if(!data) return ECORE_CALLBACK_CANCEL;
697 VoiceData *voicedata = (VoiceData *)data;
699 PRINTFUNC(DLOG_DEBUG, "");
702 if(true == _app_stt_initialize(voicedata)) {
703 PRINTFUNC(NO_PRINT, "_app_stt_initialize None Error");
704 voicedata->voicefw_state = 1;
705 voicedata->state = STT_STATE_VAL_INIT;
707 voicedata->voicefw_state = 0;
708 PRINTFUNC(DLOG_ERROR, "Initialization Fail!<br>Check STT-daemon is running");
711 Evas_Object *canvas = elm_object_part_content_get(voicedata->layout_main, "EFFECT_BG");
714 is::ui::WInputSttMicEffect *ieffect = new is::ui::WInputSttMicEffect();
715 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
717 is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
718 voicedata->ieffect = ieffect;
719 voicedata->effector = effector;
721 ieffect->SetProgressBar(voicedata->progressbar);
722 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
724 voicedata->mo->Update();
726 elm_access_highlight_set(voicedata->mic_button);
729 return ECORE_CALLBACK_CANCEL;
733 static Eina_Bool _power_delayed_unlock(void *data){
734 PRINTFUNC(DLOG_DEBUG, "POWER Unlock");
736 VoiceData *voicedata = (VoiceData *) data;
737 device_power_release_lock(POWER_LOCK_DISPLAY);
738 voicedata->power_unlock_timer = NULL;
740 return ECORE_CALLBACK_CANCEL;
745 PRINTFUNC(DLOG_DEBUG, "POWER Unlock directly.");
746 device_power_release_lock(POWER_LOCK_DISPLAY);
749 void powerLock(void *data, bool enable)
751 int ret = DEVICE_ERROR_NONE;
753 VoiceData *voicedata = (VoiceData *) data;
756 ret = device_power_wakeup(false);
757 PRINTFUNC(DLOG_DEBUG, "LCD Wakeup");
759 if(ret != DEVICE_ERROR_NONE)
760 PRINTFUNC(DLOG_ERROR, "LCD Wakeup ERROR = %d", ret);
762 ret = device_power_request_lock(POWER_LOCK_DISPLAY, 0);
763 PRINTFUNC(DLOG_DEBUG, "POWER LOCK");
764 power_state = enable;
766 if(ret != DEVICE_ERROR_NONE)
767 PRINTFUNC(DLOG_ERROR, "ERROR = %d", ret);
769 if(voicedata->power_unlock_timer != NULL){
770 ecore_timer_del(voicedata->power_unlock_timer);
771 voicedata->power_unlock_timer = NULL;
774 PRINTFUNC(DLOG_DEBUG, "POWER Unlock Delayed(5 sec)");
776 if(voicedata->power_unlock_timer != NULL){
777 ecore_timer_del(voicedata->power_unlock_timer);
778 voicedata->power_unlock_timer = NULL;
780 voicedata->power_unlock_timer = ecore_timer_add(5.0, _power_delayed_unlock, voicedata);
785 static Eina_Bool hide_guide_text(void *data){
787 VoiceData *voicedata = (VoiceData *) data;
789 voicedata->guide_text_timer = NULL;
792 PRINTFUNC(DLOG_ERROR, "");
793 elm_object_part_text_set(voicedata->layout_main, "elm.text", "");
795 return ECORE_CALLBACK_CANCEL;
798 static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
800 //elm_object_signal_emit(vd->layout_main, "idle,state,text,visible", "elm");
803 elm_object_domain_translatable_part_text_set(vd->layout_main, "elm.text", PACKAGE, text);
805 elm_object_part_text_set(vd->layout_main, "elm.text", text);
807 if(!strcmp(text, SK_SPEAK_NOW)){
808 if(vd->guide_text_timer == NULL)
809 vd->guide_text_timer = ecore_timer_add(2.0, hide_guide_text, vd);
814 * @brief - function to send the signal to edc
815 * to change the animation as per stt state
818 void set_animation_state(VoiceData *voicedata)
820 PRINTFUNC(DLOG_DEBUG, "");
822 PRINTFUNC(DLOG_ERROR, "voicedata->state == %s",
823 voicedata->state == STT_STATE_VAL_INIT ?
824 "STT_STATE_VAL_INIT" :
825 voicedata->state == STT_STATE_VAL_LISTENING ?
826 "STT_STATE_VAL_LISTENING" :
827 voicedata->state == STT_STATE_VAL_PREPARE_LISTENING ?
828 "STT_STATE_VAL_PREPARE_LISTENING" :
829 voicedata->state == STT_STATE_VAL_PROCESSING ?
830 "STT_STATE_VAL_PROCESSING" :
831 voicedata->state == STT_STATE_VAL_PREPARE_PROCESSING ?
832 "STT_STATE_VAL_PREPARE_PROCESSING" :
833 voicedata->state == STT_STATE_VAL_TERMINATING ?
834 "STT_STATE_VAL_TERMINATING" : "STT_STATE_VAL_NOT_RECOGNISED");
836 if (voicedata->state == STT_STATE_VAL_INIT) {
838 if (voicedata->sttmanager->GetCurrent() == STT_STATE_READY) {
839 set_guide_text(voicedata, "", false);
840 //_elm_access_say(voicedata->layout_main, _(SK_INIT));
842 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
843 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
844 //_elm_access_say(voicedata->layout_main, _(SK_NETWORK_CONNECTION_ERROR));
848 if(voicedata->effector)
849 voicedata->effector->Stop(true);
851 set_guide_text(voicedata, "");
853 PRINTFUNC(DLOG_DEBUG, "%d", voicedata->stt_results.size());
854 powerLock((void*)voicedata, false);
855 } else if (voicedata->state == STT_STATE_VAL_LISTENING) {
856 set_guide_text(voicedata, SK_SPEAK_NOW, true);
858 if(voicedata->effector)
859 voicedata->effector->Start();
861 powerLock((void*)voicedata, true);
862 } else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
863 set_guide_text(voicedata, "");
864 if(voicedata->effector)
865 voicedata->effector->Stop();
867 stt_feedback(VIBRATION_STOP);
869 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
870 set_guide_text(voicedata, _(SK_RECOGNITION_FAILED));
871 //_elm_access_say(voicedata->layout_main, _(SK_RECOGNITION_FAILED));
873 voicedata->state = STT_STATE_VAL_NOT_RECOGNISED;
875 if(voicedata->refresh_timer) {
876 ecore_timer_del(voicedata->refresh_timer);
879 if(voicedata->effector)
880 voicedata->effector->Stop(true);
882 voicedata->refresh_timer = ecore_timer_add(2.0, _recognition_failure_cb, voicedata);
884 //powerLock((void*)voicedata, false);
888 void show_error_message(VoiceData *vd, stt_error_e reason)
890 if(reason == STT_ERROR_OUT_OF_NETWORK)
892 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
894 int ancs_connected = 0;
896 ret = vconf_get_int("file/private/weconn/ancs_connected", &ancs_connected);
899 PRINTFUNC(DLOG_ERROR, "ancs connected status : %d", ancs_connected);
901 PRINTFUNC(DLOG_ERROR, "vconf for ancs connection ERROR - %d", ret);
903 if (ancs_connected) {
905 snprintf(text, sizeof(text), _(SK_NETWORK_ERROR_FOR_IOS), _(SK_SAMSUNG_GEAR));
907 show_popup_toast((const char*)text, false);
909 set_guide_text(vd, _(SK_NETWORK_ERROR));
912 vd->state = STT_STATE_VAL_INIT;
914 } else if (reason == STT_ERROR_RECORDER_BUSY) {
915 PRINTFUNC(DLOG_WARN, "STT is used by another application");
916 show_popup_toast(_(SK_STT_BUSY), false);
917 vd->state = STT_STATE_VAL_INIT;
919 PRINTFUNC(DLOG_WARN, "Check error code");
920 show_popup_toast(_(SK_STT_BUSY), false);
921 vd->state = STT_STATE_VAL_INIT;
925 static Eina_Bool _start_timer_cb(void* data)
928 VoiceData *voicedata = (VoiceData *) data;
931 voicedata->state = STT_STATE_VAL_PREPARE_LISTENING;
932 voicedata->sttmanager->Start();
934 catch (is::stt::SttException &e) {
935 PRINTFUNC(DLOG_ERROR, "%s", e.what());
937 if (e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
939 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
940 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
941 voicedata->state = STT_STATE_VAL_INIT;
942 } else if (e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
943 PRINTFUNC(DLOG_WARN, "STT is used by another application");
944 show_popup_toast(_(SK_STT_BUSY), false);
945 voicedata->state = STT_STATE_VAL_INIT;
947 PRINTFUNC(DLOG_WARN, "Check error code");
948 show_popup_toast(_(SK_STT_BUSY), false);
949 voicedata->state = STT_STATE_VAL_INIT;
952 voicedata->start_timer = NULL;
954 return ECORE_CALLBACK_CANCEL;
958 * @brief - cancel button press callback for cross button
962 void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
964 PRINTFUNC(NO_PRINT, "");
966 VoiceData *vd = (VoiceData *)data;
968 int tempVal = vd->sttmanager->GetCurrent();
969 if(tempVal == STT_STATE_CREATED) {
970 PRINTFUNC(DLOG_WARN, "IGNORE TOUCH event before STT READY. STT is preparing", vd->state);
974 PRINTFUNC(DLOG_DEBUG, "SttManager State : %d", vd->sttmanager->GetCurrent());
975 PRINTFUNC(DLOG_DEBUG, "Ui Voice State : %d", vd->state);
978 case STT_STATE_VAL_INIT:
980 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_INIT");
981 get_stt_default_language(vd);
982 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
984 stt_feedback(VIBRATION_START);
986 if(vd->start_timer) {
987 ecore_timer_del(vd->start_timer);
988 vd->start_timer = NULL;
991 vd->start_timer = ecore_timer_add(0.0, _start_timer_cb, vd);
994 case STT_STATE_VAL_LISTENING :
995 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_LISTENING");
997 vd->state = STT_STATE_VAL_PREPARE_PROCESSING;
998 vd->sttmanager->Stop();
1001 * Cuased touch reponse time, it can be called to stop animator.
1004 set_guide_text(vd, "");
1007 vd->effector->Stop();
1009 catch (is::stt::SttException &e) {
1010 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1012 if(e.GetEcode() != STT_ERROR_INVALID_STATE) {
1013 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
1014 set_guide_text(vd, _(SK_RECOGNITION_FAILED));
1015 vd->state = STT_STATE_VAL_INIT;
1018 vd->effector->Stop(true);
1023 case STT_STATE_VAL_PROCESSING:
1024 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_PROCESSING");
1026 //vd->state = STT_STATE_VAL_PREPARE_CANCEL;
1027 vd->sttmanager->Cancel();
1029 catch (is::stt::SttException &e) {
1030 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1035 case STT_STATE_VAL_NOT_RECOGNISED:
1036 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_NOT_RECOGNISED");
1037 vd->state = STT_STATE_VAL_INIT ;
1040 PRINTFUNC(DLOG_DEBUG, "default [%d]", vd->state);
1045 static inline void ea_naviframe_back(void *data, Evas_Object *obj, void *event_info)
1049 evas_object_del((Evas_Object *) data);
1051 g_setting_window = NULL;
1052 g_setting_naviframe = NULL;
1055 ecore_event_handler_del(g_evt_key_down);
1057 g_evt_key_down = NULL;
1060 if(g_more_option_layout){
1061 if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
1062 eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
1067 static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char *part)
1069 return strdup(_("WDS_VOICE_OPT_LANGUAGE_ABB"));
1072 char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
1074 char text[128] = {0, };
1076 if(!strcmp(part, "elm.text"))
1078 if((int)data == 0) {
1079 return strdup(_("IDS_VC_BODY_AUTOMATIC"));
1083 s = (char *)disp_lang_array_n66[(int)data];
1085 s = (char *)disp_lang_array[(int)data];
1089 char *p = strchr(s, '(');
1091 strncpy(text, s, p-s);
1093 strncpy(text, s, strlen(s));
1096 strncpy(text, "", strlen(""));
1099 return strdup(text);
1100 } else if (!strcmp(part, "elm.text.1")) {
1101 if ((int)data == 0) {
1103 value = vconf_get_str(VCONFKEY_LANGSET);
1104 if (NULL == value) {
1105 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1108 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1110 char system_lang[6] = {0, };
1111 strncpy(system_lang, value , 5);
1114 // confirm whether the system language is supported by stt engine or not.
1115 // if supported, set the language
1116 // otherwise, set language to en_US
1118 return strdup(get_lang_label_n66(system_lang));
1120 return strdup(get_lang_label(system_lang));
1125 s = (char *)disp_lang_array_n66[(int)data];
1127 s = (char *)disp_lang_array[(int)data];
1131 char *p = strchr(s, '(');
1133 strncpy(text, p+1, strlen(s)-(p-s)-2);
1135 strncpy(text, s, strlen(s));
1138 strncpy(text, "", strlen(""));
1140 return strdup(text);
1146 static Evas_Object *__get_genlist_item_content(void *data, Evas_Object *obj, const char *part)
1148 int index = (int)data;
1149 Evas_Object * content = NULL;
1151 if (!strcmp(part, "elm.icon")) {
1152 content = elm_radio_add(obj);
1153 elm_radio_state_value_set(content, index);
1154 elm_radio_group_add(content, radio_gp);
1155 evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1156 evas_object_propagate_events_set(content, EINA_TRUE);
1157 evas_object_size_hint_align_set(content, EVAS_HINT_FILL, EVAS_HINT_FILL);
1158 elm_object_style_set(content, "list");
1163 static int get_language_value()
1166 int lang = 0, ret = 0;
1168 ret = preference_get_int(PREFERENCE_ISE_STT_LANGUAGE, &lang);
1169 if(PREFERENCE_ERROR_NONE != ret){
1170 PRINTFUNC(DLOG_ERROR, "preference_get_int error!(%d)", ret);
1171 preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)2); //auto
1175 int lang = 0, ret = 0;
1177 ret = vconf_get_int(VCONFKEY_ISE_STT_LANGUAGE, &lang);
1179 PRINTFUNC(DLOG_ERROR, "Vconf_get_int error!(%d)", ret);
1183 if(lang < 0 || lang > 6) {
1184 PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
1187 PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array_n66[lang]);
1189 if(lang < 0 || lang > 12) {
1190 PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
1193 PRINTFUNC(DLOG_DEBUG, "current language value for stt (%s).", disp_lang_array[lang]);
1199 static void set_language_value(int type)
1201 // Add implementation to store language type.
1205 ret = preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)type);
1206 if(PREFERENCE_ERROR_NONE != ret){
1207 PRINTFUNC(DLOG_ERROR, "preference_set_int error!(%d)", ret);
1211 ret = vconf_set_int(VCONFKEY_ISE_STT_LANGUAGE, (int) type);
1213 PRINTFUNC(DLOG_ERROR, "Vconf_set_int error!(%d)", ret);
1217 PRINTFUNC(DLOG_DEBUG, "language type (%d)", type);
1222 static void get_stt_default_language(VoiceData *my_voicedata)
1225 PRINTFUNC(DLOG_ERROR, "my_voicedata NULL");
1229 if(my_voicedata->kbd_lang) {
1230 free(my_voicedata->kbd_lang);
1231 my_voicedata->kbd_lang = NULL;
1236 STT_VOICE_LANGUAGE_N66_I stt_lang;
1237 stt_lang = (STT_VOICE_LANGUAGE_N66_I)get_language_value();
1239 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1242 case STT_VOICE_N66_AUTO :
1244 stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1246 // get system display language
1248 value = vconf_get_str(VCONFKEY_LANGSET);
1249 if (NULL == value) {
1250 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1253 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1255 char system_lang[6] = {0, };
1256 strncpy(system_lang, value , 5);
1259 // confirm whether the system language is supported by stt engine or not.
1260 // if supported, set the language
1261 // otherwise, set language to en_US
1262 if(is_lang_supported_by_stt(system_lang) == TRUE) {
1263 my_voicedata->kbd_lang = strdup(system_lang);
1264 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1266 my_voicedata->kbd_lang = strdup("en_US");
1267 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1271 case STT_VOICE_N66_EN_US :
1272 case STT_VOICE_N66_ES_US :
1273 case STT_VOICE_N66_FR_FR :
1274 case STT_VOICE_N66_JA_JP :
1275 case STT_VOICE_N66_KO_KR :
1276 case STT_VOICE_N66_ZH_CN :
1278 my_voicedata->kbd_lang = strdup(supported_language_n66[stt_lang]);
1282 my_voicedata->kbd_lang = strdup("en_US");
1286 STT_VOICE_LANGUAGE_I stt_lang;
1287 stt_lang = (STT_VOICE_LANGUAGE_I)get_language_value();
1289 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1292 case STT_VOICE_AUTO :
1294 stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1296 // get system display language
1298 value = vconf_get_str(VCONFKEY_LANGSET);
1299 if (NULL == value) {
1300 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1303 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1305 char system_lang[6] = {0, };
1306 strncpy(system_lang, value , 5);
1309 // confirm whether the system language is supported by stt engine or not.
1310 // if supported, set the language
1311 // otherwise, set language to en_US
1312 if(is_lang_supported_by_stt(system_lang) == TRUE) {
1313 my_voicedata->kbd_lang = strdup(system_lang);
1314 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1316 my_voicedata->kbd_lang = strdup("en_US");
1317 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1321 case STT_VOICE_DE_DE :
1322 case STT_VOICE_EN_GB :
1323 case STT_VOICE_EN_US :
1324 case STT_VOICE_ES_ES :
1325 case STT_VOICE_ES_US :
1326 case STT_VOICE_FR_FR :
1327 case STT_VOICE_IT_IT :
1328 case STT_VOICE_JA_JP :
1329 case STT_VOICE_KO_KR :
1330 case STT_VOICE_RU_RU :
1331 case STT_VOICE_ZH_CN :
1332 case STT_VOICE_PT_BR :
1334 my_voicedata->kbd_lang = strdup(supported_language[stt_lang]);
1338 my_voicedata->kbd_lang = strdup("en_US");
1343 PRINTFUNC(DLOG_DEBUG, "stt language (%s)", my_voicedata->kbd_lang);
1346 static Eina_Bool close_setting_window_idler_cb(void *data)
1348 if(g_setting_window && g_setting_naviframe) {
1349 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1352 return ECORE_CALLBACK_CANCEL;
1355 static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *event_info)
1357 PRINTFUNC(DLOG_DEBUG, "");
1361 Evas_Object *genlist = (Evas_Object *) data;
1363 Elm_Object_Item * item = (Elm_Object_Item *) event_info;
1365 elm_genlist_item_selected_set(item, 0);
1366 index = (int)elm_object_item_data_get(item);
1367 elm_genlist_item_update(item);
1369 set_language_value(index);
1371 elm_radio_value_set(radio_gp, index);
1372 ecore_timer_add(0.3, close_setting_window_idler_cb, NULL);
1375 static void language_changed_cb2(void *data, Evas_Object *obj, const char *emission, const char *source)
1378 elm_genlist_realized_items_update(obj);
1381 Eina_Bool _ise_keydown_cb(void *data, int type, void *event)
1383 PRINTFUNC(DLOG_DEBUG, "");
1384 if(type == ECORE_EVENT_KEY_DOWN && g_setting_window && g_setting_naviframe) {
1385 PRINTFUNC(DLOG_DEBUG, "window will be deleted.");
1386 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1389 return ECORE_CALLBACK_DONE;
1392 char *_language_list_access_info_cb(void *data, Evas_Object *obj)
1394 PRINTFUNC(DLOG_DEBUG, "%s", __func__);
1398 std::string text = std::string(gettext(TTS_RADIO_BUTTON));
1399 const Elm_Object_Item *item = (Elm_Object_Item *)data;
1401 Evas_Object* radio = elm_object_item_part_content_get(item, "elm.icon");
1403 index = elm_genlist_item_index_get(item);
1405 if(index == 1) // title
1409 value = elm_radio_value_get(radio);
1410 //PRINTFUNC(DLOG_DEBUG,"index=%d value = %d", index, value);
1411 if(index == value + 2 ){
1412 text = text + std::string(" ") + std::string(gettext(TTS_SELECTED));
1414 text = text + std::string(" ") + std::string(gettext(TTS_NOT_SELECTED));
1417 return strdup(text.c_str());
1420 static void _language_list_item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
1422 PRINTFUNC(DLOG_DEBUG, "%s", __func__);
1425 static Evas_Object *create_language_list(Evas_Object *parent)
1427 if(!parent) return NULL;
1429 Evas_Object *genlist = elm_genlist_add(parent);
1430 if (!genlist) return NULL;
1432 elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
1433 elm_genlist_homogeneous_set(genlist, EINA_TRUE);
1434 // uxt_genlist_set_bottom_margin_enabled(genlist, EINA_TRUE);
1436 Evas_Object *circle_language_genlist = eext_circle_object_genlist_add(genlist, NULL);
1437 eext_circle_object_genlist_scroller_policy_set(circle_language_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1438 evas_object_resize(circle_language_genlist, 360, 360);
1439 evas_object_show(circle_language_genlist);
1440 eext_rotary_object_event_activated_set(circle_language_genlist, EINA_TRUE);
1444 Elm_Object_Item * item = NULL;
1445 Elm_Object_Item * item_title = NULL;
1447 evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1448 evas_object_size_hint_align_set(genlist, EVAS_HINT_FILL, EVAS_HINT_FILL);
1450 radio_gp = elm_radio_add(genlist);
1451 elm_radio_state_value_set(radio_gp, -1);
1453 lang_val = get_language_value();
1456 itc_title.item_style = "title";
1457 itc_title.func.text_get = __get_genlist_title_label;
1458 itc_title.func.content_get = NULL;
1460 item_title = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
1463 itc_2text.item_style = "2text.1icon.1/sub1.multiline";
1464 itc_2text.func.text_get = __get_genlist_item_label;
1465 itc_2text.func.content_get = __get_genlist_item_content;
1468 item = item_append(genlist, itc_2text, (void *)0, language_set_genlist_radio_cb, genlist); // AUTO
1471 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1472 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1475 if ( item == NULL ) {
1476 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1480 itc_1text.item_style = "1text.1icon.1";
1481 itc_1text.func.text_get = __get_genlist_item_label;
1482 itc_1text.func.content_get = __get_genlist_item_content;
1485 for (i = 1; i < 7; i++)
1487 char *s = (char *)disp_lang_array_n66[i];
1490 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1492 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1496 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1497 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1500 if ( item == NULL ) {
1501 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1506 for (i = 1; i < 13; i++)
1508 char *s = (char *)disp_lang_array[i];
1511 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1513 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1517 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1518 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1521 if ( item == NULL ) {
1522 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1528 elm_radio_value_set(radio_gp, lang_val);
1530 elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb2, NULL);
1531 // eext_rotary_event_callback_set(genlist, _language_list_rotary_cb, NULL);
1532 evas_object_smart_callback_add(genlist, "realized", _language_list_item_realized, NULL);
1535 g_evt_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _ise_keydown_cb, NULL);
1539 void create_setting_window(Evas_Object *more_option_layout)
1543 Evas_Object *window = NULL;
1544 Evas_Object *layout = NULL;
1545 Evas_Object *genlist = NULL;
1546 Evas_Object *naviframe = NULL;
1548 Elm_Object_Item *item = NULL;
1550 const char *str = "mobile";
1553 * Create full size window
1556 window = elm_win_add(NULL, "voice-input-setting", ELM_WIN_BASIC);
1558 PRINTFUNC(DLOG_DEBUG, "it's fail to create window.");
1562 elm_win_title_set(window, "voice-input-setting");
1563 // ecore_x_window_size_get(ecore_x_window_root_first_get(), &w, &h);
1564 elm_win_borderless_set(window, EINA_TRUE);
1565 evas_object_resize(window, w, h);
1567 elm_win_indicator_mode_set(window, ELM_WIN_INDICATOR_HIDE);
1568 elm_win_profiles_set(window, &str, 1);
1574 // ea_theme_style_set(EA_THEME_STYLE_DEFAULT);
1575 // ea_theme_changeable_ui_enabled_set(EINA_TRUE);
1578 * Create layout for language list
1581 layout = elm_layout_add(window);
1583 elm_layout_theme_set(layout, "layout", "application", "default");
1584 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1585 evas_object_show(layout);
1586 elm_win_resize_object_add(window, layout);
1590 * Set Window rotation
1593 if (elm_win_wm_rotation_supported_get(window)) {
1594 const int rots[4] = { 0, 90, 180, 270 };
1595 elm_win_wm_rotation_available_rotations_set(window, rots, 4);
1599 * Activate and show window
1602 elm_win_activate(window);
1603 evas_object_show(window);
1609 naviframe = elm_naviframe_add(layout);
1610 if (naviframe == NULL){
1611 PRINTFUNC(DLOG_DEBUG, "create navi_frame failed");
1614 // ea_object_event_callback_add(naviframe, EA_CALLBACK_BACK, ea_naviframe_back, window);
1615 elm_object_part_content_set(layout, "elm.swallow.content", naviframe);
1618 * Push language list
1621 genlist = create_language_list(naviframe);
1623 //item = elm_naviframe_item_push(naviframe, "IDS_VC_HEADER_VOICE_INPUT_LANGUAGE", NULL, NULL, genlist, NULL);
1624 item = elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, "empty");
1625 //elm_object_item_domain_text_translatable_set(item, PACKAGE, EINA_TRUE);
1627 g_setting_window = window;
1628 g_setting_naviframe = naviframe;
1629 g_more_option_layout = more_option_layout;
1632 static void language_changed_cb(void *data, Evas_Object * obj, void *event_info)
1634 PRINTFUNC(DLOG_DEBUG, "");
1640 static void get_text_part_width(Evas_Object *window, const char *text, Evas_Coord *calculated_width)
1644 if(!calculated_width) return;
1646 Evas_Coord width, height;
1648 char *strbuf = NULL;
1649 Evas_Object *tb = NULL;
1650 Evas_Textblock_Style *st = NULL;
1651 Evas_Textblock_Cursor *cur = NULL;
1653 tb = evas_object_textblock_add(evas_object_evas_get(window));
1654 evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
1656 st = evas_textblock_style_new();
1657 evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
1658 evas_object_textblock_style_set(tb, st);
1660 cur = evas_object_textblock_cursor_new(tb);
1661 strbuf = elm_entry_utf8_to_markup(text);
1662 evas_object_resize(tb, 360, 47);
1664 evas_object_textblock_text_markup_set(tb, strbuf);
1665 evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
1666 evas_object_textblock_size_formatted_get(tb, &width, &height);
1667 evas_object_resize(tb, width, 47);
1669 *calculated_width = width;
1671 if(strbuf) free(strbuf);
1672 if(tb) evas_object_del(tb);
1673 if(st) evas_textblock_style_free(st);
1674 if(cur) evas_textblock_cursor_free(cur);
1677 void _stt_lang_changed_cb(keynode_t *key, void* data)
1679 PRINTFUNC(DLOG_DEBUG, "");
1682 VoiceData *vd = (VoiceData *) data;
1683 get_stt_default_language(vd);
1684 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
1690 static void __done_key_cb(void *data, Evas_Object *obj, void *event_info )
1692 PRINTFUNC(DLOG_DEBUG, "");
1697 VoiceData *voicedata = (VoiceData *)data;
1699 elm_naviframe_item_pop(voicedata->naviframe);
1702 static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Context *imf_context, int value)
1706 VoiceData *voicedata = (VoiceData *)data;
1709 case ECORE_IMF_INPUT_PANEL_STATE_HIDE: // 1
1710 elm_naviframe_item_pop(voicedata->naviframe);
1712 case ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW: // 2
1713 PRINTFUNC(DLOG_DEBUG, "keypad state will show.");
1715 case ECORE_IMF_INPUT_PANEL_STATE_SHOW: // 0
1716 PRINTFUNC(DLOG_DEBUG, "keypad state show.");
1721 static void __stt_detailed_entry_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
1724 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(obj);
1725 ecore_imf_context_input_panel_event_callback_del(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb);
1726 PRINTFUNC(DLOG_DEBUG, "input_panel_event_cb is deleted.");
1730 static Evas_Object *create_text_detiled_view(Evas_Object *parent)
1732 string edj_path = get_resource_path();
1733 edj_path = edj_path + STT_EDJ_FILE;
1736 Evas_Object *layout = elm_layout_add(parent);
1737 elm_layout_file_set(layout, edj_path.c_str(), "entry_focused_layout");
1738 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1739 evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1740 evas_object_show(layout);
1743 Evas_Object *entry = elm_entry_add(parent);
1744 evas_object_size_hint_weight_set(entry, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1745 evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, EVAS_HINT_FILL);
1746 // ea_entry_selection_back_event_allow_set(entry, EINA_TRUE);
1747 elm_entry_context_menu_disabled_set(entry, EINA_TRUE);
1748 elm_entry_select_allow_set(entry, EINA_FALSE);
1749 // elm_entry_cursor_handler_disabled_set(entry, EINA_TRUE);
1750 elm_entry_single_line_set(entry, EINA_TRUE);
1751 elm_entry_scrollable_set(entry, EINA_TRUE);
1752 elm_entry_input_panel_return_key_type_set(entry, ELM_INPUT_PANEL_RETURN_KEY_TYPE_DONE);
1754 evas_object_show(entry);
1756 elm_object_part_content_set(layout, "contents", entry);
1760 static Eina_Bool _idler_cb2(void *data)
1762 VoiceData *voicedata = (VoiceData *)data;
1764 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_FALSE);
1766 return ECORE_CALLBACK_CANCEL;
1769 static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *it)
1771 PRINTFUNC(DLOG_DEBUG, "");
1773 if(!data) return EINA_FALSE;
1775 VoiceData *voicedata = (VoiceData *)data;
1777 Evas_Object *main_entry = (Evas_Object *)voicedata->main_entry;
1778 Evas_Object *detailed_layout = elm_object_item_part_content_get(it, "elm.swallow.content");
1779 Evas_Object *detailed_entry = elm_object_part_content_get(detailed_layout, "contents");
1781 const char *str = NULL;
1784 pos = elm_entry_cursor_pos_get(detailed_entry);
1785 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1787 str = elm_entry_entry_get(detailed_entry);
1789 voicedata->stt_results.clear();
1790 voicedata->stt_results.push_back(str);
1792 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_TRUE);
1793 elm_entry_entry_set(main_entry, str);
1794 elm_entry_cursor_pos_set(main_entry, pos);
1797 elm_entry_cursor_geometry_get(main_entry, &x, &y, &w, &h);
1798 PRINTFUNC(DLOG_DEBUG, "%d %d %d %d", x, y, w, h);
1800 elm_scroller_region_bring_in(voicedata->scroller, 0, y+h, 300, 168);
1802 ecore_idler_add(_idler_cb2, voicedata);
1807 static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_info)
1809 PRINTFUNC(DLOG_DEBUG, "");
1814 VoiceData *voicedata = (VoiceData *)data;
1819 pos = elm_entry_cursor_pos_get(obj);
1820 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1822 str = elm_entry_markup_to_utf8(elm_entry_entry_get(obj));
1824 if (str && strlen(str) > 0) {
1826 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
1827 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING) {
1828 voicedata->sttmanager->Cancel();
1829 PRINTFUNC(DLOG_DEBUG, "stt entry clicked callback during STT recording and processing");
1833 catch(is::stt::SttException &e) {
1834 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1838 Evas_Object *ly_detailed_view = create_text_detiled_view(voicedata->naviframe);
1840 Evas_Object *detailed_entry = elm_object_part_content_get(ly_detailed_view, "contents");
1841 elm_entry_entry_set(detailed_entry, str);
1842 elm_entry_cursor_pos_set(detailed_entry, pos);
1843 evas_object_smart_callback_add(detailed_entry, "activated", __done_key_cb, voicedata); // Register callback for Done key
1845 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(detailed_entry);
1846 ecore_imf_context_input_panel_event_callback_add(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb, voicedata);
1847 evas_object_event_callback_add(detailed_entry, EVAS_CALLBACK_DEL, __stt_detailed_entry_del_cb, NULL);
1850 Elm_Object_Item *navi_it = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, ly_detailed_view, NULL);
1851 elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb, (void *)voicedata);
1852 elm_naviframe_item_title_enabled_set(navi_it, EINA_FALSE, EINA_FALSE);
1860 void activate_circle_scroller_for_stt_textbox(void* data, Eina_Bool bActivate)
1862 PRINTFUNC(DLOG_DEBUG, "");
1865 VoiceData *voicedata = (VoiceData *)data;
1867 Evas_Object *scroller = NULL;
1868 Evas_Object *circle_scroller = NULL;
1870 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
1871 circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
1872 eext_rotary_object_event_activated_set(circle_scroller, bActivate);
1875 static Evas_Object *create_textblock(void* data)
1877 if(!data) return NULL;
1879 VoiceData *voicedata = (VoiceData *)data;
1881 Evas_Object *scroller = NULL;
1882 Evas_Object *box = NULL;
1883 Evas_Object *inner_layout = NULL;
1884 Evas_Object *entry = NULL;
1885 Evas_Object *tb = NULL;
1886 Evas_Object *circle_scroller = NULL;
1888 string edj_path = get_resource_path();
1889 edj_path = edj_path + STT_EDJ_FILE;
1891 scroller = elm_scroller_add(voicedata->layout_main);
1893 elm_scroller_loop_set(scroller, EINA_FALSE, EINA_FALSE);
1895 evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
1896 evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1898 // elm_scroller_page_size_set(scroller, 0, 50);
1899 // elm_scroller_page_scroll_limit_set(scroller, 0, 1);
1901 elm_object_scroll_lock_x_set(scroller, EINA_TRUE);
1903 // uxt_scroller_set_auto_scroll_enabled(scroller, EINA_FALSE);
1905 circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
1906 eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1907 eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
1909 box = elm_box_add(scroller);
1911 inner_layout = elm_layout_add(scroller);
1912 elm_layout_file_set(inner_layout, edj_path.c_str(), "layout_textblock");
1913 evas_object_size_hint_weight_set(inner_layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1915 elm_object_signal_callback_add(inner_layout, "do_scroll", "entry",
1916 [](void *data, Evas_Object *obj, const char* signal, const char* e)
1918 _bring_in_cb((void *) data);
1919 }, (void *) scroller);
1921 entry = elm_entry_add(inner_layout);
1922 voicedata->main_entry = entry;
1923 elm_entry_editable_set(entry, EINA_FALSE);
1925 #define FORMAT_TEXT_AREA_FONT_STYLE \
1926 "DEFAULT='font=Tizen:style=Regular font_size=32 color=#%02x%02x%02x%02x text_class=tizen wrap=mixed align=center' newline='br' b='+ font=Tizen:style=Bold'link='+ underline=on underline_color=#%02x%02x%02x%02x'"
1928 char customStyle[512];
1929 // ea_theme_color_get("AT02112", &r, &g, &b, &a, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
1930 snprintf(customStyle, 512, FORMAT_TEXT_AREA_FONT_STYLE, r, g, b, a, r, g, b, a);
1932 elm_entry_text_style_user_push(entry, customStyle);
1934 evas_object_smart_callback_add(entry, "clicked", _stt_entry_clicked_cb, voicedata);
1936 elm_object_part_content_set(inner_layout, "elm.swallow.content", entry);
1938 elm_box_pack_end(box, inner_layout);
1940 elm_object_content_set(scroller, box);
1941 evas_object_data_set(scroller, "inner_layout", (void *) inner_layout);
1942 evas_object_data_set(scroller, "circle", (void *) circle_scroller);
1943 evas_object_show(scroller);
1944 evas_object_show(inner_layout);
1949 static Evas_Object *create_progressbar(Evas_Object *parent)
1951 Evas_Object *progressbar = NULL;
1953 progressbar = elm_progressbar_add(parent);
1954 elm_object_style_set(progressbar, "voice_input/process/small");
1955 //elm_progressbar_pulse(progressbar, EINA_TRUE);
1957 evas_object_size_hint_align_set(progressbar, EVAS_HINT_FILL, EVAS_HINT_FILL);
1958 evas_object_size_hint_weight_set(progressbar, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1960 // ea_theme_object_color_replace(progressbar, "B065L6", "AO012");
1962 evas_object_show(progressbar);
1967 static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
1969 PRINTFUNC(NO_PRINT, "");
1971 Evas_Object *more_option_layout = NULL;
1972 Evas_Object *layout_main = NULL;
1973 Evas_Object *lang_btn_box = NULL;
1974 Evas_Object *lang_btn = NULL;
1975 Evas_Object *to = NULL;
1976 Evas_Object *ao = NULL;
1978 char *lang_type_str = NULL;
1981 int is_screen_reader_on = FALSE;
1983 VoiceData *voicedata = r_voicedata;
1986 * add app_default_layout
1989 MoreOption* mo = new MoreOption(parent, voicedata);
1995 layout_main = elm_layout_add(mo->getMoreOptionLayout());
2000 voicedata->layout_main = layout_main;
2002 string edj_path = get_resource_path();
2003 edj_path = edj_path + STT_EDJ_FILE;
2005 if (vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TTS, &is_screen_reader_on) == -1) {
2006 PRINTFUNC(DLOG_ERROR, "Cannot read value of screen reader from vconf");
2009 evas_object_size_hint_weight_set(layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2010 evas_object_size_hint_align_set(layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
2012 elm_layout_file_set(layout_main, edj_path.c_str(), "mic_control");
2014 //elm_object_content_set(parent, layout_main);
2016 //Canvas for Cairo effect
2017 Evas_Object *canvas = evas_object_image_filled_add(evas_object_evas_get(layout_main));
2018 // evas_object_image_alpha_set(canvas, EINA_TRUE);
2019 evas_object_size_hint_align_set(canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
2020 evas_object_size_hint_weight_set(canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2021 evas_object_move(canvas, 0, 0);
2023 Evas_Coord CanvasW, CanvasH;
2026 evas_object_image_size_set(canvas, CanvasW, CanvasH);
2027 evas_object_resize(canvas, CanvasW, CanvasH);
2028 evas_object_size_hint_min_set(canvas, CanvasW, CanvasH);
2029 evas_object_show(canvas);
2031 elm_object_part_content_set(layout_main, "EFFECT_BG", canvas);
2035 Evas_Object *m_mic_button = elm_button_add(layout_main);
2036 elm_object_style_set(m_mic_button, "vic/micbutton");
2037 elm_object_part_content_set(layout_main, "MIC", m_mic_button);
2039 elm_object_disabled_set(m_mic_button, EINA_TRUE);
2040 evas_object_smart_callback_add(m_mic_button, "clicked", on_mic_button_press_cb, (void *) voicedata);
2042 voicedata->mic_button = m_mic_button;
2044 if(voicedata->btn_disabling_timer == NULL){
2045 voicedata->btn_disabling_timer = ecore_timer_add(2.0, _mic_button_enable_cb, voicedata);
2048 // ecore_idler_add(_idler_cb, voicedata);
2049 ecore_timer_add(0.6, _idler_cb, voicedata);
2051 // Confirm panel layout
2052 Evas_Object *panel_layout;
2053 panel_layout = elm_layout_add(layout_main);
2054 elm_layout_theme_set(panel_layout, "layout", "drawer", "panel");
2055 evas_object_show(panel_layout);
2059 panel = elm_panel_add(panel_layout);
2060 elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
2061 elm_layout_theme_set(panel, "panel", "left_confirm", "default");
2062 if(app_data->source_app_control){
2064 char *app_id = NULL;
2065 ret = app_control_get_extra_data(app_data->source_app_control, "selector_keyboard_app_id", &app_id);
2066 if (ret == APP_CONTROL_ERROR_NONE) {
2067 PRINTFUNC(DLOG_DEBUG, "app_id = %s", app_id);
2071 if(!strcmp(app_id, "com.samsung.message.appcontrol.compose")
2072 || !strcmp(app_id, "com.samsung.wemail-send")){
2073 elm_layout_theme_set(panel, "panel", "left_sending", "default");
2079 elm_layout_signal_callback_add(panel, "cue,clicked", "elm", _panel_cue_clicked_cb, (void *) voicedata);
2080 evas_object_show(panel);
2082 elm_object_part_content_set(panel_layout, "elm.swallow.right", panel);
2083 elm_object_part_content_set(layout_main, "left_panel_area", panel_layout);
2085 elm_object_signal_emit(panel, "elm,state,disabled", "elm");
2086 elm_panel_toggle(panel);
2090 Evas_Object *scroller = create_textblock(voicedata);
2091 elm_object_part_content_set(layout_main, "text_area", scroller);
2092 voicedata->scroller = scroller;
2095 Evas_Object *progress_bar = create_progressbar(layout_main);
2096 elm_object_part_content_set(layout_main, "PROGRESS_BAR", progress_bar);
2097 voicedata->progressbar = progress_bar;
2100 elm_object_signal_callback_add(layout_main, "idle,state,pulse,visible", "", on_initial_anim_press_cb, voicedata);
2102 mo->SetContentLayout(layout_main);
2107 int is_lang_supported_by_stt(char lang[])
2109 /* to check if the language is supported by stt */
2111 for (index = (sizeof(supported_language) / sizeof(supported_language[0]))-1; index != 0; index--)
2113 if (!strcmp(lang, supported_language[index])) {
2114 PRINTFUNC(DLOG_DEBUG, "current lang supported (%s)", supported_language[index]);
2119 PRINTFUNC(DLOG_DEBUG, "current lang not supported (%s)", lang);
2124 int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
2126 PRINTFUNC(DLOG_DEBUG, "[init_voice]");
2128 // stt_is_samsung_asr(&g_is_n66);
2130 VoiceData *voicedata = (VoiceData *)r_voicedata;
2136 PRINTFUNC(DLOG_ERROR, "Parent is NULL\n");
2139 PRINTFUNC(NO_PRINT, "Parent is there");
2142 voicedata->voicefw_state = 0;
2144 /* Set Voice Language */
2145 if(voicedata->kbd_lang){
2146 free(voicedata->kbd_lang);
2147 voicedata->kbd_lang = NULL;
2150 //stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
2151 get_stt_default_language(voicedata);
2152 if(NULL == voicedata->kbd_lang || FALSE == is_lang_supported_by_stt(voicedata->kbd_lang)) {
2153 voicedata->kbd_lang = strdup("en_US");
2156 PRINTFUNC(DLOG_DEBUG, "Voice input active language is : %s", voicedata->kbd_lang);
2158 voicedata->naviframe = parent;
2160 if (NULL == voicedata->naviframe) {
2167 static Eina_Bool init_view(void *data)
2169 VoiceData *voicedata = (VoiceData *)data;
2171 if(voicedata == NULL)
2172 return ECORE_CALLBACK_CANCEL;
2174 voicedata->layout_main = create_fullview(voicedata->naviframe, voicedata);
2176 if (voicedata->layout_main) {
2177 evas_object_show(voicedata->layout_main);
2180 return ECORE_CALLBACK_CANCEL;
2184 Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
2186 PRINTFUNC(NO_PRINT, "[show_voice_window]");
2188 VoiceData *voicedata = (VoiceData *)r_voicedata;
2194 PRINTFUNC(NO_PRINT, "Parent is NULL\n");
2197 PRINTFUNC(NO_PRINT, "Parent is there");
2200 if (NULL != voicedata->layout_main) {
2201 PRINTFUNC(DLOG_DEBUG, "delete previous layout");
2202 evas_object_del((voicedata)->layout_main);
2203 (voicedata)->layout_main = NULL;
2206 if (NULL != voicedata->effector) {
2207 PRINTFUNC(DLOG_DEBUG, "delete previous effect");
2208 delete (voicedata->effector);
2209 (voicedata)->effector = NULL;
2212 if (NULL != voicedata->ieffect) {
2213 PRINTFUNC(DLOG_DEBUG, "delete previous ieffect");
2214 delete (voicedata->ieffect);
2215 voicedata->ieffect = NULL;
2219 delete voicedata->mo;
2220 voicedata->mo = NULL;
2223 init_view((void *)voicedata);
2224 return voicedata->layout_main;
2228 void on_stt_pause(VoiceData *r_voicedata){
2229 PRINTFUNC(DLOG_DEBUG, "");
2231 VoiceData *voicedata = (VoiceData *)r_voicedata;
2235 //voicedata->state = STT_STATE_VAL_PREPARE_CANCEL;
2236 voicedata->sttmanager->Cancel();
2237 }catch(is::stt::SttException &e){
2238 PRINTFUNC(DLOG_ERROR, "reason : %s", e.what());
2241 //Hide more option and language settings by interrupt scenario.
2242 close_setting_window_idler_cb(NULL);
2243 Evas_Object *mo_layout = voicedata->mo->getMoreOptionLayout();
2245 if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
2246 eext_more_option_opened_set(mo_layout, EINA_FALSE);
2252 void on_destroy(VoiceData *r_voicedata)
2254 PRINTFUNC(NO_PRINT, "");
2256 VoiceData *voicedata = (VoiceData *)r_voicedata;
2258 int result = STT_ERROR_NONE;
2262 if (NULL != voicedata) {
2263 if (NULL != voicedata->layout_main) {
2264 voicedata->layout_main = NULL;
2267 if (NULL != voicedata->naviframe) {
2268 voicedata->naviframe = NULL;
2271 if (NULL != voicedata->start_timer) {
2272 ecore_timer_del(voicedata->start_timer);
2273 voicedata->start_timer = NULL;
2276 if (NULL != voicedata->refresh_timer) {
2277 ecore_timer_del(voicedata->refresh_timer);
2278 voicedata->refresh_timer = NULL;
2281 if (NULL != voicedata->progressbar_timer) {
2282 ecore_timer_del(voicedata->progressbar_timer);
2283 voicedata->progressbar_timer = NULL;
2284 elm_progressbar_pulse(voicedata->progressbar, EINA_FALSE);
2287 if (NULL != voicedata->textblock_timer) {
2288 ecore_timer_del(voicedata->textblock_timer);
2289 voicedata->textblock_timer = NULL;
2292 if (NULL != voicedata->guide_text_timer) {
2293 ecore_timer_del(voicedata->guide_text_timer);
2294 voicedata->guide_text_timer = NULL;
2297 if (NULL != voicedata->btn_disabling_timer) {
2298 ecore_timer_del(voicedata->btn_disabling_timer);
2299 voicedata->btn_disabling_timer = NULL;
2302 if (NULL != voicedata->power_unlock_timer) {
2303 ecore_timer_del(voicedata->power_unlock_timer);
2304 voicedata->power_unlock_timer = NULL;
2307 if(voicedata->kbd_lang) {
2308 free(voicedata->kbd_lang);
2309 voicedata->kbd_lang = NULL;
2312 if(voicedata->ieffect) {
2313 delete voicedata->ieffect;
2314 voicedata->ieffect = NULL;
2317 if(voicedata->effector) {
2318 delete voicedata->effector;
2319 voicedata->effector = NULL;
2323 delete voicedata->mo;
2324 voicedata->mo = NULL;
2327 if(voicedata->sttmanager) {
2328 delete voicedata->sttmanager;
2329 voicedata->sttmanager = NULL;
2332 if(voicedata->sttfeedback) {
2333 delete voicedata->sttfeedback;
2334 voicedata->sttfeedback = NULL;