OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "chrome/browser/speech/tts_android.h" | |
6 | |
7 #include <string> | |
8 | |
9 #include "base/android/jni_string.h" | |
10 #include "base/memory/singleton.h" | |
11 #include "base/utf_string_conversions.h" | |
12 #include "chrome/browser/speech/tts_controller.h" | |
13 #include "jni/TtsPlatformImpl_jni.h" | |
14 | |
15 using base::android::AttachCurrentThread; | |
16 | |
17 // static | |
18 TtsPlatformImpl* TtsPlatformImpl::GetInstance() { | |
19 return TtsPlatformImplAndroid::GetInstance(); | |
20 } | |
21 | |
22 TtsPlatformImplAndroid::TtsPlatformImplAndroid() | |
23 : utterance_id_(0) { | |
24 JNIEnv* env = AttachCurrentThread(); | |
25 java_ref_.Reset( | |
26 Java_TtsPlatformImpl_create(env, | |
27 reinterpret_cast<jint>(this), | |
28 base::android::GetApplicationContext())); | |
29 } | |
30 | |
31 TtsPlatformImplAndroid::~TtsPlatformImplAndroid() { | |
32 JNIEnv* env = AttachCurrentThread(); | |
33 Java_TtsPlatformImpl_destroy(env, java_ref_.obj()); | |
34 } | |
35 | |
36 bool TtsPlatformImplAndroid::Speak( | |
37 int utterance_id, | |
38 const std::string& utterance, | |
39 const std::string& lang, | |
40 const VoiceData& voice, | |
41 const UtteranceContinuousParameters& params) { | |
42 JNIEnv* env = AttachCurrentThread(); | |
43 if (!Java_TtsPlatformImpl_isInitialized(env, java_ref_.obj())) | |
44 return false; | |
45 | |
46 jboolean success = Java_TtsPlatformImpl_speak( | |
47 env, java_ref_.obj(), | |
48 utterance_id, | |
49 base::android::ConvertUTF8ToJavaString(env, utterance).Release(), | |
50 base::android::ConvertUTF8ToJavaString(env, lang).Release(), | |
51 params.rate, params.pitch, params.volume); | |
52 if (success) { | |
bulach
2013/05/16 11:10:28
nit: the "else" is unecessary, and it'd probably b
dmazzoni
2013/05/16 16:36:40
Done.
| |
53 utterance_ = utterance; | |
54 utterance_id_ = utterance_id; | |
55 return true; | |
56 } else { | |
57 return false; | |
58 } | |
59 } | |
60 | |
61 bool TtsPlatformImplAndroid::StopSpeaking() { | |
62 JNIEnv* env = AttachCurrentThread(); | |
63 Java_TtsPlatformImpl_stop(env, java_ref_.obj()); | |
64 utterance_id_ = 0; | |
65 utterance_.clear(); | |
66 return true; | |
67 } | |
68 | |
69 bool TtsPlatformImplAndroid::IsSpeaking() { | |
70 return (utterance_id_ != 0); | |
71 } | |
72 | |
73 void TtsPlatformImplAndroid::GetVoices( | |
74 std::vector<VoiceData>* out_voices) { | |
75 JNIEnv* env = AttachCurrentThread(); | |
76 if (!Java_TtsPlatformImpl_isInitialized(env, java_ref_.obj())) | |
77 return; | |
78 | |
79 int count = Java_TtsPlatformImpl_getVoiceCount(env, java_ref_.obj()); | |
80 for (int i = 0; i < count; ++i) { | |
81 out_voices->push_back(VoiceData()); | |
82 VoiceData& data = out_voices->back(); | |
bulach
2013/05/16 11:10:28
I think we don't normally use mutable refs.. presu
dmazzoni
2013/05/16 16:36:40
I'm using this pattern consistently in chrome/brow
| |
83 data.native = true; | |
84 data.name = base::android::ConvertJavaStringToUTF8( | |
85 Java_TtsPlatformImpl_getVoiceName(env, java_ref_.obj(), i)); | |
86 data.lang = base::android::ConvertJavaStringToUTF8( | |
87 Java_TtsPlatformImpl_getVoiceLanguage(env, java_ref_.obj(), i)); | |
88 data.gender = TTS_GENDER_NONE; | |
89 data.events.insert(TTS_EVENT_START); | |
90 data.events.insert(TTS_EVENT_END); | |
91 data.events.insert(TTS_EVENT_ERROR); | |
92 } | |
93 } | |
94 | |
95 void TtsPlatformImplAndroid::VoicesChanged(JNIEnv* env, jobject obj) { | |
96 TtsController::GetInstance()->VoicesChanged(); | |
97 } | |
98 | |
99 void TtsPlatformImplAndroid::OnEndEvent( | |
100 JNIEnv* env, jobject obj, jint utterance_id) { | |
101 if (utterance_id != utterance_id_) | |
102 return; | |
103 | |
104 TtsController::GetInstance()->OnTtsEvent( | |
105 utterance_id_, TTS_EVENT_END, utterance_.size(), std::string()); | |
106 utterance_id_ = 0; | |
107 utterance_.clear(); | |
bulach
2013/05/16 11:10:28
nit: 100-107 is fairly similar to 112-118, so perh
dmazzoni
2013/05/16 16:36:40
Done.
| |
108 } | |
109 | |
110 void TtsPlatformImplAndroid::OnErrorEvent( | |
111 JNIEnv* env, jobject obj, jint utterance_id) { | |
112 if (utterance_id != utterance_id_) | |
113 return; | |
114 | |
115 TtsController::GetInstance()->OnTtsEvent( | |
116 utterance_id_, TTS_EVENT_ERROR, 0, std::string()); | |
117 utterance_id_ = 0; | |
118 utterance_.clear(); | |
119 } | |
120 | |
121 void TtsPlatformImplAndroid::OnStartEvent( | |
122 JNIEnv* env, jobject obj, jint utterance_id) { | |
123 if (utterance_id != utterance_id_) | |
124 return; | |
125 | |
126 TtsController::GetInstance()->OnTtsEvent( | |
127 utterance_id_, TTS_EVENT_START, 0, std::string()); | |
128 } | |
129 | |
130 // static | |
131 TtsPlatformImplAndroid* TtsPlatformImplAndroid::GetInstance() { | |
132 return Singleton<TtsPlatformImplAndroid>::get(); | |
133 } | |
134 | |
135 // static | |
136 bool TtsPlatformImplAndroid::Register(JNIEnv* env) { | |
137 return RegisterNativesImpl(env); | |
138 } | |
OLD | NEW |