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[7] = {
87 char *disp_lang_array[7] = {
89 "English (United States)",
90 "Español (América Latina)",
112 }STT_VOICE_LANGUAGE_I;
122 }STT_VOICE_LANGUAGE_N66_I;
133 static void get_stt_default_language(VoiceData *my_voicedata);
136 char* get_lang_label(char lang[])
140 if (strcmp (lang, "en_US") == 0)
141 str = disp_lang_array[1];
143 else if (strcmp (lang, "ko_KR") == 0)
144 str = disp_lang_array[6];
146 else if (strcmp (lang, "fr_FR") == 0)
147 str = disp_lang_array[3];
149 else if (strcmp (lang, "ja_JP") == 0)
150 str = disp_lang_array[5];
152 else if (strcmp (lang, "zh_CN") == 0)
153 str = disp_lang_array[4];
155 else if (strcmp (lang, "es_US") == 0)
156 str = disp_lang_array[2];
159 str = disp_lang_array[1];
166 _bring_in_cb(void *data)
169 return ECORE_CALLBACK_CANCEL;
171 Evas_Coord x, y, w, h;
173 Evas_Object *scroller = (Evas_Object *)data;
174 Evas_Object *inner_layout = NULL;
176 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
178 evas_object_geometry_get(inner_layout, &x, &y, &w, &h);
179 elm_scroller_region_bring_in(scroller, x, h, w, h);
181 PRINTFUNC(NO_PRINT, "scroller %d %d %d %d", x, y, w, h);
183 return ECORE_CALLBACK_CANCEL;
186 static inline Evas_Coord get_text_block_size(Evas_Object *obj, std::string text)
188 int calculated_height = 0;
190 int max_height = 1280;
191 int unit_width = 282;
193 Evas_Coord width, height;
196 Evas_Object *tb = NULL;
197 Evas_Textblock_Style *st = NULL;
198 Evas_Textblock_Cursor *cur = NULL;
200 tb = evas_object_textblock_add(evas_object_evas_get(obj));
201 evas_object_textblock_legacy_newline_set(tb, EINA_FALSE);
203 st = evas_textblock_style_new();
204 evas_textblock_style_set(st, VIRTUAL_TEXT_AREA_FONT_STYLE);
205 evas_object_textblock_style_set(tb, st);
207 cur = evas_object_textblock_cursor_new(tb);
208 strbuf = elm_entry_utf8_to_markup(text.c_str());
209 evas_object_resize(tb, unit_width, max_height);
211 evas_object_textblock_text_markup_set(tb, strbuf);
212 evas_textblock_cursor_format_prepend(cur, "+ wrap=mixed");
213 evas_object_textblock_size_formatted_get(tb, &width, &height);
214 evas_object_resize(tb, unit_width, height);
216 if(strbuf) free(strbuf);
217 if(tb) evas_object_del(tb);
218 if(st) evas_textblock_style_free(st);
219 if(cur) evas_textblock_cursor_free(cur);
224 static Eina_Bool _update_textblock_timer_cb(void *data)
227 return ECORE_CALLBACK_CANCEL;
229 VoiceData* voicedata = (VoiceData*)data;
231 voicedata->textblock_timer = NULL;
233 std::string result_text;
234 for(int i = 0; i < voicedata->stt_results.size(); i++){
235 if(i == voicedata->stt_results.size()-1){
236 result_text += voicedata->stt_results.at(i);
238 result_text += voicedata->stt_results.at(i);
243 Evas_Object *rect = NULL;
244 Evas_Object *entry = NULL;
245 Evas_Object *scroller = NULL;
246 Evas_Object *box = NULL;
247 Evas_Object *inner_layout = NULL;
250 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
253 PRINTFUNC(DLOG_ERROR, "failed to get scroller");
254 return ECORE_CALLBACK_CANCEL;
257 box = elm_object_content_get(scroller);
260 PRINTFUNC(DLOG_ERROR, "failed to get box");
261 return ECORE_CALLBACK_CANCEL;
264 inner_layout = (Evas_Object *) evas_object_data_get(scroller, "inner_layout");
267 PRINTFUNC(DLOG_ERROR, "failed to get inner_layout");
268 return ECORE_CALLBACK_CANCEL;
271 entry = elm_layout_content_get(inner_layout, "elm.swallow.content");
274 PRINTFUNC(DLOG_ERROR, "failed to get entry");
275 return ECORE_CALLBACK_CANCEL;
278 Evas_Object *top = (Evas_Object *) evas_object_data_get(box, "top_padding");
279 Evas_Object *bottom = (Evas_Object *) evas_object_data_get(box, "bottom_padding");
282 elm_box_unpack(box, top);
283 evas_object_del(top);
287 elm_box_unpack(box, bottom);
288 evas_object_del(bottom);
292 Evas_Coord height = get_text_block_size(box, result_text);
294 // if(height < 173) {
296 int text_area_height = 360-102; // screen H - bottom button H
297 int top_height = ((text_area_height - height) / 2);
298 if(top_height < 120) top_height = 120; // Top fade area H
300 int bottom_height = (text_area_height - top_height - height);
301 if(bottom_height < 1) bottom_height = 0;
303 PRINTFUNC(SECURE_DEBUG, "str : %s", result_text.c_str());
304 PRINTFUNC(DLOG_DEBUG, "height : %d", height);
305 PRINTFUNC(DLOG_DEBUG, "top_height : %d", top_height);
306 PRINTFUNC(DLOG_DEBUG, "bottom_height : %d", bottom_height);
308 rect = evas_object_rectangle_add(evas_object_evas_get(box));
309 evas_object_color_set(rect, 0, 0, 0, 100);
310 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
311 evas_object_size_hint_min_set(rect, 282, top_height);
312 evas_object_show(rect);
314 elm_box_pack_before(box, rect, inner_layout);
315 evas_object_data_set(box, "top_padding", (void *) rect);
317 rect = evas_object_rectangle_add(evas_object_evas_get(box));
318 evas_object_color_set(rect, 0, 0, 0, 100);
319 evas_object_size_hint_weight_set(rect, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
320 evas_object_size_hint_min_set(rect, 282, bottom_height);
321 evas_object_show(rect);
323 elm_box_pack_end(box, rect);
324 evas_object_data_set(box, "bottom_padding", (void *) rect);
327 elm_entry_entry_set(entry, result_text.c_str());
329 Evas_Object *panel_layout = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "left_panel_area");
330 Evas_Object *panel_left = elm_layout_content_get((Evas_Object *)panel_layout, "elm.swallow.right");
332 if (result_text.size() > 0) {
333 elm_object_signal_emit(panel_left, "elm,state,enabled", "elm");
335 elm_object_signal_emit(panel_left, "elm,state,disabled", "elm");
338 elm_object_signal_emit((Evas_Object *)voicedata->layout_main, "idle,state,guide_text,bottom", "elm");
340 if(voicedata->state == STT_STATE_VAL_LISTENING){
341 if(voicedata->guide_text_timer != NULL){
342 PRINTFUNC(DLOG_DEBUG, "Skip hide_guide_text");
343 ecore_timer_del(voicedata->guide_text_timer);
344 voicedata->guide_text_timer = NULL;
346 set_guide_text(voicedata, SK_TAP_TO_PAUSE, true);
349 elm_object_signal_emit(inner_layout, "scrolling", "entry");
351 return ECORE_CALLBACK_CANCEL;
354 void _update_textblock(void *data)
359 VoiceData *voicedata = (VoiceData *) data;
361 if(voicedata->textblock_timer == NULL){
362 voicedata->textblock_timer = ecore_timer_add(1.0, _update_textblock_timer_cb, voicedata);
364 PRINTFUNC(DLOG_DEBUG, "skip : the timer is not expired.");
370 void voice_get_string(const char *keyValue, _VoiceData *voicedata)
377 strbuf = elm_entry_utf8_to_markup(keyValue);
379 PRINTFUNC(DLOG_DEBUG, "text : %s, voicedata->partial_result=%s", strbuf, voicedata->partial_result);
382 if(voicedata->partial_result){ // partial_result is not Null so replace
383 if(strcmp(voicedata->partial_result, strbuf)){
385 PRINTFUNC(DLOG_DEBUG, "different replace");
387 voicedata->stt_results.pop_back();
388 voicedata->stt_results.push_back(strbuf);
390 free(voicedata->partial_result);
391 voicedata->partial_result = strdup(strbuf);
393 } else { // partial_result is Null so first case
394 PRINTFUNC(DLOG_DEBUG, "first push");
395 voicedata->stt_results.push_back(strbuf);
396 voicedata->partial_result = strdup(strbuf);
400 _update_textblock(voicedata);
405 PRINTFUNC(DLOG_DEBUG, "ends");
408 static Eina_Bool _recognition_failure_cb(void *data)
411 VoiceData *voicedata = (VoiceData *) data;
413 voicedata->state = STT_STATE_VAL_INIT;
414 set_animation_state(voicedata);
415 voicedata->refresh_timer = NULL;
417 return ECORE_CALLBACK_CANCEL;
420 void start_by_press(VoiceData *voicedata)
422 PRINTFUNC(DLOG_DEBUG, "");
424 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
429 static void on_mic_button_press_cb(void *data, Evas_Object *obj, void *event_info)
431 PRINTFUNC(NO_PRINT, "");
433 VoiceData *voicedata = (VoiceData *)data;
434 edje_object_signal_emit(_EDJ(voicedata->layout_main), "mouse,clicked,1", "background");
440 static Eina_Bool _mic_button_enable_cb(void *data)
442 PRINTFUNC(DLOG_DEBUG, "");
445 return ECORE_CALLBACK_CANCEL;
447 VoiceData* voicedata = (VoiceData*)data;
449 voicedata->btn_disabling_timer = NULL;
451 Evas_Object *button = (Evas_Object *)voicedata->mic_button;
453 elm_object_disabled_set(button, EINA_FALSE);
455 return ECORE_CALLBACK_CANCEL;
459 static void on_confirm_button_clicked_cb(void *data, Evas_Object *obj, void *event_info)
461 if(g_send_button_clicked == true){
462 PRINTFUNC(DLOG_DEBUG, "skipped seding STT result");
466 g_send_button_clicked = true;
471 VoiceData* voicedata = (VoiceData*)data;
473 std::string result_text;
474 for(int i = 0; i < voicedata->stt_results.size(); i++){
475 result_text += voicedata->stt_results.at(i);
476 if(i != voicedata->stt_results.size()-1)
480 PRINTFUNC(DLOG_DEBUG, "result_text = %s", result_text.c_str());
481 input_smartreply_send_feedback(result_text.c_str());
483 reply_to_sender_by_callback(result_text.c_str(), "voice");
492 _panel_cue_clicked_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
494 PRINTFUNC(DLOG_DEBUG, "left cue clicked!!");
496 on_confirm_button_clicked_cb(data, NULL, NULL);
501 void stt_feedback_initialize()
505 ret = feedback_initialize();
508 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
514 void stt_feedback(FeedbackType type)
518 ret = feedback_initialize();
521 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
525 if (type == VIBRATION_START){
526 // feedback_play(FEEDBACK_PATTERN_VOICE_START);
527 } else if (type == VIBRATION_STOP){
528 // feedback_play(FEEDBACK_PATTERN_VOICE_STOP);
531 ret = feedback_deinitialize();
534 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
539 void stt_feedback_deinitialize()
543 ret = feedback_deinitialize();
546 PRINTFUNC(DLOG_ERROR, "feedback_initialize failed!");
552 static Eina_Bool _idler_cb(void *data)
554 if(!data) return ECORE_CALLBACK_CANCEL;
556 VoiceData *voicedata = (VoiceData *)data;
558 PRINTFUNC(DLOG_DEBUG, "");
561 if(true == _app_stt_initialize(voicedata)) {
562 PRINTFUNC(NO_PRINT, "_app_stt_initialize None Error");
563 voicedata->voicefw_state = 1;
564 voicedata->state = STT_STATE_VAL_INIT;
566 voicedata->voicefw_state = 0;
567 PRINTFUNC(DLOG_ERROR, "Initialization Fail!<br>Check STT-daemon is running");
570 Evas_Object *canvas = elm_object_part_content_get(voicedata->layout_main, "EFFECT_BG");
573 is::ui::WInputSttMicEffect *ieffect = new is::ui::WInputSttMicEffect();
574 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
576 is::ui::MicEffector *effector = new is::ui::MicEffector(canvas, voicedata->layout_main, *ieffect);
577 voicedata->ieffect = ieffect;
578 voicedata->effector = effector;
580 ieffect->SetProgressBar(voicedata->progressbar);
581 ieffect->SetSttHandle(voicedata->sttmanager->GetSttHandle());
583 voicedata->mo->Update();
585 elm_access_highlight_set(voicedata->mic_button);
588 return ECORE_CALLBACK_CANCEL;
592 static Eina_Bool _power_delayed_unlock(void *data){
593 PRINTFUNC(DLOG_DEBUG, "POWER Unlock");
595 VoiceData *voicedata = (VoiceData *) data;
596 device_power_release_lock(POWER_LOCK_DISPLAY);
597 voicedata->power_unlock_timer = NULL;
599 return ECORE_CALLBACK_CANCEL;
604 PRINTFUNC(DLOG_DEBUG, "POWER Unlock directly.");
605 device_power_release_lock(POWER_LOCK_DISPLAY);
608 void powerLock(void *data, bool enable)
610 int ret = DEVICE_ERROR_NONE;
612 VoiceData *voicedata = (VoiceData *) data;
615 ret = device_power_wakeup(false);
616 PRINTFUNC(DLOG_DEBUG, "LCD Wakeup");
618 if(ret != DEVICE_ERROR_NONE)
619 PRINTFUNC(DLOG_ERROR, "LCD Wakeup ERROR = %d", ret);
621 ret = device_power_request_lock(POWER_LOCK_DISPLAY, 0);
622 PRINTFUNC(DLOG_DEBUG, "POWER LOCK");
623 power_state = enable;
625 if(ret != DEVICE_ERROR_NONE)
626 PRINTFUNC(DLOG_ERROR, "ERROR = %d", ret);
628 if(voicedata->power_unlock_timer != NULL){
629 ecore_timer_del(voicedata->power_unlock_timer);
630 voicedata->power_unlock_timer = NULL;
633 PRINTFUNC(DLOG_DEBUG, "POWER Unlock Delayed(5 sec)");
635 if(voicedata->power_unlock_timer != NULL){
636 ecore_timer_del(voicedata->power_unlock_timer);
637 voicedata->power_unlock_timer = NULL;
639 voicedata->power_unlock_timer = ecore_timer_add(5.0, _power_delayed_unlock, voicedata);
644 static Eina_Bool hide_guide_text(void *data){
646 VoiceData *voicedata = (VoiceData *) data;
648 voicedata->guide_text_timer = NULL;
651 PRINTFUNC(DLOG_ERROR, "");
652 elm_object_part_text_set(voicedata->layout_main, "elm.text", "");
654 return ECORE_CALLBACK_CANCEL;
657 static void set_guide_text(VoiceData *vd, const char* text, bool translatable)
659 //elm_object_signal_emit(vd->layout_main, "idle,state,text,visible", "elm");
662 elm_object_domain_translatable_part_text_set(vd->layout_main, "elm.text", PACKAGE, text);
664 elm_object_part_text_set(vd->layout_main, "elm.text", text);
666 if(!strcmp(text, SK_SPEAK_NOW)){
667 if(vd->guide_text_timer == NULL)
668 vd->guide_text_timer = ecore_timer_add(2.0, hide_guide_text, vd);
673 * @brief - function to send the signal to edc
674 * to change the animation as per stt state
677 void set_animation_state(VoiceData *voicedata)
679 PRINTFUNC(DLOG_DEBUG, "");
681 PRINTFUNC(DLOG_ERROR, "voicedata->state == %s",
682 voicedata->state == STT_STATE_VAL_INIT ?
683 "STT_STATE_VAL_INIT" :
684 voicedata->state == STT_STATE_VAL_LISTENING ?
685 "STT_STATE_VAL_LISTENING" :
686 voicedata->state == STT_STATE_VAL_PREPARE_LISTENING ?
687 "STT_STATE_VAL_PREPARE_LISTENING" :
688 voicedata->state == STT_STATE_VAL_PROCESSING ?
689 "STT_STATE_VAL_PROCESSING" :
690 voicedata->state == STT_STATE_VAL_PREPARE_PROCESSING ?
691 "STT_STATE_VAL_PREPARE_PROCESSING" :
692 voicedata->state == STT_STATE_VAL_TERMINATING ?
693 "STT_STATE_VAL_TERMINATING" : "STT_STATE_VAL_NOT_RECOGNISED");
695 if (voicedata->state == STT_STATE_VAL_INIT) {
697 if (voicedata->sttmanager->GetCurrent() == STT_STATE_READY) {
698 set_guide_text(voicedata, "", false);
699 //_elm_access_say(voicedata->layout_main, _(SK_INIT));
701 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR [%d]", voicedata->sttmanager->GetCurrent());
702 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
703 //_elm_access_say(voicedata->layout_main, _(SK_NETWORK_CONNECTION_ERROR));
707 if(voicedata->effector)
708 voicedata->effector->Stop(true);
710 set_guide_text(voicedata, "");
712 PRINTFUNC(DLOG_DEBUG, "%d", voicedata->stt_results.size());
713 powerLock((void*)voicedata, false);
714 } else if (voicedata->state == STT_STATE_VAL_LISTENING) {
715 set_guide_text(voicedata, SK_SPEAK_NOW, true);
717 if(voicedata->effector)
718 voicedata->effector->Start();
720 powerLock((void*)voicedata, true);
721 } else if (voicedata->state == STT_STATE_VAL_PROCESSING) {
722 set_guide_text(voicedata, "");
723 if(voicedata->effector)
724 voicedata->effector->Stop();
726 stt_feedback(VIBRATION_STOP);
728 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
729 set_guide_text(voicedata, _(SK_RECOGNITION_FAILED));
730 //_elm_access_say(voicedata->layout_main, _(SK_RECOGNITION_FAILED));
732 voicedata->state = STT_STATE_VAL_NOT_RECOGNISED;
734 if(voicedata->refresh_timer) {
735 ecore_timer_del(voicedata->refresh_timer);
738 if(voicedata->effector)
739 voicedata->effector->Stop(true);
741 voicedata->refresh_timer = ecore_timer_add(2.0, _recognition_failure_cb, voicedata);
743 //powerLock((void*)voicedata, false);
747 void show_error_message(VoiceData *vd, stt_error_e reason)
749 if(reason == STT_ERROR_OUT_OF_NETWORK)
751 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
753 int ancs_connected = 0;
755 ret = vconf_get_int("file/private/weconn/ancs_connected", &ancs_connected);
758 PRINTFUNC(DLOG_ERROR, "ancs connected status : %d", ancs_connected);
760 PRINTFUNC(DLOG_ERROR, "vconf for ancs connection ERROR - %d", ret);
762 if (ancs_connected) {
764 snprintf(text, sizeof(text), _(SK_NETWORK_ERROR_FOR_IOS), _(SK_SAMSUNG_GEAR));
766 show_popup_toast((const char*)text, false);
768 set_guide_text(vd, _(SK_NETWORK_ERROR));
771 vd->state = STT_STATE_VAL_INIT;
773 } else if (reason == STT_ERROR_RECORDER_BUSY) {
774 PRINTFUNC(DLOG_WARN, "STT is used by another application");
775 show_popup_toast(_(SK_STT_BUSY), false);
776 vd->state = STT_STATE_VAL_INIT;
778 PRINTFUNC(DLOG_WARN, "Check error code");
779 show_popup_toast(_(SK_STT_BUSY), false);
780 vd->state = STT_STATE_VAL_INIT;
784 static Eina_Bool _start_timer_cb(void* data)
787 VoiceData *voicedata = (VoiceData *) data;
790 voicedata->state = STT_STATE_VAL_PREPARE_LISTENING;
791 voicedata->sttmanager->Start();
793 catch (is::stt::SttException &e) {
794 PRINTFUNC(DLOG_ERROR, "%s", e.what());
796 if (e.GetEcode() == STT_ERROR_OUT_OF_NETWORK)
798 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
799 set_guide_text(voicedata, _(SK_NETWORK_ERROR));
800 voicedata->state = STT_STATE_VAL_INIT;
801 } else if (e.GetEcode() == STT_ERROR_RECORDER_BUSY) {
802 PRINTFUNC(DLOG_WARN, "STT is used by another application");
803 show_popup_toast(_(SK_STT_BUSY), false);
804 voicedata->state = STT_STATE_VAL_INIT;
806 PRINTFUNC(DLOG_WARN, "Check error code");
807 show_popup_toast(_(SK_STT_BUSY), false);
808 voicedata->state = STT_STATE_VAL_INIT;
811 voicedata->start_timer = NULL;
813 return ECORE_CALLBACK_CANCEL;
817 * @brief - cancel button press callback for cross button
821 void on_initial_anim_press_cb(void *data, Evas_Object *obj, const char *emission, const char *source)
823 PRINTFUNC(NO_PRINT, "");
825 VoiceData *vd = (VoiceData *)data;
827 int tempVal = vd->sttmanager->GetCurrent();
828 if(tempVal == STT_STATE_CREATED) {
829 PRINTFUNC(DLOG_WARN, "IGNORE TOUCH event before STT READY. STT is preparing", vd->state);
833 PRINTFUNC(DLOG_DEBUG, "SttManager State : %d", vd->sttmanager->GetCurrent());
834 PRINTFUNC(DLOG_DEBUG, "Ui Voice State : %d", vd->state);
837 case STT_STATE_VAL_INIT:
839 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_INIT");
840 get_stt_default_language(vd);
841 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
843 stt_feedback(VIBRATION_START);
845 if(vd->start_timer) {
846 ecore_timer_del(vd->start_timer);
847 vd->start_timer = NULL;
850 vd->start_timer = ecore_timer_add(0.0, _start_timer_cb, vd);
853 case STT_STATE_VAL_LISTENING :
854 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_LISTENING");
856 vd->state = STT_STATE_VAL_PREPARE_PROCESSING;
857 vd->sttmanager->Stop();
860 * Cuased touch reponse time, it can be called to stop animator.
863 set_guide_text(vd, "");
866 vd->effector->Stop();
868 catch (is::stt::SttException &e) {
869 PRINTFUNC(DLOG_ERROR, "%s", e.what());
871 if(e.GetEcode() != STT_ERROR_INVALID_STATE) {
872 PRINTFUNC(DLOG_DEBUG, "SK_NETWORK_ERROR");
873 set_guide_text(vd, _(SK_RECOGNITION_FAILED));
874 vd->state = STT_STATE_VAL_INIT;
877 vd->effector->Stop(true);
882 case STT_STATE_VAL_PROCESSING:
883 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_PROCESSING");
885 //vd->state = STT_STATE_VAL_PREPARE_CANCEL;
886 vd->sttmanager->Cancel();
888 catch (is::stt::SttException &e) {
889 PRINTFUNC(DLOG_ERROR, "%s", e.what());
894 case STT_STATE_VAL_NOT_RECOGNISED:
895 PRINTFUNC(DLOG_DEBUG, "%s", "STT_STATE_VAL_NOT_RECOGNISED");
896 vd->state = STT_STATE_VAL_INIT ;
899 PRINTFUNC(DLOG_DEBUG, "default [%d]", vd->state);
904 static inline void ea_naviframe_back(void *data, Evas_Object *obj, void *event_info)
908 evas_object_del((Evas_Object *) data);
910 g_setting_window = NULL;
911 g_setting_naviframe = NULL;
914 ecore_event_handler_del(g_evt_key_down);
916 g_evt_key_down = NULL;
919 if(g_more_option_layout){
920 if(eext_more_option_opened_get(g_more_option_layout) == EINA_TRUE) {
921 eext_more_option_opened_set(g_more_option_layout, EINA_FALSE);
926 static char *__get_genlist_title_label(void *data, Evas_Object *obj, const char *part)
928 return strdup(_("WDS_VOICE_OPT_LANGUAGE_ABB"));
931 char *__get_genlist_item_label(void *data, Evas_Object *obj, const char *part)
933 char text[128] = {0, };
935 if(!strcmp(part, "elm.text"))
938 return strdup(_("IDS_VC_BODY_AUTOMATIC"));
941 s = (char *)disp_lang_array[(int)data];
944 char *p = strchr(s, '(');
946 strncpy(text, s, p-s);
948 strncpy(text, s, strlen(s));
951 strncpy(text, "", strlen(""));
955 } else if (!strcmp(part, "elm.text.1")) {
956 if ((int)data == 0) {
958 value = vconf_get_str(VCONFKEY_LANGSET);
960 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
963 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
965 char system_lang[6] = {0, };
966 strncpy(system_lang, value , 5);
969 // confirm whether the system language is supported by stt engine or not.
970 // if supported, set the language
971 // otherwise, set language to en_US
972 return strdup(get_lang_label(system_lang));
976 s = (char *)disp_lang_array[(int)data];
979 char *p = strchr(s, '(');
981 strncpy(text, p+1, strlen(s)-(p-s)-2);
983 strncpy(text, s, strlen(s));
986 strncpy(text, "", strlen(""));
994 static Evas_Object *__get_genlist_item_content(void *data, Evas_Object *obj, const char *part)
996 int index = (int)data;
997 Evas_Object * content = NULL;
999 if (!strcmp(part, "elm.icon")) {
1000 content = elm_radio_add(obj);
1001 elm_radio_state_value_set(content, index);
1002 elm_radio_group_add(content, radio_gp);
1003 evas_object_size_hint_weight_set(content, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1004 evas_object_propagate_events_set(content, EINA_TRUE);
1005 evas_object_size_hint_align_set(content, EVAS_HINT_FILL, EVAS_HINT_FILL);
1006 elm_object_style_set(content, "list");
1011 static int get_language_value()
1014 int lang = 0, ret = 0;
1016 ret = preference_get_int(PREFERENCE_ISE_STT_LANGUAGE, &lang);
1017 if(PREFERENCE_ERROR_NONE != ret){
1018 PRINTFUNC(DLOG_ERROR, "preference_get_int error!(%d)", ret);
1019 preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)2); //auto
1023 int lang = 0, ret = 0;
1025 ret = vconf_get_int(VCONFKEY_ISE_STT_LANGUAGE, &lang);
1027 PRINTFUNC(DLOG_ERROR, "Vconf_get_int error!(%d)", ret);
1031 if(lang < 0 || lang > 6) {
1032 PRINTFUNC(DLOG_WARN, "vconf lang orig(%d) to be 0", lang);
1035 PRINTFUNC(DLOG_DEBUG, "n66 current language value for stt (%s).", disp_lang_array[lang]);
1041 static void set_language_value(int type)
1043 // Add implementation to store language type.
1047 ret = preference_set_int(PREFERENCE_ISE_STT_LANGUAGE, (int)type);
1048 if(PREFERENCE_ERROR_NONE != ret){
1049 PRINTFUNC(DLOG_ERROR, "preference_set_int error!(%d)", ret);
1053 ret = vconf_set_int(VCONFKEY_ISE_STT_LANGUAGE, (int) type);
1055 PRINTFUNC(DLOG_ERROR, "Vconf_set_int error!(%d)", ret);
1059 PRINTFUNC(DLOG_DEBUG, "language type (%d)", type);
1064 static void get_stt_default_language(VoiceData *my_voicedata)
1067 PRINTFUNC(DLOG_ERROR, "my_voicedata NULL");
1071 if(my_voicedata->kbd_lang) {
1072 free(my_voicedata->kbd_lang);
1073 my_voicedata->kbd_lang = NULL;
1078 STT_VOICE_LANGUAGE_N66_I stt_lang;
1079 stt_lang = (STT_VOICE_LANGUAGE_N66_I)get_language_value();
1081 PRINTFUNC(DLOG_DEBUG, "language type (%d)", stt_lang);
1084 case STT_VOICE_N66_AUTO :
1086 stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1088 // get system display language
1090 value = vconf_get_str(VCONFKEY_LANGSET);
1091 if (NULL == value) {
1092 PRINTFUNC(DLOG_ERROR, "Fail to get display language");
1095 PRINTFUNC(DLOG_DEBUG, "system language (%s)", value);
1097 char system_lang[6] = {0, };
1098 strncpy(system_lang, value , 5);
1101 // confirm whether the system language is supported by stt engine or not.
1102 // if supported, set the language
1103 // otherwise, set language to en_US
1104 if(is_lang_supported_by_stt(system_lang) == TRUE) {
1105 my_voicedata->kbd_lang = strdup(system_lang);
1106 PRINTFUNC(DLOG_DEBUG, "Set auto language (%s)", system_lang);
1108 my_voicedata->kbd_lang = strdup("en_US");
1109 PRINTFUNC(DLOG_DEBUG, "System language is not supported by STT (%s), en_US will be set", system_lang);
1113 case STT_VOICE_N66_EN_US :
1114 case STT_VOICE_N66_ES_US :
1115 case STT_VOICE_N66_FR_FR :
1116 case STT_VOICE_N66_JA_JP :
1117 case STT_VOICE_N66_KO_KR :
1118 case STT_VOICE_N66_ZH_CN :
1120 my_voicedata->kbd_lang = strdup(supported_language[stt_lang]);
1124 my_voicedata->kbd_lang = strdup("en_US");
1129 PRINTFUNC(DLOG_DEBUG, "stt language (%s)", my_voicedata->kbd_lang);
1132 static Eina_Bool close_setting_window_idler_cb(void *data)
1134 if(g_setting_window && g_setting_naviframe) {
1135 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1138 return ECORE_CALLBACK_CANCEL;
1141 static void language_set_genlist_radio_cb(void *data, Evas_Object *obj, void *event_info)
1143 PRINTFUNC(DLOG_DEBUG, "");
1147 Evas_Object *genlist = (Evas_Object *) data;
1149 Elm_Object_Item * item = (Elm_Object_Item *) event_info;
1151 elm_genlist_item_selected_set(item, 0);
1152 index = (int)elm_object_item_data_get(item);
1153 elm_genlist_item_update(item);
1155 set_language_value(index);
1157 elm_radio_value_set(radio_gp, index);
1158 ecore_timer_add(0.3, close_setting_window_idler_cb, NULL);
1161 static void language_changed_cb2(void *data, Evas_Object *obj, const char *emission, const char *source)
1164 elm_genlist_realized_items_update(obj);
1167 Eina_Bool _ise_keydown_cb(void *data, int type, void *event)
1169 PRINTFUNC(DLOG_DEBUG, "");
1170 if(type == ECORE_EVENT_KEY_DOWN && g_setting_window && g_setting_naviframe) {
1171 PRINTFUNC(DLOG_DEBUG, "window will be deleted.");
1172 ea_naviframe_back(g_setting_window, g_setting_naviframe, NULL);
1175 return ECORE_CALLBACK_DONE;
1179 static void _language_list_item_realized(void *data, Evas_Object *obj, void *event_info) //called when list scrolled
1181 PRINTFUNC(DLOG_DEBUG, "%s", __func__);
1184 static Evas_Object *create_language_list(Evas_Object *parent)
1186 if(!parent) return NULL;
1188 Evas_Object *genlist = elm_genlist_add(parent);
1189 if (!genlist) return NULL;
1191 elm_genlist_mode_set(genlist, ELM_LIST_COMPRESS);
1192 elm_genlist_homogeneous_set(genlist, EINA_TRUE);
1193 // uxt_genlist_set_bottom_margin_enabled(genlist, EINA_TRUE);
1195 Evas_Object *circle_language_genlist = eext_circle_object_genlist_add(genlist, NULL);
1196 eext_circle_object_genlist_scroller_policy_set(circle_language_genlist, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1197 evas_object_resize(circle_language_genlist, 360, 360);
1198 evas_object_show(circle_language_genlist);
1199 eext_rotary_object_event_activated_set(circle_language_genlist, EINA_TRUE);
1203 Elm_Object_Item * item = NULL;
1204 Elm_Object_Item * item_title = NULL;
1206 evas_object_size_hint_weight_set(genlist, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1207 evas_object_size_hint_align_set(genlist, EVAS_HINT_FILL, EVAS_HINT_FILL);
1209 radio_gp = elm_radio_add(genlist);
1210 elm_radio_state_value_set(radio_gp, -1);
1212 lang_val = get_language_value();
1215 itc_title.item_style = "title";
1216 itc_title.func.text_get = __get_genlist_title_label;
1217 itc_title.func.content_get = NULL;
1219 item_title = elm_genlist_item_append(genlist, &itc_title, (void *)-1, NULL, ELM_GENLIST_ITEM_GROUP, NULL, genlist);
1222 itc_2text.item_style = "2text.1icon.1/sub1.multiline";
1223 itc_2text.func.text_get = __get_genlist_item_label;
1224 itc_2text.func.content_get = __get_genlist_item_content;
1227 item = item_append(genlist, itc_2text, (void *)0, language_set_genlist_radio_cb, genlist); // AUTO
1230 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1231 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1234 if ( item == NULL ) {
1235 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1239 itc_1text.item_style = "1text.1icon.1";
1240 itc_1text.func.text_get = __get_genlist_item_label;
1241 itc_1text.func.content_get = __get_genlist_item_content;
1244 for (i = 1; i < 7; i++)
1246 char *s = (char *)disp_lang_array[i];
1249 item = item_append(genlist, itc_2text, i, language_set_genlist_radio_cb, genlist);
1251 item = item_append(genlist, itc_1text, i, language_set_genlist_radio_cb, genlist);
1255 PRINTFUNC(DLOG_DEBUG, "%d item is choiced.", i);
1256 elm_genlist_item_show(item, ELM_GENLIST_ITEM_SCROLLTO_MIDDLE);
1259 if ( item == NULL ) {
1260 PRINTFUNC(DLOG_DEBUG, "elm_genlist_item_append was failed");
1266 elm_radio_value_set(radio_gp, lang_val);
1268 elm_object_signal_callback_add(genlist, "elm,system,language,change", "elm", language_changed_cb2, NULL);
1269 // eext_rotary_event_callback_set(genlist, _language_list_rotary_cb, NULL);
1270 evas_object_smart_callback_add(genlist, "realized", _language_list_item_realized, NULL);
1273 g_evt_key_down = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN, _ise_keydown_cb, NULL);
1277 void create_setting_window(Evas_Object *more_option_layout)
1281 Evas_Object *window = NULL;
1282 Evas_Object *layout = NULL;
1283 Evas_Object *genlist = NULL;
1284 Evas_Object *naviframe = NULL;
1286 Elm_Object_Item *item = NULL;
1288 const char *str = "mobile";
1291 * Create full size window
1294 window = elm_win_add(NULL, "voice-input-setting", ELM_WIN_BASIC);
1296 PRINTFUNC(DLOG_DEBUG, "it's fail to create window.");
1300 elm_win_title_set(window, "voice-input-setting");
1301 // ecore_x_window_size_get(ecore_x_window_root_first_get(), &w, &h);
1302 elm_win_borderless_set(window, EINA_TRUE);
1303 evas_object_resize(window, w, h);
1305 elm_win_indicator_mode_set(window, ELM_WIN_INDICATOR_HIDE);
1306 elm_win_profiles_set(window, &str, 1);
1312 // ea_theme_style_set(EA_THEME_STYLE_DEFAULT);
1313 // ea_theme_changeable_ui_enabled_set(EINA_TRUE);
1316 * Create layout for language list
1319 layout = elm_layout_add(window);
1321 elm_layout_theme_set(layout, "layout", "application", "default");
1322 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1323 evas_object_show(layout);
1324 elm_win_resize_object_add(window, layout);
1328 * Set Window rotation
1331 if (elm_win_wm_rotation_supported_get(window)) {
1332 const int rots[4] = { 0, 90, 180, 270 };
1333 elm_win_wm_rotation_available_rotations_set(window, rots, 4);
1337 * Activate and show window
1340 elm_win_activate(window);
1341 evas_object_show(window);
1347 naviframe = elm_naviframe_add(layout);
1348 if (naviframe == NULL){
1349 PRINTFUNC(DLOG_DEBUG, "create navi_frame failed");
1352 // ea_object_event_callback_add(naviframe, EA_CALLBACK_BACK, ea_naviframe_back, window);
1353 elm_object_part_content_set(layout, "elm.swallow.content", naviframe);
1356 * Push language list
1359 genlist = create_language_list(naviframe);
1361 //item = elm_naviframe_item_push(naviframe, "IDS_VC_HEADER_VOICE_INPUT_LANGUAGE", NULL, NULL, genlist, NULL);
1362 item = elm_naviframe_item_push(naviframe, NULL, NULL, NULL, genlist, "empty");
1363 //elm_object_item_domain_text_translatable_set(item, PACKAGE, EINA_TRUE);
1365 g_setting_window = window;
1366 g_setting_naviframe = naviframe;
1367 g_more_option_layout = more_option_layout;
1370 static void language_changed_cb(void *data, Evas_Object * obj, void *event_info)
1372 PRINTFUNC(DLOG_DEBUG, "");
1379 void _stt_lang_changed_cb(keynode_t *key, void* data)
1381 PRINTFUNC(DLOG_DEBUG, "");
1384 VoiceData *vd = (VoiceData *) data;
1385 get_stt_default_language(vd);
1386 vd->sttmanager->SetLanguage(std::string(vd->kbd_lang));
1392 static void __done_key_cb(void *data, Evas_Object *obj, void *event_info )
1394 PRINTFUNC(DLOG_DEBUG, "");
1399 VoiceData *voicedata = (VoiceData *)data;
1401 elm_naviframe_item_pop(voicedata->naviframe);
1404 static void __stt_detailed_entry_input_panel_event_cb(void *data, Ecore_IMF_Context *imf_context, int value)
1408 VoiceData *voicedata = (VoiceData *)data;
1411 case ECORE_IMF_INPUT_PANEL_STATE_HIDE: // 1
1412 elm_naviframe_item_pop(voicedata->naviframe);
1414 case ECORE_IMF_INPUT_PANEL_STATE_WILL_SHOW: // 2
1415 PRINTFUNC(DLOG_DEBUG, "keypad state will show.");
1417 case ECORE_IMF_INPUT_PANEL_STATE_SHOW: // 0
1418 PRINTFUNC(DLOG_DEBUG, "keypad state show.");
1423 static void __stt_detailed_entry_del_cb(void *data, Evas *e, Evas_Object *obj, void *event_info)
1426 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(obj);
1427 ecore_imf_context_input_panel_event_callback_del(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb);
1428 PRINTFUNC(DLOG_DEBUG, "input_panel_event_cb is deleted.");
1432 static Evas_Object *create_text_detiled_view(Evas_Object *parent)
1434 string edj_path = get_resource_path();
1435 edj_path = edj_path + STT_EDJ_FILE;
1438 Evas_Object *layout = elm_layout_add(parent);
1439 elm_layout_file_set(layout, edj_path.c_str(), "entry_focused_layout");
1440 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1441 evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1442 evas_object_show(layout);
1445 Evas_Object *entry = elm_entry_add(parent);
1446 evas_object_size_hint_weight_set(entry, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1447 evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, EVAS_HINT_FILL);
1448 // ea_entry_selection_back_event_allow_set(entry, EINA_TRUE);
1449 elm_entry_context_menu_disabled_set(entry, EINA_TRUE);
1450 elm_entry_select_allow_set(entry, EINA_FALSE);
1451 // elm_entry_cursor_handler_disabled_set(entry, EINA_TRUE);
1452 elm_entry_single_line_set(entry, EINA_TRUE);
1453 elm_entry_scrollable_set(entry, EINA_TRUE);
1454 elm_entry_input_panel_return_key_type_set(entry, ELM_INPUT_PANEL_RETURN_KEY_TYPE_DONE);
1456 evas_object_show(entry);
1458 elm_object_part_content_set(layout, "contents", entry);
1462 static Eina_Bool _idler_cb2(void *data)
1464 VoiceData *voicedata = (VoiceData *)data;
1466 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_FALSE);
1468 return ECORE_CALLBACK_CANCEL;
1471 static Eina_Bool __stt_entry_detailed_view_pop_cb(void *data, Elm_Object_Item *it)
1473 PRINTFUNC(DLOG_DEBUG, "");
1475 if(!data) return EINA_FALSE;
1477 VoiceData *voicedata = (VoiceData *)data;
1479 Evas_Object *main_entry = (Evas_Object *)voicedata->main_entry;
1480 Evas_Object *detailed_layout = elm_object_item_part_content_get(it, "elm.swallow.content");
1481 Evas_Object *detailed_entry = elm_object_part_content_get(detailed_layout, "contents");
1483 const char *str = NULL;
1486 pos = elm_entry_cursor_pos_get(detailed_entry);
1487 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1489 str = elm_entry_entry_get(detailed_entry);
1491 voicedata->stt_results.clear();
1492 voicedata->stt_results.push_back(str);
1494 // uxt_scroller_set_auto_scroll_enabled(voicedata->scroller, EINA_TRUE);
1495 elm_entry_entry_set(main_entry, str);
1496 elm_entry_cursor_pos_set(main_entry, pos);
1499 elm_entry_cursor_geometry_get(main_entry, &x, &y, &w, &h);
1500 PRINTFUNC(DLOG_DEBUG, "%d %d %d %d", x, y, w, h);
1502 elm_scroller_region_bring_in(voicedata->scroller, 0, y+h, 300, 168);
1504 ecore_idler_add(_idler_cb2, voicedata);
1509 static void _stt_entry_clicked_cb(void *data, Evas_Object * obj, void *event_info)
1511 PRINTFUNC(DLOG_DEBUG, "");
1516 VoiceData *voicedata = (VoiceData *)data;
1521 pos = elm_entry_cursor_pos_get(obj);
1522 PRINTFUNC(DLOG_DEBUG, "pos = %d", pos);
1524 str = elm_entry_markup_to_utf8(elm_entry_entry_get(obj));
1526 if (str && strlen(str) > 0) {
1528 if (voicedata->sttmanager->GetCurrent() == STT_STATE_RECORDING ||
1529 voicedata->sttmanager->GetCurrent() == STT_STATE_PROCESSING) {
1530 voicedata->sttmanager->Cancel();
1531 PRINTFUNC(DLOG_DEBUG, "stt entry clicked callback during STT recording and processing");
1535 catch(is::stt::SttException &e) {
1536 PRINTFUNC(DLOG_ERROR, "%s", e.what());
1540 Evas_Object *ly_detailed_view = create_text_detiled_view(voicedata->naviframe);
1542 Evas_Object *detailed_entry = elm_object_part_content_get(ly_detailed_view, "contents");
1543 elm_entry_entry_set(detailed_entry, str);
1544 elm_entry_cursor_pos_set(detailed_entry, pos);
1545 evas_object_smart_callback_add(detailed_entry, "activated", __done_key_cb, voicedata); // Register callback for Done key
1547 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(detailed_entry);
1548 ecore_imf_context_input_panel_event_callback_add(imf_context, ECORE_IMF_INPUT_PANEL_STATE_EVENT, __stt_detailed_entry_input_panel_event_cb, voicedata);
1549 evas_object_event_callback_add(detailed_entry, EVAS_CALLBACK_DEL, __stt_detailed_entry_del_cb, NULL);
1552 Elm_Object_Item *navi_it = elm_naviframe_item_push(voicedata->naviframe, NULL, NULL, NULL, ly_detailed_view, NULL);
1553 elm_naviframe_item_pop_cb_set(navi_it, __stt_entry_detailed_view_pop_cb, (void *)voicedata);
1554 elm_naviframe_item_title_enabled_set(navi_it, EINA_FALSE, EINA_FALSE);
1562 void activate_circle_scroller_for_stt_textbox(void* data, Eina_Bool bActivate)
1564 PRINTFUNC(DLOG_DEBUG, "");
1567 VoiceData *voicedata = (VoiceData *)data;
1569 Evas_Object *scroller = NULL;
1570 Evas_Object *circle_scroller = NULL;
1572 scroller = elm_layout_content_get((Evas_Object *)voicedata->layout_main, "text_area");
1573 circle_scroller = (Evas_Object *) evas_object_data_get(scroller, "circle");
1574 eext_rotary_object_event_activated_set(circle_scroller, bActivate);
1577 static Evas_Object *create_textblock(void* data)
1579 if(!data) return NULL;
1581 VoiceData *voicedata = (VoiceData *)data;
1583 Evas_Object *scroller = NULL;
1584 Evas_Object *box = NULL;
1585 Evas_Object *inner_layout = NULL;
1586 Evas_Object *entry = NULL;
1587 Evas_Object *tb = NULL;
1588 Evas_Object *circle_scroller = NULL;
1590 string edj_path = get_resource_path();
1591 edj_path = edj_path + STT_EDJ_FILE;
1593 scroller = elm_scroller_add(voicedata->layout_main);
1595 elm_scroller_loop_set(scroller, EINA_FALSE, EINA_FALSE);
1597 evas_object_size_hint_align_set(scroller, EVAS_HINT_FILL, EVAS_HINT_FILL);
1598 evas_object_size_hint_weight_set(scroller, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1600 // elm_scroller_page_size_set(scroller, 0, 50);
1601 // elm_scroller_page_scroll_limit_set(scroller, 0, 1);
1603 elm_object_scroll_lock_x_set(scroller, EINA_TRUE);
1605 // uxt_scroller_set_auto_scroll_enabled(scroller, EINA_FALSE);
1607 circle_scroller = eext_circle_object_scroller_add(scroller, app_data->circle_surface);
1608 eext_circle_object_scroller_policy_set(circle_scroller, ELM_SCROLLER_POLICY_OFF, ELM_SCROLLER_POLICY_AUTO);
1609 eext_rotary_object_event_activated_set(circle_scroller, EINA_TRUE);
1611 box = elm_box_add(scroller);
1613 inner_layout = elm_layout_add(scroller);
1614 elm_layout_file_set(inner_layout, edj_path.c_str(), "layout_textblock");
1615 evas_object_size_hint_weight_set(inner_layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1617 elm_object_signal_callback_add(inner_layout, "do_scroll", "entry",
1618 [](void *data, Evas_Object *obj, const char* signal, const char* e)
1620 _bring_in_cb((void *) data);
1621 }, (void *) scroller);
1623 entry = elm_entry_add(inner_layout);
1624 voicedata->main_entry = entry;
1625 elm_entry_editable_set(entry, EINA_FALSE);
1627 #define FORMAT_TEXT_AREA_FONT_STYLE \
1628 "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'"
1630 char customStyle[512];
1631 // ea_theme_color_get("AT02112", &r, &g, &b, &a, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
1632 snprintf(customStyle, 512, FORMAT_TEXT_AREA_FONT_STYLE, r, g, b, a, r, g, b, a);
1634 elm_entry_text_style_user_push(entry, customStyle);
1636 evas_object_smart_callback_add(entry, "clicked", _stt_entry_clicked_cb, voicedata);
1638 elm_object_part_content_set(inner_layout, "elm.swallow.content", entry);
1640 elm_box_pack_end(box, inner_layout);
1642 elm_object_content_set(scroller, box);
1643 evas_object_data_set(scroller, "inner_layout", (void *) inner_layout);
1644 evas_object_data_set(scroller, "circle", (void *) circle_scroller);
1645 evas_object_show(scroller);
1646 evas_object_show(inner_layout);
1651 static Evas_Object *create_progressbar(Evas_Object *parent)
1653 Evas_Object *progressbar = NULL;
1655 progressbar = elm_progressbar_add(parent);
1656 elm_object_style_set(progressbar, "voice_input/process/small");
1657 //elm_progressbar_pulse(progressbar, EINA_TRUE);
1659 evas_object_size_hint_align_set(progressbar, EVAS_HINT_FILL, EVAS_HINT_FILL);
1660 evas_object_size_hint_weight_set(progressbar, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1662 // ea_theme_object_color_replace(progressbar, "B065L6", "AO012");
1664 evas_object_show(progressbar);
1669 static Evas_Object *create_fullview(Evas_Object *parent, VoiceData *r_voicedata)
1671 PRINTFUNC(NO_PRINT, "");
1673 Evas_Object *more_option_layout = NULL;
1674 Evas_Object *layout_main = NULL;
1675 Evas_Object *lang_btn_box = NULL;
1676 Evas_Object *lang_btn = NULL;
1677 Evas_Object *to = NULL;
1678 Evas_Object *ao = NULL;
1680 char *lang_type_str = NULL;
1683 int is_screen_reader_on = FALSE;
1685 VoiceData *voicedata = r_voicedata;
1688 * add app_default_layout
1691 MoreOption* mo = new MoreOption(parent, voicedata);
1697 layout_main = elm_layout_add(mo->getMoreOptionLayout());
1702 voicedata->layout_main = layout_main;
1704 string edj_path = get_resource_path();
1705 edj_path = edj_path + STT_EDJ_FILE;
1707 if (vconf_get_bool(VCONFKEY_SETAPPL_ACCESSIBILITY_TTS, &is_screen_reader_on) == -1) {
1708 PRINTFUNC(DLOG_ERROR, "Cannot read value of screen reader from vconf");
1711 evas_object_size_hint_weight_set(layout_main, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1712 evas_object_size_hint_align_set(layout_main, EVAS_HINT_FILL, EVAS_HINT_FILL);
1714 elm_layout_file_set(layout_main, edj_path.c_str(), "mic_control");
1716 //elm_object_content_set(parent, layout_main);
1718 //Canvas for Cairo effect
1719 Evas_Object *canvas = evas_object_image_filled_add(evas_object_evas_get(layout_main));
1720 // evas_object_image_alpha_set(canvas, EINA_TRUE);
1721 evas_object_size_hint_align_set(canvas, EVAS_HINT_FILL, EVAS_HINT_FILL);
1722 evas_object_size_hint_weight_set(canvas, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1723 evas_object_move(canvas, 0, 0);
1725 Evas_Coord CanvasW, CanvasH;
1728 evas_object_image_size_set(canvas, CanvasW, CanvasH);
1729 evas_object_resize(canvas, CanvasW, CanvasH);
1730 evas_object_size_hint_min_set(canvas, CanvasW, CanvasH);
1731 evas_object_show(canvas);
1733 elm_object_part_content_set(layout_main, "EFFECT_BG", canvas);
1737 Evas_Object *m_mic_button = elm_button_add(layout_main);
1738 elm_object_style_set(m_mic_button, "vic/micbutton");
1739 elm_object_part_content_set(layout_main, "MIC", m_mic_button);
1741 elm_object_disabled_set(m_mic_button, EINA_TRUE);
1742 evas_object_smart_callback_add(m_mic_button, "clicked", on_mic_button_press_cb, (void *) voicedata);
1744 voicedata->mic_button = m_mic_button;
1746 if(voicedata->btn_disabling_timer == NULL){
1747 voicedata->btn_disabling_timer = ecore_timer_add(2.0, _mic_button_enable_cb, voicedata);
1750 // ecore_idler_add(_idler_cb, voicedata);
1751 ecore_timer_add(0.6, _idler_cb, voicedata);
1753 // Confirm panel layout
1754 Evas_Object *panel_layout;
1755 panel_layout = elm_layout_add(layout_main);
1756 elm_layout_theme_set(panel_layout, "layout", "drawer", "panel");
1757 evas_object_show(panel_layout);
1761 panel = elm_panel_add(panel_layout);
1762 elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
1763 elm_layout_theme_set(panel, "panel", "left_confirm", "default");
1764 elm_layout_theme_set(panel, "panel", "left_sending", "default");
1766 elm_layout_signal_callback_add(panel, "cue,clicked", "elm", _panel_cue_clicked_cb, (void *) voicedata);
1767 evas_object_show(panel);
1769 elm_object_part_content_set(panel_layout, "elm.swallow.right", panel);
1770 elm_object_part_content_set(layout_main, "left_panel_area", panel_layout);
1772 elm_object_signal_emit(panel, "elm,state,disabled", "elm");
1773 elm_panel_toggle(panel);
1777 Evas_Object *scroller = create_textblock(voicedata);
1778 elm_object_part_content_set(layout_main, "text_area", scroller);
1779 voicedata->scroller = scroller;
1782 Evas_Object *progress_bar = create_progressbar(layout_main);
1783 elm_object_part_content_set(layout_main, "PROGRESS_BAR", progress_bar);
1784 voicedata->progressbar = progress_bar;
1787 elm_object_signal_callback_add(layout_main, "idle,state,pulse,visible", "", on_initial_anim_press_cb, voicedata);
1789 mo->SetContentLayout(layout_main);
1794 int is_lang_supported_by_stt(char lang[])
1796 /* to check if the language is supported by stt */
1798 for (index = (sizeof(supported_language) / sizeof(supported_language[0]))-1; index != 0; index--)
1800 if (!strcmp(lang, supported_language[index])) {
1801 PRINTFUNC(DLOG_DEBUG, "current lang supported (%s)", supported_language[index]);
1806 PRINTFUNC(DLOG_DEBUG, "current lang not supported (%s)", lang);
1811 int init_voice(Evas_Object *parent, const char *lang, VoiceData *r_voicedata)
1813 PRINTFUNC(DLOG_DEBUG, "[init_voice]");
1815 // stt_is_samsung_asr(&g_is_n66);
1817 VoiceData *voicedata = (VoiceData *)r_voicedata;
1823 PRINTFUNC(DLOG_ERROR, "Parent is NULL\n");
1826 PRINTFUNC(NO_PRINT, "Parent is there");
1829 voicedata->voicefw_state = 0;
1831 /* Set Voice Language */
1832 if(voicedata->kbd_lang){
1833 free(voicedata->kbd_lang);
1834 voicedata->kbd_lang = NULL;
1837 //stt_get_default_language(my_voicedata->voicefw_handle, &my_voicedata->kbd_lang);
1838 get_stt_default_language(voicedata);
1839 if(NULL == voicedata->kbd_lang || FALSE == is_lang_supported_by_stt(voicedata->kbd_lang)) {
1840 voicedata->kbd_lang = strdup("en_US");
1843 PRINTFUNC(DLOG_DEBUG, "Voice input active language is : %s", voicedata->kbd_lang);
1845 voicedata->naviframe = parent;
1847 if (NULL == voicedata->naviframe) {
1854 static Eina_Bool init_view(void *data)
1856 VoiceData *voicedata = (VoiceData *)data;
1858 if(voicedata == NULL)
1859 return ECORE_CALLBACK_CANCEL;
1861 voicedata->layout_main = create_fullview(voicedata->naviframe, voicedata);
1863 if (voicedata->layout_main) {
1864 evas_object_show(voicedata->layout_main);
1867 return ECORE_CALLBACK_CANCEL;
1871 Evas_Object *show_voice_window(Evas_Object *parent, VoiceData *r_voicedata)
1873 PRINTFUNC(NO_PRINT, "[show_voice_window]");
1875 VoiceData *voicedata = (VoiceData *)r_voicedata;
1881 PRINTFUNC(NO_PRINT, "Parent is NULL\n");
1884 PRINTFUNC(NO_PRINT, "Parent is there");
1887 if (NULL != voicedata->layout_main) {
1888 PRINTFUNC(DLOG_DEBUG, "delete previous layout");
1889 evas_object_del((voicedata)->layout_main);
1890 (voicedata)->layout_main = NULL;
1893 if (NULL != voicedata->effector) {
1894 PRINTFUNC(DLOG_DEBUG, "delete previous effect");
1895 delete (voicedata->effector);
1896 (voicedata)->effector = NULL;
1899 if (NULL != voicedata->ieffect) {
1900 PRINTFUNC(DLOG_DEBUG, "delete previous ieffect");
1901 delete (voicedata->ieffect);
1902 voicedata->ieffect = NULL;
1906 delete voicedata->mo;
1907 voicedata->mo = NULL;
1910 init_view((void *)voicedata);
1911 return voicedata->layout_main;
1915 void on_stt_pause(VoiceData *r_voicedata){
1916 PRINTFUNC(DLOG_DEBUG, "");
1918 VoiceData *voicedata = (VoiceData *)r_voicedata;
1922 //voicedata->state = STT_STATE_VAL_PREPARE_CANCEL;
1923 voicedata->sttmanager->Cancel();
1924 }catch(is::stt::SttException &e){
1925 PRINTFUNC(DLOG_ERROR, "reason : %s", e.what());
1928 //Hide more option and language settings by interrupt scenario.
1929 close_setting_window_idler_cb(NULL);
1930 Evas_Object *mo_layout = voicedata->mo->getMoreOptionLayout();
1932 if(eext_more_option_opened_get(mo_layout) == EINA_TRUE) {
1933 eext_more_option_opened_set(mo_layout, EINA_FALSE);
1939 void on_destroy(VoiceData *r_voicedata)
1941 PRINTFUNC(NO_PRINT, "");
1943 VoiceData *voicedata = (VoiceData *)r_voicedata;
1945 int result = STT_ERROR_NONE;
1949 if (NULL != voicedata) {
1950 if (NULL != voicedata->layout_main) {
1951 voicedata->layout_main = NULL;
1954 if (NULL != voicedata->naviframe) {
1955 voicedata->naviframe = NULL;
1958 if (NULL != voicedata->start_timer) {
1959 ecore_timer_del(voicedata->start_timer);
1960 voicedata->start_timer = NULL;
1963 if (NULL != voicedata->refresh_timer) {
1964 ecore_timer_del(voicedata->refresh_timer);
1965 voicedata->refresh_timer = NULL;
1968 if (NULL != voicedata->progressbar_timer) {
1969 ecore_timer_del(voicedata->progressbar_timer);
1970 voicedata->progressbar_timer = NULL;
1971 elm_progressbar_pulse(voicedata->progressbar, EINA_FALSE);
1974 if (NULL != voicedata->textblock_timer) {
1975 ecore_timer_del(voicedata->textblock_timer);
1976 voicedata->textblock_timer = NULL;
1979 if (NULL != voicedata->guide_text_timer) {
1980 ecore_timer_del(voicedata->guide_text_timer);
1981 voicedata->guide_text_timer = NULL;
1984 if (NULL != voicedata->btn_disabling_timer) {
1985 ecore_timer_del(voicedata->btn_disabling_timer);
1986 voicedata->btn_disabling_timer = NULL;
1989 if (NULL != voicedata->power_unlock_timer) {
1990 ecore_timer_del(voicedata->power_unlock_timer);
1991 voicedata->power_unlock_timer = NULL;
1994 if(voicedata->kbd_lang) {
1995 free(voicedata->kbd_lang);
1996 voicedata->kbd_lang = NULL;
1999 if(voicedata->ieffect) {
2000 delete voicedata->ieffect;
2001 voicedata->ieffect = NULL;
2004 if(voicedata->effector) {
2005 delete voicedata->effector;
2006 voicedata->effector = NULL;
2010 delete voicedata->mo;
2011 voicedata->mo = NULL;
2014 if(voicedata->sttmanager) {
2015 delete voicedata->sttmanager;
2016 voicedata->sttmanager = NULL;
2019 if(voicedata->sttfeedback) {
2020 delete voicedata->sttfeedback;
2021 voicedata->sttfeedback = NULL;