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[])
173 if(strcmp(lang, "en_US") == 0)
174 str = disp_lang_array[3];
176 else if(strcmp(lang, "ko_KR") == 0)
177 str = disp_lang_array[12];
179 else if(strcmp(lang, "de_DE") == 0)
180 str = disp_lang_array[1];
182 else if(strcmp(lang, "fr_FR") == 0)
183 str = disp_lang_array[6];
185 else if(strcmp(lang, "it_IT") == 0)
186 str = disp_lang_array[7];
188 else if(strcmp(lang, "en_GB") == 0)
189 str = disp_lang_array[2];
191 else if(strcmp(lang, "ja_JP") == 0)
192 str = disp_lang_array[11];
194 else if(strcmp(lang, "zh_CN") == 0)
195 str = disp_lang_array[10];
197 else if(strcmp(lang, "ru_RU") == 0)
198 str = disp_lang_array[9];
200 else if(strcmp(lang, "pt_BR") == 0)
201 str = disp_lang_array[8];
203 else if(strcmp(lang, "es_ES") == 0)
204 str = disp_lang_array[4];
206 else if(strcmp(lang, "es_US") == 0)
207 str = disp_lang_array[5];
210 str = disp_lang_array[3];
215 char* get_lang_label_n66(char lang[])
220 if(strcmp(lang, "en_US") == 0)
221 str = disp_lang_array_n66[1];
223 else if(strcmp(lang, "ko_KR") == 0)
224 str = disp_lang_array_n66[6];
226 else if(strcmp(lang, "fr_FR") == 0)
227 str = disp_lang_array_n66[3];
229 else if(strcmp(lang, "ja_JP") == 0)
230 str = disp_lang_array_n66[5];
232 else if(strcmp(lang, "zh_CN") == 0)
233 str = disp_lang_array_n66[4];
235 else if(strcmp(lang, "es_US") == 0)
236 str = disp_lang_array_n66[2];
239 str = disp_lang_array_n66[1];
246 _bring_in_cb(void *data)
250 return ECORE_CALLBACK_CANCEL;
252 Evas_Coord x, y ,w, h;
254 Evas_Object *scroller = (Evas_Object *)data;
255 Evas_Object *inner_layout = NULL;
257 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
259 evas_object_geometry_get(inner_layout , &x, &y, &w, &h);
260 elm_scroller_region_bring_in(scroller, x, h, w, h);
262 PRINTFUNC(NO_PRINT,"scroller %d %d %d %d",x, y, w, h);
264 return ECORE_CALLBACK_CANCEL;
267 static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
269 int calculated_height = 0;
271 int max_height = 1280;
272 int unit_width = 282;
274 Evas_Coord width, height;
277 Evas_Object *tb = NULL;
278 Evas_Textblock_Style *st = NULL;
279 Evas_Textblock_Cursor *cur = NULL;
281 tb = evas_object_textblock_add(evas_object_evas_get(obj));
282 evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
284 st = evas_textblock_style_new();
285 evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
286 evas_object_textblock_style_set(tb, st);
288 cur = evas_object_textblock_cursor_new(tb);
289 strbuf = elm_entry_utf8_to_markup(text.c_str());
290 evas_object_resize(tb, unit_width, max_height);
292 evas_object_textblock_text_markup_set(tb, strbuf);
293 evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
294 evas_object_textblock_size_formatted_get(tb, &width, &height);
295 evas_object_resize(tb, unit_width, height);
297 if(strbuf) free(strbuf);
298 if(tb) evas_object_del(tb);
299 if(st) evas_textblock_style_free(st);
300 if(cur) evas_textblock_cursor_free(cur);
305 static Eina_Bool _update_textblock_timer_cb (void *data)
308 return ECORE_CALLBACK_CANCEL;
310 VoiceData* voicedata = (VoiceData*)data;
312 voicedata->textblock_timer = NULL;
314 std::string result_text;
315 for(int i=0;i<voicedata->stt_results.size();i++){
316 if(i == voicedata->stt_results.size()-1){
317 result_text += voicedata->stt_results.at(i);
319 result_text += voicedata->stt_results.at(i);
324 Evas_Object *rect = NULL;
325 Evas_Object *entry = NULL;
326 Evas_Object *scroller = NULL;
327 Evas_Object *box = NULL;
328 Evas_Object *inner_layout = NULL;
331 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
334 PRINTFUNC(DLOG_ERROR, "failed to get scroller");
335 return ECORE_CALLBACK_CANCEL;
338 box = elm_object_content_get(scroller);
341 PRINTFUNC(DLOG_ERROR, "failed to get box");
342 return ECORE_CALLBACK_CANCEL;
345 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
348 PRINTFUNC(DLOG_ERROR, "failed to get inner_layout");
349 return ECORE_CALLBACK_CANCEL;
352 entry = elm_layout_content_get(inner_layout, "elm.swallow.content");
355 PRINTFUNC(DLOG_ERROR, "failed to get entry");
356 return ECORE_CALLBACK_CANCEL;
359 Evas_Object *top = (Evas_Object *) evas_object_data_get(box, "top_padding");
360 Evas_Object *bottom = (Evas_Object *) evas_object_data_get(box, "bottom_padding");
363 elm_box_unpack(box, top);
364 evas_object_del(top);
368 elm_box_unpack(box, bottom);
369 evas_object_del(bottom);
373 Evas_Coord height = get_text_block_size(box, result_text);
375 // if(height < 173) {
377 int text_area_height = 360-102; // screen H - bottom button H
378 int top_height = ((text_area_height - height) / 2);
379 if(top_height < 120) top_height = 120; // Top fade area H
381 int bottom_height = (text_area_height - top_height - height);
382 if(bottom_height < 1) bottom_height = 0;
384 PRINTFUNC(SECURE_DEBUG, "str : %s", result_text.c_str());
385 PRINTFUNC(DLOG_DEBUG, "height : %d", height);
386 PRINTFUNC(DLOG_DEBUG, "top_height : %d", top_height);
387 PRINTFUNC(DLOG_DEBUG, "bottom_height : %d", bottom_height);
389 rect = evas_object_rectangle_add(evas_object_evas_get(box));
390 evas_object_color_set(rect, 0, 0, 0, 100);
391 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
392 evas_object_size_hint_min_set(rect, 282, top_height);
393 evas_object_show(rect);
395 elm_box_pack_before(box, rect, inner_layout);
396 evas_object_data_set(box, "top_padding", (void *) rect);
398 rect = evas_object_rectangle_add(evas_object_evas_get(box));
399 evas_object_color_set(rect, 0, 0, 0, 100);
400 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
401 evas_object_size_hint_min_set(rect, 282, bottom_height);
402 evas_object_show(rect);
404 elm_box_pack_end(box, rect);
405 evas_object_data_set(box, "bottom_padding", (void *) rect);
408 elm_entry_entry_set(entry, result_text.c_str());
410 Evas_Object *panel_layout = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "left_panel_area");
411 Evas_Object *panel_left = elm_layout_content_get((Evas_Object *)panel_layout, "elm.swallow.right");
413 if(result_text.size()>0){
414 elm_object_signal_emit(panel_left, "elm,state,enabled", "elm");
417 elm_object_signal_emit(panel_left, "elm,state,disabled", "elm");
420 elm_object_signal_emit((Evas_Object *)voicedata->layout_main, "idle,state,guide_text,bottom", "elm");
422 if(voicedata->state == STT_STATE_VAL_LISTENING){
423 if(voicedata->guide_text_timer != NULL){
424 PRINTFUNC(DLOG_DEBUG, "Skip hide_guide_text");
425 ecore_timer_del(voicedata->guide_text_timer);
426 voicedata->guide_text_timer = NULL;
428 set_guide_text(voicedata, SK_TAP_TO_PAUSE, true);
431 elm_object_signal_emit(inner_layout, "scrolling", "entry");
433 return ECORE_CALLBACK_CANCEL;
440 void _update_textblock(void *data)
446 VoiceData *voicedata = (VoiceData *) data;
448 if(voicedata->textblock_timer == NULL){
449 voicedata->textblock_timer = ecore_timer_add(1.0, _update_textblock_timer_cb, voicedata);
451 PRINTFUNC(DLOG_DEBUG, "skip : the timer is not expired.");
457 void voice_get_string(const char *keyValue, _VoiceData *voicedata)
464 strbuf = elm_entry_utf8_to_markup(keyValue);
466 PRINTFUNC(DLOG_DEBUG, "text : %s, voicedata->partial_result=%s", strbuf, voicedata->partial_result);
469 if(voicedata->partial_result){ // partial_result is not Null so replace
470 if(strcmp(voicedata->partial_result, strbuf)){
472 PRINTFUNC(DLOG_DEBUG, "different replace");
474 voicedata->stt_results.pop_back();
475 voicedata->stt_results.push_back(strbuf);
477 free(voicedata->partial_result);
478 voicedata->partial_result = strdup(strbuf);
480 } else { // partial_result is Null so first case
482 PRINTFUNC(DLOG_DEBUG, "first push");
483 voicedata->stt_results.push_back(strbuf);
484 voicedata->partial_result = strdup(strbuf);
488 _update_textblock(voicedata);
493 PRINTFUNC(DLOG_DEBUG, "ends");
496 static Eina_Bool _recognition_failure_cb (void *data)
499 VoiceData *voicedata = (VoiceData *) data;
501 voicedata->state = STT_STATE_VAL_INIT;
502 set_animation_state(voicedata);
503 voicedata->refresh_timer = NULL;
505 return ECORE_CALLBACK_CANCEL;
508 void start_by_press(VoiceData *voicedata)
511 PRINTFUNC(DLOG_DEBUG,"");
513 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
519 static void on_mic_button_press_cb(void *data, Evas_Object *obj, void *event_info)
522 PRINTFUNC(NO_PRINT,"");
524 VoiceData *voicedata = (VoiceData *)data;
526 if (elm_config_access_get()){
527 if( bottom_button_access_state == true){
528 PRINTFUNC(DLOG_DEBUG,"skip until bottom buttom is being read by accessibility");
533 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1","background");
538 static char *_left_cue_access_info_cb(void *data, Evas_Object *obj)
542 snprintf(text, sizeof(text), "%s, %s", gettext(TTS_SEND), gettext(TTS_BUTTON));
547 static void _left_cue_access_activate_cb(void * data, Evas_Object *part_obj, Elm_Object_Item *item)
550 Evas_Object *obj = (Evas_Object *)data;
551 elm_layout_signal_emit(obj, "cue,clicked", "elm");
553 elm_panel_toggle(obj);
557 static void _send_button_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
560 PRINTFUNC(DLOG_DEBUG,"");
561 VoiceData* voicedata = (VoiceData*)data;
563 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
564 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
567 std::string text = std::string(gettext(TTS_SEND));
568 text = text +" "+ gettext(TTS_BUTTON);
569 if (elm_object_disabled_get(obj))
570 text = text + " " + gettext(TTS_DISABLED);
572 elm_access_say(text.c_str());
575 static Eina_Bool _mic_button_enable_cb(void *data)
578 PRINTFUNC(DLOG_DEBUG,"");
581 return ECORE_CALLBACK_CANCEL;
583 VoiceData* voicedata = (VoiceData*)data;
585 voicedata->btn_disabling_timer = NULL;
587 Evas_Object *button = (Evas_Object *)voicedata->mic_button;
589 elm_object_disabled_set(button, EINA_FALSE);
591 if (elm_config_access_get()){
592 bottom_button_access_state = false;
595 return ECORE_CALLBACK_CANCEL;
598 static void _mic_highlighted_cb(void *data, Evas_Object * obj, void *event_info)
601 PRINTFUNC(DLOG_DEBUG,"");
602 VoiceData* voicedata = (VoiceData*)data;
604 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
605 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING)
609 if (elm_config_access_get()){
610 bottom_button_access_state = true;
612 elm_object_disabled_set(voicedata->mic_button, EINA_TRUE);
616 if(voicedata->btn_disabling_timer == NULL){
617 ecore_timer_del(voicedata->btn_disabling_timer);
619 voicedata->btn_disabling_timer = ecore_timer_add(3.0, _mic_button_enable_cb, voicedata);
622 elm_access_say(gettext(SK_DOUBLE_TAP_TO_SPEAK));
628 static char *_mic_access_info_cb(void *data, Evas_Object *obj)
630 if (data) return strdup((const char*)data);
635 static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *event_info)
638 if(g_send_button_clicked == true){
639 PRINTFUNC(DLOG_DEBUG,"skipped seding STT result");
643 g_send_button_clicked = true;
648 VoiceData* voicedata = (VoiceData*)data;
650 std::string result_text;
651 for(int i=0;i<voicedata->stt_results.size();i++){
652 result_text += voicedata->stt_results.at(i);
653 if(i != voicedata->stt_results.size()-1)
657 PRINTFUNC(DLOG_DEBUG,"result_text = %s", result_text.c_str());
658 input_smartreply_send_feedback(result_text.c_str());
660 if(app_data->reply_type == REPLY_APP_CONTROL){
661 reply_to_sender_by_appcontrol((void*)app_data, result_text.c_str(), "voice");
663 reply_to_sender_by_callback(result_text.c_str(), "voice");
673 _panel_cue_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
675 PRINTFUNC(DLOG_DEBUG,"left cue clicked!!");
677 on_confirm_button_clicked_cb(data, NULL, NULL);
682 void stt_feedback_initialize()
686 ret = feedback_initialize();
689 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
695 void stt_feedback(FeedbackType type)
699 ret = feedback_initialize();
702 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
706 if(type == VIBRATION_START){
707 // feedback_play(FEEDBACK_PATTERN_VOICE_START);
708 } else if(type == VIBRATION_STOP){
709 // feedback_play(FEEDBACK_PATTERN_VOICE_STOP);
712 ret = feedback_deinitialize();
715 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
721 void stt_feedback_deinitialize()
725 ret = feedback_deinitialize();
728 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
735 static Eina_Bool _idler_cb(void *data)
738 if(!data) return ECORE_CALLBACK_CANCEL;
740 VoiceData *voicedata = (VoiceData *)data;
742 PRINTFUNC(DLOG_DEBUG,"");
745 if(true == _app_stt_initialize(voicedata)) {
746 PRINTFUNC(NO_PRINT,"_app_stt_initialize None Error");
747 voicedata->voicefw_state = 1;
748 voicedata->state = STT_STATE_VAL_INIT;
751 voicedata->voicefw_state = 0;
752 PRINTFUNC(DLOG_ERROR,"Initialization Fail!<br>Check STT-daemon is running");
755 Evas_Object *canvas = elm_object_part_content_get(voicedata->layout_main, "EFFECT_BG");
758 is::ui::WInputSttMicEffect *ieffect = new is::ui::WInputSttMicEffect();
759 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
761 is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
762 voicedata->ieffect = ieffect;
763 voicedata->effector= effector;
765 ieffect->SetProgressBar(voicedata->progressbar);
766 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
768 voicedata->mo->Update();
770 elm_access_highlight_set(voicedata->mic_button);
773 return ECORE_CALLBACK_CANCEL;
777 static Eina_Bool _power_delayed_unlock(void *data){
779 PRINTFUNC(DLOG_DEBUG,"POWER Unlock");
781 VoiceData *voicedata = (VoiceData *) data;
782 device_power_release_lock(POWER_LOCK_DISPLAY);
783 voicedata->power_unlock_timer = NULL;
785 return ECORE_CALLBACK_CANCEL;
790 PRINTFUNC(DLOG_DEBUG,"POWER Unlock directly.");
791 device_power_release_lock(POWER_LOCK_DISPLAY);
794 void powerLock(void *data, bool enable)
797 int ret = DEVICE_ERROR_NONE;
799 VoiceData *voicedata = (VoiceData *) data;
803 ret = device_power_wakeup(false);
804 PRINTFUNC(DLOG_DEBUG,"LCD Wakeup");
806 if(ret != DEVICE_ERROR_NONE)
807 PRINTFUNC(DLOG_ERROR,"LCD Wakeup ERROR =%d",ret);
809 ret = device_power_request_lock(POWER_LOCK_DISPLAY, 0);
810 PRINTFUNC(DLOG_DEBUG,"POWER LOCK");
811 power_state = enable;
813 if(ret != DEVICE_ERROR_NONE)
814 PRINTFUNC(DLOG_ERROR,"ERROR =%d",ret);
816 if(voicedata->power_unlock_timer != NULL){
817 ecore_timer_del(voicedata->power_unlock_timer);
818 voicedata->power_unlock_timer = NULL;
822 PRINTFUNC(DLOG_DEBUG,"POWER Unlock Delayed(5 sec)");
824 if(voicedata->power_unlock_timer != NULL){
825 ecore_timer_del(voicedata->power_unlock_timer);
826 voicedata->power_unlock_timer = NULL;
828 voicedata->power_unlock_timer = ecore_timer_add(5.0, _power_delayed_unlock, voicedata);
834 static Eina_Bool hide_guide_text(void *data){
838 VoiceData *voicedata = (VoiceData *) data;
840 voicedata->guide_text_timer = NULL;
843 PRINTFUNC(DLOG_ERROR,"");
844 elm_object_part_text_set(voicedata->layout_main, "elm.text", "");
847 return ECORE_CALLBACK_CANCEL;
850 static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
852 //elm_object_signal_emit(vd->layout_main, "idle,state,text,visible", "elm");
855 elm_object_domain_translatable_part_text_set(vd->layout_main, "elm.text", PACKAGE, text);
857 elm_object_part_text_set(vd->layout_main, "elm.text", text);
859 if(!strcmp(text, SK_SPEAK_NOW)){
860 if(vd->guide_text_timer == NULL)
861 vd->guide_text_timer = ecore_timer_add(2.0, hide_guide_text, vd);
866 * @brief - function to send the signal to edc
867 * to change the animation as per stt state
870 void set_animation_state(VoiceData *voicedata)
872 PRINTFUNC(DLOG_DEBUG,"");
874 PRINTFUNC(DLOG_ERROR, "voicedata->state == %s",
875 voicedata->state == STT_STATE_VAL_INIT ?
876 "STT_STATE_VAL_INIT" :
877 voicedata->state == STT_STATE_VAL_LISTENING ?
878 "STT_STATE_VAL_LISTENING" :
879 voicedata->state == STT_STATE_VAL_PREPARE_LISTENING ?
880 "STT_STATE_VAL_PREPARE_LISTENING" :
881 voicedata->state == STT_STATE_VAL_PROCESSING ?
882 "STT_STATE_VAL_PROCESSING" :
883 voicedata->state == STT_STATE_VAL_PREPARE_PROCESSING ?
884 "STT_STATE_VAL_PREPARE_PROCESSING" :
885 voicedata->state == STT_STATE_VAL_TERMINATING ?
886 "STT_STATE_VAL_TERMINATING" : "STT_STATE_VAL_NOT_RECOGNISED");
888 if (voicedata->state == STT_STATE_VAL_INIT) {
891 if (voicedata->sttmanager->GetCurrent() == STT_STATE_READY) {
892 set_guide_text(voicedata, "", false);
893 //_elm_access_say(voicedata->layout_main, _(SK_INIT));
896 PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
897 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
898 //_elm_access_say(voicedata->layout_main, _(SK_NETWORK_CONNECTION_ERROR));
902 if(voicedata->effector)
903 voicedata->effector->Stop(true);
905 set_guide_text(voicedata, "");
907 PRINTFUNC(DLOG_DEBUG,"%d", voicedata->stt_results.size());
908 powerLock((void*)voicedata, false);
910 else if (voicedata->state == STT_STATE_VAL_LISTENING) {
912 set_guide_text(voicedata, SK_SPEAK_NOW, true);
914 if(voicedata->effector)
915 voicedata->effector->Start();
917 powerLock((void*)voicedata, true);
919 else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
921 set_guide_text(voicedata, "");
922 if(voicedata->effector)
923 voicedata->effector->Stop();
925 stt_feedback(VIBRATION_STOP);
928 PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
929 set_guide_text(voicedata, _(SK_RECOGNITION_FAILED));
930 //_elm_access_say(voicedata->layout_main, _(SK_RECOGNITION_FAILED));
932 voicedata->state = STT_STATE_VAL_NOT_RECOGNISED;
934 if(voicedata->refresh_timer) {
935 ecore_timer_del(voicedata->refresh_timer);
938 if(voicedata->effector)
939 voicedata->effector->Stop(true);
941 voicedata->refresh_timer = ecore_timer_add(2.0, _recognition_failure_cb, voicedata);
943 //powerLock((void*)voicedata, false);
947 void show_error_message(VoiceData *vd, stt_error_e reason)
949 if(reason == STT_ERROR_OUT_OF_NETWORK)
951 PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
953 int ancs_connected = 0;
955 ret = vconf_get_int("file/private/weconn/ancs_connected", &ancs_connected);
958 PRINTFUNC(DLOG_ERROR, "ancs connected status : %d" ,ancs_connected);
960 PRINTFUNC(DLOG_ERROR, "vconf for ancs connection ERROR - %d", ret);
964 snprintf(text, sizeof(text), _(SK_NETWORK_ERROR_FOR_IOS), _(SK_SAMSUNG_GEAR));
966 show_popup_toast((const char*)text, false);
968 set_guide_text(vd, _(SK_NETWORK_ERROR));
971 vd->state = STT_STATE_VAL_INIT;
973 } else if(reason == STT_ERROR_RECORDER_BUSY) {
974 PRINTFUNC(DLOG_WARN,"STT is used by another application");
975 show_popup_toast(_(SK_STT_BUSY), false);
976 vd->state = STT_STATE_VAL_INIT;
978 PRINTFUNC(DLOG_WARN,"Check error code");
979 show_popup_toast(_(SK_STT_BUSY), false);
980 vd->state = STT_STATE_VAL_INIT;
984 static Eina_Bool _start_timer_cb(void* data)
987 VoiceData *voicedata = (VoiceData *) data;
990 voicedata->state = STT_STATE_VAL_PREPARE_LISTENING;
991 voicedata->sttmanager->Start();
993 catch (is::stt::SttException &e) {
994 PRINTFUNC(DLOG_ERROR, "%s", e.what());
996 if(e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
998 PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
999 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
1000 voicedata->state = STT_STATE_VAL_INIT;
1001 } else if(e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
1002 PRINTFUNC(DLOG_WARN,"STT is used by another application");
1003 show_popup_toast(_(SK_STT_BUSY), false);
1004 voicedata->state = STT_STATE_VAL_INIT;
1006 PRINTFUNC(DLOG_WARN,"Check error code");
1007 show_popup_toast(_(SK_STT_BUSY), false);
1008 voicedata->state = STT_STATE_VAL_INIT;
1011 voicedata->start_timer = NULL;
1013 return ECORE_CALLBACK_CANCEL;
1017 * @brief - cancel button press callback for cross button
1021 void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
1023 PRINTFUNC(NO_PRINT,"");
1025 VoiceData *vd = (VoiceData *)data;
1027 int tempVal = vd->sttmanager->GetCurrent();
1028 if(tempVal == STT_STATE_CREATED) {
1029 PRINTFUNC(DLOG_WARN, "IGNORE TOUCH event before STT READY. STT is preparing", vd->state);
1033 PRINTFUNC(DLOG_DEBUG, "SttManager State : %d", vd->sttmanager->GetCurrent());
1034 PRINTFUNC(DLOG_DEBUG, "Ui Voice State : %d", vd->state);
1038 case STT_STATE_VAL_INIT:
1040 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_INIT");
1041 get_stt_default_language(vd);
1042 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
1044 stt_feedback(VIBRATION_START);
1046 if(vd->start_timer) {
1047 ecore_timer_del(vd->start_timer);
1048 vd->start_timer = NULL;
1051 vd->start_timer = ecore_timer_add(0.0, _start_timer_cb, vd);
1054 case STT_STATE_VAL_LISTENING :
1055 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_LISTENING");
1057 vd->state = STT_STATE_VAL_PREPARE_PROCESSING;
1058 vd->sttmanager->Stop();
1061 * Cuased touch reponse time, it can be called to stop animator.
1064 set_guide_text(vd, "");
1067 vd->effector->Stop();
1069 catch (is::stt::SttException &e) {
1070 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1072 if(e.GetEcode() != STT_ERROR_INVALID_STATE)
1074 PRINTFUNC(DLOG_DEBUG,"SK_NETWORK_ERROR");
1075 set_guide_text(vd, _(SK_RECOGNITION_FAILED));
1076 vd->state = STT_STATE_VAL_INIT;
1079 vd->effector->Stop(true);
1084 case STT_STATE_VAL_PROCESSING:
1085 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_PROCESSING");
1087 //vd->state = STT_STATE_VAL_PREPARE_CANCEL;
1088 vd->sttmanager->Cancel();
1090 catch (is::stt::SttException &e) {
1091 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1096 case STT_STATE_VAL_NOT_RECOGNISED:
1097 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_NOT_RECOGNISED");
1098 vd->state = STT_STATE_VAL_INIT ;
1101 PRINTFUNC(DLOG_DEBUG, "default [%d]", vd->state);
1106 static inline void ea_naviframe_back(void *data, Evas_Object *obj, void *event_info)
1110 evas_object_del((Evas_Object *) data);
1112 g_setting_window = NULL;
1113 g_setting_naviframe = NULL;
1116 ecore_event_handler_del(g_evt_key_down);
1118 g_evt_key_down = NULL;
1121 if(g_more_option_layout){
1122 if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
1123 eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
1130 static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char *part)
1132 return strdup(_("WDS_VOICE_OPT_LANGUAGE_ABB"));
1135 char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
1137 char text[128] = {0,};
1139 if(!strcmp(part, "elm.text"))
1141 if((int)data == 0) {
1142 return strdup(_("IDS_VC_BODY_AUTOMATIC"));
1147 s = (char *)disp_lang_array_n66[(int)data];
1149 s = (char *)disp_lang_array[(int)data];
1153 char *p = strchr(s, '(');
1155 strncpy(text, s, p-s);
1157 strncpy(text, s, strlen(s));
1161 strncpy(text, "", strlen(""));
1165 return strdup(text);
1166 } else if(!strcmp(part, "elm.text.1")) {
1169 if((int)data == 0) {
1172 value = vconf_get_str(VCONFKEY_LANGSET);
1173 if (NULL == value) {
1174 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1177 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1179 char system_lang[6] = {0,};
1180 strncpy(system_lang, value , 5);
1183 // confirm whether the system language is supported by stt engine or not.
1184 // if supported, set the language
1185 // otherwise, set language to en_US
1187 return strdup(get_lang_label_n66(system_lang));
1189 return strdup(get_lang_label(system_lang));
1194 s = (char *)disp_lang_array_n66[(int)data];
1196 s = (char *)disp_lang_array[(int)data];
1200 char *p = strchr(s, '(');
1202 strncpy(text,p+1,strlen(s)-(p-s)-2);
1204 strncpy(text, s, strlen(s));
1207 strncpy(text, "", strlen(""));
1209 return strdup(text);
1218 static Evas_Object *__get_genlist_item_content(void *data, Evas_Object *obj, const char *part)
1220 int index = (int)data;
1221 Evas_Object * content = NULL;
1223 if (!strcmp(part, "elm.icon")) {
1224 content = elm_radio_add(obj);
1225 elm_radio_state_value_set(content, index);
1226 elm_radio_group_add(content, radio_gp);
1227 evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1228 evas_object_propagate_events_set(content, EINA_TRUE);
1229 evas_object_size_hint_align_set(content, EVAS_HINT_FILL, EVAS_HINT_FILL);
1230 elm_object_style_set(content, "list");
1232 if (elm_config_access_get())
1233 elm_access_object_unregister(content);
1241 static int get_language_value()
1246 int lang = 0, ret = 0;
1248 ret = preference_get_int(PREFERENCE_ISE_STT_LANGUAGE, &lang);
1249 if(PREFERENCE_ERROR_NONE != ret){
1250 PRINTFUNC(DLOG_ERROR, "preference_get_int error!(%d)", ret);
1251 preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)2); //auto
1255 int lang = 0, ret = 0;
1257 ret = vconf_get_int(VCONFKEY_ISE_STT_LANGUAGE, &lang);
1259 PRINTFUNC(DLOG_ERROR, "Vconf_get_int error!(%d)", ret);
1263 if(lang < 0 || lang > 6) {
1264 PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
1267 PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array_n66[lang]);
1270 PRINTFUNC(DLOG_DEBUG, "current language value for stt (%s).", disp_lang_array[lang]);
1276 static void set_language_value(int type)
1278 // Add implementation to store language type.
1282 ret = preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)type);
1283 if(PREFERENCE_ERROR_NONE != ret){
1284 PRINTFUNC(DLOG_ERROR, "preference_set_int error!(%d)", ret);
1288 ret = vconf_set_int(VCONFKEY_ISE_STT_LANGUAGE, (int) type);
1290 PRINTFUNC(DLOG_ERROR, "Vconf_set_int error!(%d)", ret);
1294 PRINTFUNC(DLOG_DEBUG, "language type (%d)", type);
1300 static void get_stt_default_language(VoiceData *my_voicedata)
1303 PRINTFUNC(DLOG_ERROR, "my_voicedata NULL");
1307 if(my_voicedata->kbd_lang) {
1308 free(my_voicedata->kbd_lang);
1309 my_voicedata->kbd_lang = NULL;
1314 STT_VOICE_LANGUAGE_N66_I stt_lang;
1315 stt_lang = (STT_VOICE_LANGUAGE_N66_I)get_language_value();
1317 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1320 case STT_VOICE_N66_AUTO :
1322 stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1324 // get system display language
1326 value = vconf_get_str(VCONFKEY_LANGSET);
1327 if (NULL == value) {
1328 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1331 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1333 char system_lang[6] = {0,};
1334 strncpy(system_lang, value , 5);
1337 // confirm whether the system language is supported by stt engine or not.
1338 // if supported, set the language
1339 // otherwise, set language to en_US
1340 if(is_lang_supported_by_stt(system_lang) == TRUE) {
1341 my_voicedata->kbd_lang = strdup(system_lang);
1342 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1344 my_voicedata->kbd_lang = strdup("en_US");
1345 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1349 case STT_VOICE_N66_EN_US :
1350 case STT_VOICE_N66_ES_US :
1351 case STT_VOICE_N66_FR_FR :
1352 case STT_VOICE_N66_JA_JP :
1353 case STT_VOICE_N66_KO_KR :
1354 case STT_VOICE_N66_ZH_CN :
1356 my_voicedata->kbd_lang = strdup(supported_language_n66[stt_lang]);
1360 my_voicedata->kbd_lang = strdup("en_US");
1364 STT_VOICE_LANGUAGE_I stt_lang;
1365 stt_lang = (STT_VOICE_LANGUAGE_I)get_language_value();
1367 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1370 case STT_VOICE_AUTO :
1372 stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1374 // get system display language
1376 value = vconf_get_str(VCONFKEY_LANGSET);
1377 if (NULL == value) {
1378 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1381 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1383 char system_lang[6] = {0,};
1384 strncpy(system_lang, value , 5);
1387 // confirm whether the system language is supported by stt engine or not.
1388 // if supported, set the language
1389 // otherwise, set language to en_US
1390 if(is_lang_supported_by_stt(system_lang) == TRUE) {
1391 my_voicedata->kbd_lang = strdup(system_lang);
1392 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1394 my_voicedata->kbd_lang = strdup("en_US");
1395 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1399 case STT_VOICE_DE_DE :
1400 case STT_VOICE_EN_GB :
1401 case STT_VOICE_EN_US :
1402 case STT_VOICE_ES_ES :
1403 case STT_VOICE_ES_US :
1404 case STT_VOICE_FR_FR :
1405 case STT_VOICE_IT_IT :
1406 case STT_VOICE_JA_JP :
1407 case STT_VOICE_KO_KR :
1408 case STT_VOICE_RU_RU :
1409 case STT_VOICE_ZH_CN :
1410 case STT_VOICE_PT_BR :
1412 my_voicedata->kbd_lang = strdup(supported_language[stt_lang]);
1416 my_voicedata->kbd_lang = strdup("en_US");
1421 PRINTFUNC(DLOG_DEBUG, "stt language (%s)", my_voicedata->kbd_lang);
1425 static Eina_Bool close_setting_window_idler_cb(void *data)
1427 if(g_setting_window && g_setting_naviframe) {
1428 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1431 return ECORE_CALLBACK_CANCEL;
1434 static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *event_info)
1436 PRINTFUNC(DLOG_DEBUG, "");
1440 Evas_Object *genlist = (Evas_Object *) data;
1442 Elm_Object_Item * item = (Elm_Object_Item *) event_info;
1444 elm_genlist_item_selected_set(item, 0);
1445 index = (int)elm_object_item_data_get(item);
1446 elm_genlist_item_update(item);
1448 set_language_value(index);
1450 elm_radio_value_set(radio_gp, index);
1451 ecore_timer_add(0.3, close_setting_window_idler_cb, NULL);
1454 static void language_changed_cb2(void *data, Evas_Object *obj, const char *emission, const char *source)
1457 elm_genlist_realized_items_update(obj);
1460 Eina_Bool _ise_keydown_cb(void *data, int type, void *event)
1462 PRINTFUNC(DLOG_DEBUG, "");
1463 if(type == ECORE_EVENT_KEY_DOWN && g_setting_window && g_setting_naviframe) {
1464 PRINTFUNC(DLOG_DEBUG, "window will be deleted.");
1465 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1468 return ECORE_CALLBACK_DONE;
1471 char *_language_list_access_info_cb(void *data, Evas_Object *obj)
1473 PRINTFUNC(DLOG_DEBUG,"%s", __func__);
1477 std::string text = std::string(gettext(TTS_RADIO_BUTTON));
1478 const Elm_Object_Item *item = (Elm_Object_Item *)data;
1480 Evas_Object* radio = elm_object_item_part_content_get(item, "elm.icon");
1482 index = elm_genlist_item_index_get(item);
1484 if(index == 1) // title
1488 value = elm_radio_value_get(radio);
1489 //PRINTFUNC(DLOG_DEBUG,"index=%d value = %d", index, value);
1490 if(index == value + 2 ){
1491 text = text + std::string(" ") + std::string(gettext(TTS_SELECTED));
1493 text = text + std::string(" ") + std::string(gettext(TTS_NOT_SELECTED));
1496 return strdup(text.c_str());
1499 static void _language_list_item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
1501 PRINTFUNC(DLOG_DEBUG,"%s", __func__);
1502 if (elm_config_access_get()) {
1503 Elm_Object_Item *item = (Elm_Object_Item *)event_info;
1504 Evas_Object *item_access = elm_object_item_access_object_get(item);
1506 elm_access_info_cb_set(item_access, ELM_ACCESS_CONTEXT_INFO, _language_list_access_info_cb, (void*)item);
1510 static Evas_Object *create_language_list(Evas_Object *parent)
1512 if(!parent) return NULL;
1514 Evas_Object *genlist = elm_genlist_add(parent);
1515 if (!genlist) return NULL;
1517 elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
1518 elm_genlist_homogeneous_set(genlist, EINA_TRUE);
1519 // uxt_genlist_set_bottom_margin_enabled(genlist, EINA_TRUE);
1521 Evas_Object *circle_language_genlist = eext_circle_object_genlist_add(genlist, NULL);
1522 eext_circle_object_genlist_scroller_policy_set(circle_language_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1523 evas_object_resize(circle_language_genlist, 360, 360);
1524 evas_object_show(circle_language_genlist);
1525 eext_rotary_object_event_activated_set(circle_language_genlist, EINA_TRUE);
1529 Elm_Object_Item * item = NULL;
1530 Elm_Object_Item * item_title = NULL;
1532 evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND,EVAS_HINT_EXPAND);
1533 evas_object_size_hint_align_set(genlist, EVAS_HINT_FILL, EVAS_HINT_FILL);
1535 radio_gp = elm_radio_add(genlist);
1536 elm_radio_state_value_set(radio_gp, -1);
1538 lang_val = get_language_value();
1541 itc_title.item_style = "title";
1542 itc_title.func.text_get = __get_genlist_title_label;
1543 itc_title.func.content_get = NULL;
1545 item_title = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
1548 itc_2text.item_style = "2text.1icon.1/sub1.multiline";
1549 itc_2text.func.text_get = __get_genlist_item_label;
1550 itc_2text.func.content_get = __get_genlist_item_content;
1553 item = item_append(genlist, itc_2text, (void *)0, language_set_genlist_radio_cb, genlist); // AUTO
1556 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1557 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1560 if ( item == NULL ) {
1561 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1565 itc_1text.item_style = "1text.1icon.1";
1566 itc_1text.func.text_get = __get_genlist_item_label;
1567 itc_1text.func.content_get = __get_genlist_item_content;
1570 for (i = 1; i < 7; i++)
1573 char *s = (char *)disp_lang_array_n66[i];
1576 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1578 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1582 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1583 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1586 if ( item == NULL ) {
1587 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1592 for (i = 1; i < 13; i++)
1595 char *s = (char *)disp_lang_array[i];
1598 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1600 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1604 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1605 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1608 if ( item == NULL ) {
1609 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1615 elm_radio_value_set(radio_gp, lang_val);
1617 elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb2, NULL);
1618 // eext_rotary_event_callback_set(genlist, _language_list_rotary_cb, NULL);
1619 evas_object_smart_callback_add(genlist, "realized", _language_list_item_realized, NULL);
1622 g_evt_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _ise_keydown_cb, NULL);
1626 void create_setting_window(Evas_Object *more_option_layout)
1630 Evas_Object *window = NULL;
1631 Evas_Object *layout = NULL;
1632 Evas_Object *genlist = NULL;
1633 Evas_Object *naviframe = NULL;
1635 Elm_Object_Item *item = NULL;
1637 const char *str = "mobile";
1640 * Create full size window
1643 window = elm_win_add(NULL, "voice-input-setting", ELM_WIN_BASIC);
1645 PRINTFUNC(DLOG_DEBUG, "it's fail to create window.");
1649 elm_win_title_set(window, "voice-input-setting");
1650 // ecore_x_window_size_get(ecore_x_window_root_first_get(), &w, &h);
1651 elm_win_borderless_set(window, EINA_TRUE);
1652 evas_object_resize(window, w, h);
1654 elm_win_indicator_mode_set(window, ELM_WIN_INDICATOR_HIDE);
1655 elm_win_profiles_set(window, &str, 1);
1661 // ea_theme_style_set(EA_THEME_STYLE_DEFAULT);
1662 // ea_theme_changeable_ui_enabled_set(EINA_TRUE);
1665 * Create layout for language list
1668 layout = elm_layout_add(window);
1670 elm_layout_theme_set(layout, "layout", "application", "default");
1671 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1672 evas_object_show(layout);
1673 elm_win_resize_object_add(window, layout);
1677 * Set Window rotation
1680 if (elm_win_wm_rotation_supported_get(window)) {
1681 const int rots[4] = { 0, 90, 180, 270 };
1682 elm_win_wm_rotation_available_rotations_set(window, rots, 4);
1686 * Activate and show window
1689 elm_win_activate(window);
1690 evas_object_show(window);
1696 naviframe= elm_naviframe_add(layout);
1697 if (naviframe == NULL){
1698 PRINTFUNC(DLOG_DEBUG, "create navi_frame failed");
1701 // ea_object_event_callback_add(naviframe, EA_CALLBACK_BACK, ea_naviframe_back, window);
1702 elm_object_part_content_set(layout, "elm.swallow.content", naviframe);
1705 * Push language list
1708 genlist = create_language_list(naviframe);
1710 //item = elm_naviframe_item_push(naviframe, "IDS_VC_HEADER_VOICE_INPUT_LANGUAGE", NULL, NULL, genlist, NULL);
1711 item = elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, "empty");
1712 //elm_object_item_domain_text_translatable_set(item, PACKAGE, EINA_TRUE);
1714 g_setting_window = window;
1715 g_setting_naviframe = naviframe;
1716 g_more_option_layout = more_option_layout;
1719 static void language_changed_cb(void *data, Evas_Object * obj, void *event_info)
1721 PRINTFUNC(DLOG_DEBUG,"");
1728 static void get_text_part_width(Evas_Object *window, const char *text, Evas_Coord *calculated_width)
1732 if(!calculated_width) return;
1734 Evas_Coord width, height;
1736 char *strbuf = NULL;
1737 Evas_Object *tb = NULL;
1738 Evas_Textblock_Style *st = NULL;
1739 Evas_Textblock_Cursor *cur = NULL;
1741 tb = evas_object_textblock_add(evas_object_evas_get(window));
1742 evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
1744 st = evas_textblock_style_new();
1745 evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
1746 evas_object_textblock_style_set(tb, st);
1748 cur = evas_object_textblock_cursor_new(tb);
1749 strbuf = elm_entry_utf8_to_markup(text);
1750 evas_object_resize(tb, 360, 47);
1752 evas_object_textblock_text_markup_set(tb, strbuf);
1753 evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
1754 evas_object_textblock_size_formatted_get(tb, &width, &height);
1755 evas_object_resize(tb, width, 47);
1757 *calculated_width = width;
1759 if(strbuf) free(strbuf);
1760 if(tb) evas_object_del(tb);
1761 if(st) evas_textblock_style_free(st);
1762 if(cur) evas_textblock_cursor_free(cur);
1765 void _stt_lang_changed_cb(keynode_t *key, void* data)
1767 PRINTFUNC(DLOG_DEBUG, "");
1770 VoiceData *vd = (VoiceData *) data;
1771 get_stt_default_language(vd);
1772 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
1779 static void __done_key_cb( void *data, Evas_Object *obj, void *event_info )
1781 PRINTFUNC(DLOG_DEBUG,"");
1786 VoiceData *voicedata = (VoiceData *)data;
1788 elm_naviframe_item_pop(voicedata->naviframe);
1791 static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Context *imf_context, int value)
1796 VoiceData *voicedata = (VoiceData *)data;
1799 case ECORE_IMF_INPUT_PANEL_STATE_HIDE: // 1
1800 elm_naviframe_item_pop(voicedata->naviframe);
1802 case ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW: // 2
1803 PRINTFUNC(DLOG_DEBUG,"keypad state will show.");
1805 case ECORE_IMF_INPUT_PANEL_STATE_SHOW: // 0
1806 PRINTFUNC(DLOG_DEBUG,"keypad state show.");
1811 static void __stt_detailed_entry_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
1815 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(obj);
1816 ecore_imf_context_input_panel_event_callback_del(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb);
1817 PRINTFUNC(DLOG_DEBUG,"input_panel_event_cb is deleted.");
1821 static Evas_Object *create_text_detiled_view(Evas_Object *parent)
1824 string edj_path = get_resource_path();
1825 edj_path = edj_path + STT_EDJ_FILE;
1828 Evas_Object *layout = elm_layout_add(parent);
1829 elm_layout_file_set(layout, edj_path.c_str(), "entry_focused_layout");
1830 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1831 evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1832 evas_object_show(layout);
1835 Evas_Object *entry = elm_entry_add(parent);
1836 evas_object_size_hint_weight_set(entry, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1837 evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, EVAS_HINT_FILL);
1838 // ea_entry_selection_back_event_allow_set(entry, EINA_TRUE);
1839 elm_entry_context_menu_disabled_set(entry, EINA_TRUE);
1840 elm_entry_select_allow_set(entry, EINA_FALSE);
1841 // elm_entry_cursor_handler_disabled_set(entry, EINA_TRUE);
1842 elm_entry_single_line_set(entry, EINA_TRUE);
1843 elm_entry_scrollable_set(entry, EINA_TRUE);
1844 elm_entry_input_panel_return_key_type_set(entry, ELM_INPUT_PANEL_RETURN_KEY_TYPE_DONE);
1846 evas_object_show(entry);
1848 elm_object_part_content_set(layout, "contents", entry);
1853 static Eina_Bool _idler_cb2(void *data)
1855 VoiceData *voicedata = (VoiceData *)data;
1857 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_FALSE);
1859 return ECORE_CALLBACK_CANCEL;
1862 static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *it)
1864 PRINTFUNC(DLOG_DEBUG, "");
1866 if(!data) return EINA_FALSE;
1868 VoiceData *voicedata = (VoiceData *)data;
1870 Evas_Object *main_entry = (Evas_Object *)voicedata->main_entry;
1871 Evas_Object *detailed_layout = elm_object_item_part_content_get(it, "elm.swallow.content");
1872 Evas_Object *detailed_entry = elm_object_part_content_get(detailed_layout, "contents");
1874 const char *str = NULL;
1877 pos = elm_entry_cursor_pos_get(detailed_entry);
1878 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1880 str = elm_entry_entry_get(detailed_entry);
1882 voicedata->stt_results.clear();
1883 voicedata->stt_results.push_back(str);
1885 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_TRUE);
1886 elm_entry_entry_set(main_entry, str);
1887 elm_entry_cursor_pos_set(main_entry, pos);
1890 elm_entry_cursor_geometry_get(main_entry,&x,&y,&w,&h);
1891 PRINTFUNC(DLOG_DEBUG, "%d %d %d %d",x,y,w,h);
1893 elm_scroller_region_bring_in(voicedata->scroller, 0, y+h, 300, 168);
1895 ecore_idler_add(_idler_cb2, voicedata);
1900 static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_info)
1903 PRINTFUNC(DLOG_DEBUG, "");
1908 VoiceData *voicedata = (VoiceData *)data;
1913 pos = elm_entry_cursor_pos_get(obj);
1914 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1916 str = elm_entry_markup_to_utf8(elm_entry_entry_get(obj));
1918 if (str && strlen(str) > 0) {
1921 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
1922 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING) {
1923 voicedata->sttmanager->Cancel();
1924 PRINTFUNC(DLOG_DEBUG, "stt entry clicked callback during STT recording and processing");
1928 catch(is::stt::SttException &e) {
1929 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1933 Evas_Object *ly_detailed_view = create_text_detiled_view(voicedata->naviframe);
1935 Evas_Object *detailed_entry = elm_object_part_content_get(ly_detailed_view, "contents");
1936 elm_entry_entry_set(detailed_entry, str);
1937 elm_entry_cursor_pos_set(detailed_entry, pos);
1938 evas_object_smart_callback_add( detailed_entry, "activated", __done_key_cb, voicedata ); // Register callback for Done key
1940 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(detailed_entry);
1941 ecore_imf_context_input_panel_event_callback_add(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb, voicedata);
1942 evas_object_event_callback_add(detailed_entry, EVAS_CALLBACK_DEL, __stt_detailed_entry_del_cb, NULL);
1945 Elm_Object_Item *navi_it = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, ly_detailed_view, NULL);
1946 elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb,(void *)voicedata);
1947 elm_naviframe_item_title_enabled_set(navi_it, EINA_FALSE, EINA_FALSE);
1955 void activate_circle_scroller_for_stt_textbox(void* data, Eina_Bool bActivate)
1958 PRINTFUNC(DLOG_DEBUG,"");
1961 VoiceData *voicedata = (VoiceData *)data;
1963 Evas_Object *scroller = NULL;
1964 Evas_Object *circle_scroller = NULL;
1966 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
1967 circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
1968 eext_rotary_object_event_activated_set(circle_scroller, bActivate);
1971 static Evas_Object *create_textblock(void* data)
1974 if(!data) return NULL;
1976 VoiceData *voicedata = (VoiceData *)data;
1978 Evas_Object *scroller = NULL;
1979 Evas_Object *box = NULL;
1980 Evas_Object *inner_layout = NULL;
1981 Evas_Object *entry = NULL;
1982 Evas_Object *tb = NULL;
1983 Evas_Object *circle_scroller = NULL;
1985 string edj_path = get_resource_path();
1986 edj_path = edj_path + STT_EDJ_FILE;
1988 scroller = elm_scroller_add(voicedata->layout_main);
1990 elm_scroller_loop_set(scroller, EINA_FALSE, EINA_FALSE);
1992 evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
1993 evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1995 // elm_scroller_page_size_set(scroller, 0, 50);
1996 // elm_scroller_page_scroll_limit_set(scroller, 0, 1);
1998 elm_object_scroll_lock_x_set(scroller, EINA_TRUE);
2000 // uxt_scroller_set_auto_scroll_enabled(scroller, EINA_FALSE);
2002 circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
2003 eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
2004 eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
2006 box = elm_box_add(scroller);
2008 inner_layout = elm_layout_add(scroller);
2009 elm_layout_file_set(inner_layout, edj_path.c_str(), "layout_textblock");
2010 evas_object_size_hint_weight_set(inner_layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2012 elm_object_signal_callback_add(inner_layout, "do_scroll", "entry",
2013 [](void *data, Evas_Object *obj, const char* signal, const char* e)
2015 _bring_in_cb((void *) data);
2016 }, (void *) scroller);
2018 entry = elm_entry_add(inner_layout);
2019 voicedata->main_entry = entry;
2020 elm_entry_editable_set(entry, EINA_FALSE);
2022 #define FORMAT_TEXT_AREA_FONT_STYLE \
2023 "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'"
2025 char customStyle[512];
2026 // ea_theme_color_get("AT02112", &r, &g, &b, &a, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
2027 snprintf(customStyle, 512, FORMAT_TEXT_AREA_FONT_STYLE, r, g, b, a, r, g, b, a);
2029 elm_entry_text_style_user_push(entry, customStyle);
2031 evas_object_smart_callback_add(entry, "clicked", _stt_entry_clicked_cb, voicedata);
2033 elm_object_part_content_set(inner_layout, "elm.swallow.content", entry);
2035 elm_box_pack_end(box, inner_layout);
2037 elm_object_content_set(scroller, box);
2038 evas_object_data_set(scroller, "inner_layout", (void *) inner_layout);
2039 evas_object_data_set(scroller, "circle", (void *) circle_scroller);
2040 evas_object_show(scroller);
2041 evas_object_show(inner_layout);
2047 static Evas_Object *create_progressbar(Evas_Object *parent)
2050 Evas_Object *progressbar = NULL;
2052 progressbar = elm_progressbar_add(parent);
2053 elm_object_style_set(progressbar, "voice_input/process/small");
2054 //elm_progressbar_pulse(progressbar, EINA_TRUE);
2056 evas_object_size_hint_align_set(progressbar, EVAS_HINT_FILL, EVAS_HINT_FILL);
2057 evas_object_size_hint_weight_set(progressbar, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2059 // ea_theme_object_color_replace(progressbar, "B065L6", "AO012");
2061 evas_object_show(progressbar);
2067 static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
2069 PRINTFUNC(NO_PRINT,"");
2071 Evas_Object *more_option_layout = NULL;
2072 Evas_Object *layout_main = NULL;
2073 Evas_Object *lang_btn_box = NULL;
2074 Evas_Object *lang_btn = NULL;
2075 Evas_Object *to = NULL;
2076 Evas_Object *ao = NULL;
2078 char *lang_type_str = NULL;
2081 int is_screen_reader_on = FALSE;
2083 VoiceData *voicedata = r_voicedata;
2086 * add app_default_layout
2089 MoreOption* mo = new MoreOption(parent, voicedata);
2095 layout_main = elm_layout_add(mo->getMoreOptionLayout());
2100 voicedata->layout_main = layout_main;
2102 string edj_path = get_resource_path();
2103 edj_path = edj_path + STT_EDJ_FILE;
2105 if (vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TTS, &is_screen_reader_on) == -1) {
2106 PRINTFUNC(DLOG_ERROR,"Cannot read value of screen reader from vconf");
2109 evas_object_size_hint_weight_set (layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2110 evas_object_size_hint_align_set (layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
2112 elm_layout_file_set (layout_main, edj_path.c_str(), "mic_control");
2114 //elm_object_content_set(parent, layout_main);
2116 //Canvas for Cairo effect
2117 Evas_Object *canvas = evas_object_image_filled_add(evas_object_evas_get(layout_main));
2118 // evas_object_image_alpha_set(canvas, EINA_TRUE);
2119 evas_object_size_hint_align_set (canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
2120 evas_object_size_hint_weight_set (canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
2121 evas_object_move (canvas, 0, 0);
2123 Evas_Coord CanvasW, CanvasH;
2126 evas_object_image_size_set (canvas, CanvasW, CanvasH);
2127 evas_object_resize (canvas, CanvasW, CanvasH);
2128 evas_object_size_hint_min_set (canvas, CanvasW, CanvasH);
2129 evas_object_show (canvas);
2131 elm_object_part_content_set(layout_main, "EFFECT_BG", canvas);
2135 Evas_Object *m_mic_button = elm_button_add(layout_main);
2136 elm_object_style_set(m_mic_button, "vic/micbutton");
2137 elm_object_part_content_set(layout_main, "MIC", m_mic_button);
2138 if (elm_config_access_get()){
2139 elm_access_info_cb_set(m_mic_button, ELM_ACCESS_INFO, _mic_access_info_cb, NULL);
2140 elm_access_info_cb_set(m_mic_button, ELM_ACCESS_TYPE, _mic_access_info_cb, NULL);
2141 elm_access_info_cb_set(m_mic_button, ELM_ACCESS_STATE, _mic_access_info_cb, NULL);
2142 evas_object_smart_callback_add(m_mic_button, "access,highlighted", _mic_highlighted_cb, voicedata);
2145 elm_object_disabled_set(m_mic_button, EINA_TRUE);
2146 evas_object_smart_callback_add(m_mic_button, "clicked", on_mic_button_press_cb, (void *) voicedata);
2148 voicedata->mic_button = m_mic_button;
2150 if(voicedata->btn_disabling_timer == NULL){
2151 voicedata->btn_disabling_timer = ecore_timer_add(2.0, _mic_button_enable_cb, voicedata);
2154 // ecore_idler_add(_idler_cb, voicedata);
2155 ecore_timer_add(0.6, _idler_cb, voicedata);
2157 // Confirm panel layout
2158 Evas_Object *panel_layout;
2159 panel_layout = elm_layout_add(layout_main);
2160 elm_layout_theme_set(panel_layout, "layout", "drawer", "panel");
2161 evas_object_show(panel_layout);
2165 panel = elm_panel_add(panel_layout);
2166 elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
2167 elm_layout_theme_set(panel, "panel", "left_confirm", "default");
2168 if(app_data->source_app_control){
2170 char *app_id = NULL;
2171 ret = app_control_get_extra_data(app_data->source_app_control, "selector_keyboard_app_id", &app_id);
2172 if (ret == APP_CONTROL_ERROR_NONE) {
2173 PRINTFUNC(DLOG_DEBUG, "app_id = %s", app_id);
2177 if(!strcmp(app_id, "com.samsung.message.appcontrol.compose")
2178 || !strcmp(app_id, "com.samsung.wemail-send")){
2179 elm_layout_theme_set(panel, "panel", "left_sending", "default");
2184 elm_layout_signal_callback_add(panel, "cue,clicked", "elm", _panel_cue_clicked_cb, (void *) voicedata);
2185 evas_object_show(panel);
2187 elm_object_part_content_set(panel_layout, "elm.swallow.right", panel);
2188 elm_object_part_content_set(layout_main, "left_panel_area", panel_layout);
2190 elm_object_signal_emit(panel, "elm,state,disabled", "elm");
2191 elm_panel_toggle(panel);
2195 Evas_Object *scroller = create_textblock(voicedata);
2196 elm_object_part_content_set(layout_main, "text_area", scroller);
2197 voicedata->scroller = scroller;
2200 Evas_Object *progress_bar = create_progressbar(layout_main);
2201 elm_object_part_content_set(layout_main, "PROGRESS_BAR", progress_bar);
2202 voicedata->progressbar = progress_bar;
2205 elm_object_signal_callback_add(layout_main, "idle,state,pulse,visible", "", on_initial_anim_press_cb, voicedata);
2207 mo->SetContentLayout(layout_main);
2209 //accesbility chaining
2210 if (elm_config_access_get()) {
2212 Evas_Object *cue_access_right = NULL;
2214 Evas_Object *panel_right = elm_object_part_content_get(mo->getMoreOptionLayout(), "elm.swallow.right");
2216 PRINTFUNC(DLOG_DEBUG,"panel_right == NULL");
2218 Evas_Object *cue_right = (Evas_Object *)edje_object_part_object_get(elm_layout_edje_get(panel_right), "cue.event");
2220 PRINTFUNC(DLOG_DEBUG,"cue_right == NULL");
2222 Evas_Object *_access_right = elm_access_object_get(cue_right);
2223 if (!_access_right){
2224 PRINTFUNC(DLOG_DEBUG,"_access_right == NULL");
2226 cue_access_right = _access_right;
2229 Evas_Object *cue_access_left = NULL;
2230 Evas_Object *panel_layout = elm_layout_content_get(layout_main, "left_panel_area");
2231 Evas_Object *panel_left = elm_layout_content_get(panel_layout, "elm.swallow.right");
2233 PRINTFUNC(DLOG_DEBUG,"panel_left == NULL");
2235 Evas_Object *cue_left = (Evas_Object *)edje_object_part_object_get(elm_layout_edje_get(panel_left), "cue.event");
2237 PRINTFUNC(DLOG_DEBUG,"cue_left == NULL");
2239 Evas_Object *_access_left = elm_access_object_register(cue_left, panel_left);
2241 PRINTFUNC(DLOG_DEBUG,"_access_left == NULL");
2243 elm_access_info_cb_set(_access_left, ELM_ACCESS_INFO, _left_cue_access_info_cb, panel_left);
2244 elm_access_activate_cb_set(_access_left, _left_cue_access_activate_cb, panel_left);
2246 cue_access_left = _access_left;
2248 elm_access_highlight_next_set(m_mic_button, ELM_HIGHLIGHT_DIR_NEXT, cue_access_right);
2249 elm_access_highlight_next_set(cue_access_right, ELM_HIGHLIGHT_DIR_PREVIOUS, m_mic_button);
2251 elm_access_highlight_next_set(cue_access_right, ELM_HIGHLIGHT_DIR_NEXT, cue_access_left);
2252 elm_access_highlight_next_set(cue_access_left, ELM_HIGHLIGHT_DIR_PREVIOUS, cue_access_right);
2254 elm_access_highlight_next_set(cue_access_left, ELM_HIGHLIGHT_DIR_NEXT, m_mic_button);
2255 elm_access_highlight_next_set(m_mic_button, ELM_HIGHLIGHT_DIR_PREVIOUS, cue_access_left);
2262 int is_lang_supported_by_stt(char lang[])
2264 /* to check if the language is supported by stt */
2266 for (index = (sizeof(supported_language) / sizeof(supported_language[0]))-1; index != 0; index--)
2268 if (!strcmp(lang, supported_language[index])) {
2269 PRINTFUNC(DLOG_DEBUG,"current lang supported (%s)", supported_language[index]);
2274 PRINTFUNC(DLOG_DEBUG,"current lang not supported (%s)", lang);
2279 int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
2281 PRINTFUNC(DLOG_DEBUG,"[init_voice]");
2283 // stt_is_samsung_asr(&g_is_n66);
2285 VoiceData *voicedata = (VoiceData *)r_voicedata;
2291 PRINTFUNC(DLOG_ERROR,"Parent is NULL\n");
2295 PRINTFUNC(NO_PRINT,"Parent is there");
2298 voicedata->voicefw_state = 0;
2300 /* Set Voice Language */
2301 if(voicedata->kbd_lang){
2302 free(voicedata->kbd_lang);
2303 voicedata->kbd_lang = NULL;
2306 //stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
2307 get_stt_default_language(voicedata);
2308 if(NULL == voicedata->kbd_lang || FALSE == is_lang_supported_by_stt(voicedata->kbd_lang)) {
2309 voicedata->kbd_lang = strdup("en_US");
2312 PRINTFUNC(DLOG_DEBUG,"Voice input active language is : %s", voicedata->kbd_lang);
2314 voicedata->naviframe = parent;
2316 if (NULL == voicedata->naviframe) {
2323 static Eina_Bool init_view(void *data)
2325 VoiceData *voicedata = (VoiceData *)data;
2327 if(voicedata == NULL)
2328 return ECORE_CALLBACK_CANCEL;
2330 voicedata->layout_main = create_fullview(voicedata->naviframe, voicedata);
2332 if (voicedata->layout_main) {
2333 evas_object_show(voicedata->layout_main);
2336 return ECORE_CALLBACK_CANCEL;
2340 Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
2342 PRINTFUNC(NO_PRINT,"[show_voice_window]");
2344 VoiceData *voicedata = (VoiceData *)r_voicedata;
2350 PRINTFUNC(NO_PRINT,"Parent is NULL\n");
2354 PRINTFUNC(NO_PRINT,"Parent is there");
2357 if (NULL != voicedata->layout_main) {
2358 PRINTFUNC(DLOG_DEBUG, "delete previous layout");
2359 evas_object_del((voicedata)->layout_main);
2360 (voicedata)->layout_main = NULL;
2363 if (NULL != voicedata->effector) {
2364 PRINTFUNC(DLOG_DEBUG, "delete previous effect");
2365 delete (voicedata->effector);
2366 (voicedata)->effector = NULL;
2369 if (NULL != voicedata->ieffect) {
2370 PRINTFUNC(DLOG_DEBUG, "delete previous ieffect");
2371 delete (voicedata->ieffect);
2372 voicedata->ieffect = NULL;
2376 delete voicedata->mo;
2377 voicedata->mo = NULL;
2380 init_view((void *)voicedata);
2381 return voicedata->layout_main;
2385 void on_stt_pause(VoiceData *r_voicedata){
2387 PRINTFUNC(DLOG_DEBUG,"");
2389 VoiceData *voicedata = (VoiceData *)r_voicedata;
2393 //voicedata->state = STT_STATE_VAL_PREPARE_CANCEL;
2394 voicedata->sttmanager->Cancel();
2395 }catch(is::stt::SttException &e){
2396 PRINTFUNC(DLOG_ERROR, "reason : %s", e.what());
2399 //Hide more option and language settings by interrupt scenario.
2400 close_setting_window_idler_cb(NULL);
2401 Evas_Object *mo_layout = voicedata->mo->getMoreOptionLayout();
2403 if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
2404 eext_more_option_opened_set(mo_layout, EINA_FALSE);
2413 void on_destroy(VoiceData *r_voicedata)
2415 PRINTFUNC(NO_PRINT,"");
2417 VoiceData *voicedata = (VoiceData *)r_voicedata;
2419 int result = STT_ERROR_NONE;
2423 if (NULL != voicedata) {
2425 if (NULL != voicedata->layout_main) {
2426 voicedata->layout_main = NULL;
2429 if (NULL != voicedata->naviframe) {
2430 voicedata->naviframe = NULL;
2433 if (NULL != voicedata->start_timer) {
2434 ecore_timer_del(voicedata->start_timer);
2435 voicedata->start_timer = NULL;
2438 if (NULL != voicedata->refresh_timer) {
2439 ecore_timer_del(voicedata->refresh_timer);
2440 voicedata->refresh_timer = NULL;
2443 if (NULL != voicedata->progressbar_timer) {
2444 ecore_timer_del(voicedata->progressbar_timer);
2445 voicedata->progressbar_timer = NULL;
2446 elm_progressbar_pulse(voicedata->progressbar, EINA_FALSE);
2449 if (NULL != voicedata->textblock_timer) {
2450 ecore_timer_del(voicedata->textblock_timer);
2451 voicedata->textblock_timer = NULL;
2454 if (NULL != voicedata->guide_text_timer) {
2455 ecore_timer_del(voicedata->guide_text_timer);
2456 voicedata->guide_text_timer = NULL;
2459 if (NULL != voicedata->btn_disabling_timer) {
2460 ecore_timer_del(voicedata->btn_disabling_timer);
2461 voicedata->btn_disabling_timer = NULL;
2464 if (NULL != voicedata->power_unlock_timer) {
2465 ecore_timer_del(voicedata->power_unlock_timer);
2466 voicedata->power_unlock_timer = NULL;
2469 if(voicedata->kbd_lang) {
2470 free(voicedata->kbd_lang);
2471 voicedata->kbd_lang = NULL;
2474 if(voicedata->ieffect) {
2475 delete voicedata->ieffect;
2476 voicedata->ieffect = NULL;
2479 if(voicedata->effector) {
2480 delete voicedata->effector;
2481 voicedata->effector = NULL;
2485 delete voicedata->mo;
2486 voicedata->mo = NULL;
2489 if(voicedata->sttmanager) {
2490 delete voicedata->sttmanager;
2491 voicedata->sttmanager = NULL;
2494 if(voicedata->sttfeedback) {
2495 delete voicedata->sttfeedback;
2496 voicedata->sttfeedback = NULL;