@mhpdev/react-native-speech v1.1.0
react-native-speech
A high-performance text-to-speech library built for bare React Native and Expo, compatible with Android and iOS. It enables seamless speech management and provides events for detailed synthesis management.
Only New Architecture: This library is currently compatible with the new architecture. If you're using React Native 0.76 or higher, it is already enabled. However, if your React Native version is between 0.68 and 0.75, you need to enable it first. Click here if you need help enabling the new architecture
Preview
| Android | iOS |
|---|---|
| Android Preview | iOS Preview |
Features
🚀 High-performance library created with Turbo Modules for both Android and iOS
🎛️ Provides essential and useful methods for full control over synthesis
😎 Support for
pauseandresume, along withonResumeandonPauseevents, for Android too (On Android, unlike iOS—which does not natively support these features—this library implements its own handling)🖍️ Provides a customizable HighlightedText component to display the currently spoken text
📡 Offers useful events for more precise control over synthesis
✅ Completely type-safe and written in TypeScript (on the React Native side)
Installation
Bare React Native
Install the package using either npm or Yarn:
npm install @mhpdev/react-native-speechOr with Yarn:
yarn add @mhpdev/react-native-speechExpo
For Expo projects, follow these steps:
Install the package:
npx expo install @mhpdev/react-native-speechSince it is not supported on Expo Go, run:
npx expo prebuild
Usage
To learn how to use the library, check out the usage section.
Quick Start
import React from 'react';
import Speech from '@mhpdev/react-native-speech';
import {SafeAreaView, StyleSheet, Text, TouchableOpacity} from 'react-native';
const App: React.FC = () => {
const onSpeakPress = () => {
Speech.speak('Hello World!');
};
return (
<SafeAreaView style={styles.container}>
<TouchableOpacity style={styles.button} onPress={onSpeakPress}>
<Text style={styles.buttonText}>Speak</Text>
</TouchableOpacity>
</SafeAreaView>
);
};
export default App;
const styles = StyleSheet.create({
container: {
flex: 1,
alignItems: 'center',
justifyContent: 'center',
},
button: {
padding: 12.5,
borderRadius: 5,
backgroundColor: 'skyblue',
},
buttonText: {
fontSize: 22,
fontWeight: '600',
},
});To become more familiar with the usage of the library, check out the example project.
Contributing
See the contributing guide to learn how to contribute to the repository and the development workflow.
License
MIT
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago