-
-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
#58 Add a pause between each paragraph #89
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,7 +6,6 @@ | |
import android.os.Environment; | ||
import android.speech.tts.TextToSpeech; | ||
import android.speech.tts.UtteranceProgressListener; | ||
import android.text.TextUtils; | ||
import android.util.Log; | ||
import android.view.LayoutInflater; | ||
import android.view.View; | ||
|
@@ -58,9 +57,11 @@ public class ChapterFragment extends Fragment implements AudioListener { | |
final static String PICTURES_PATH = FILES_PATH + Environment.DIRECTORY_PICTURES + "/"; | ||
final static String MUSIC_PATH = FILES_PATH + Environment.DIRECTORY_MUSIC + "/"; | ||
|
||
private final static long PARAGRAPH_PAUSE = 1000; | ||
|
||
private StoryBookChapterGson storyBookChapter; | ||
|
||
protected String chapterText = ""; | ||
protected String[] chapterText = {}; | ||
|
||
private RecyclerView chapterRecyclerView; | ||
|
||
|
@@ -159,6 +160,7 @@ public void onItemClick(WordGson wordWithAudio, View view, int position) { | |
chapterRecyclerView.setAdapter(wordViewAdapter); | ||
} | ||
|
||
chapterText = new String[storyBookParagraphGsons.size()]; | ||
for (int paragraphIndex = 0; paragraphIndex < storyBookParagraphGsons.size(); paragraphIndex++) { | ||
Log.i(getClass().getName(), "storyBookParagraphGson.getOriginalText(): \"" + storyBookParagraphGsons.get(paragraphIndex).getOriginalText() + "\""); | ||
|
||
|
@@ -167,10 +169,7 @@ public void onItemClick(WordGson wordWithAudio, View view, int position) { | |
Log.i(getClass().getName(), "wordsInOriginalText.length: " + wordsInOriginalText.length); | ||
Log.i(getClass().getName(), "Arrays.toString(wordsInOriginalText): " + Arrays.toString(wordsInOriginalText)); | ||
|
||
if (!TextUtils.isEmpty(chapterText)) { | ||
chapterText += "\n\n"; | ||
} | ||
chapterText += originalText; | ||
chapterText[paragraphIndex] = originalText; | ||
|
||
List<WordGson> wordAudios = storyBookParagraphGsons.get(paragraphIndex).getWords(); | ||
Log.i(getClass().getName(), "words: " + wordAudios); | ||
|
@@ -189,7 +188,7 @@ public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceStat | |
super.onViewCreated(view, savedInstanceState); | ||
|
||
// Add button for initializing Text-to-Speech (TTS) | ||
final String finalChapterText = chapterText; | ||
final String[] finalChapterText = chapterText; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
FloatingActionButton fab = view.findViewById(R.id.fab); | ||
fab.setOnClickListener(new View.OnClickListener() { | ||
@Override | ||
|
@@ -200,7 +199,7 @@ public void onClick(View view) { | |
}); | ||
} | ||
|
||
public void playAudio(final String chapterText, final AudioListener audioListener) { | ||
public void playAudio(final String[] chapterText, final AudioListener audioListener) { | ||
List<StoryBookParagraphGson> storyBookParagraphs = storyBookChapter.getStoryBookParagraphs(); | ||
StoryBookParagraphGson storyBookParagraphGson = storyBookParagraphs.get(0); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It looks like we have hardcoded a selection of only the first paragraph, which is probably the audio is not being played correctly for chapters containing more than 1 paragraph. I created a separate issue for this here: #90 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I'll take that issue There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
@gscdev Great, thank you! 🙂 |
||
String transcription = storyBookParagraphGson.getOriginalText(); | ||
|
@@ -213,8 +212,11 @@ public void playAudio(final String chapterText, final AudioListener audioListene | |
// Fall back to TTS | ||
tts.setOnUtteranceProgressListener(getUtteranceProgressListener(audioListener)); | ||
|
||
Log.i(getClass().getName(), "chapterText: \"" + chapterText + "\""); | ||
tts.speak(chapterText.replaceAll("[-*]", ""), TextToSpeech.QUEUE_FLUSH, null, "0"); | ||
Log.i(getClass().getName(), "chapterText: \"" + Arrays.toString(chapterText) + "\""); | ||
for (String paragraph : chapterText) { | ||
tts.speak(paragraph.replaceAll("[-*]", ""), TextToSpeech.QUEUE_ADD, null, "0"); | ||
tts.playSilentUtterance(PARAGRAPH_PAUSE, TextToSpeech.QUEUE_ADD, null); | ||
} | ||
} | ||
} | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Perhaps rename to
chapterParagraphs
?