Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
21_22-J 38
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
21_22-J 38
21_22-J 38
Commits
cd33709f
Commit
cd33709f
authored
Apr 27, 2022
by
Lihinikaduwa D.N.R.
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
voice recorder created
parent
5b8b75b4
Changes
5
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
895 additions
and
9 deletions
+895
-9
frontend/package-lock.json
frontend/package-lock.json
+580
-3
frontend/package.json
frontend/package.json
+1
-0
frontend/src/screen/auth/Login.js
frontend/src/screen/auth/Login.js
+4
-3
frontend/src/screen/reading/ReadActivity.js
frontend/src/screen/reading/ReadActivity.js
+67
-3
frontend/src/screen/reading/sample.js
frontend/src/screen/reading/sample.js
+243
-0
No files found.
frontend/package-lock.json
View file @
cd33709f
This diff is collapsed.
Click to expand it.
frontend/package.json
View file @
cd33709f
...
@@ -11,6 +11,7 @@
...
@@ -11,6 +11,7 @@
},
},
"dependencies"
:
{
"dependencies"
:
{
"@react-native-community/netinfo"
:
"^7.1.7"
,
"@react-native-community/netinfo"
:
"^7.1.7"
,
"@react-native-voice/voice"
:
"^3.2.3"
,
"@react-navigation/drawer"
:
"^6.1.8"
,
"@react-navigation/drawer"
:
"^6.1.8"
,
"@react-navigation/native"
:
"^6.0.6"
,
"@react-navigation/native"
:
"^6.0.6"
,
"@react-navigation/native-stack"
:
"^6.2.5"
,
"@react-navigation/native-stack"
:
"^6.2.5"
,
...
...
frontend/src/screen/auth/Login.js
View file @
cd33709f
...
@@ -74,9 +74,10 @@ const Login = () => {
...
@@ -74,9 +74,10 @@ const Login = () => {
};
};
const
submitForm
=
()
=>
{
const
submitForm
=
()
=>
{
if
(
isValidForm
())
{
navigation
.
navigate
(
'
Start
'
);
loginFun
(
userInfo
);
// if (isValidForm()) {
}
// loginFun(userInfo);
// }
};
};
const
loginFun
=
()
=>
{
const
loginFun
=
()
=>
{
...
...
frontend/src/screen/reading/ReadActivity.js
View file @
cd33709f
...
@@ -11,7 +11,9 @@ import {
...
@@ -11,7 +11,9 @@ import {
ImageBackground
,
ImageBackground
,
Button
,
Button
,
Image
,
Image
,
TouchableHighlight
,
}
from
'
react-native
'
;
}
from
'
react-native
'
;
import
Voice
from
'
@react-native-voice/voice
'
;
export
default
function
ReadActivity
()
{
export
default
function
ReadActivity
()
{
const
navigation
=
useNavigation
();
const
navigation
=
useNavigation
();
...
@@ -27,6 +29,44 @@ export default function ReadActivity() {
...
@@ -27,6 +29,44 @@ export default function ReadActivity() {
// return unsubscribe;
// return unsubscribe;
// }, [navigation]);
// }, [navigation]);
useEffect
(()
=>
{
Voice
.
onSpeechStart
=
onSpeechStartHandler
;
Voice
.
onSpeechEnd
=
onSpeechEndHandler
;
Voice
.
onSpeechResults
=
onSpeechResultsHandler
;
return
()
=>
{
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
};
},
[]);
const
onSpeechStartHandler
=
e
=>
{
console
.
log
(
'
start handler =>>
'
,
e
);
};
const
onSpeechEndHandler
=
e
=>
{
console
.
log
(
'
end handler =>>
'
,
e
);
};
const
onSpeechResultsHandler
=
e
=>
{
console
.
log
(
'
result handler =>>
'
,
e
);
};
const
startRecording
=
async
()
=>
{
try
{
await
Voice
.
start
(
'
en-US
'
);
}
catch
(
error
)
{
console
.
log
(
'
error =>>
'
,
error
);
}
};
const
stopRecording
=
async
()
=>
{
try
{
await
Voice
.
stop
();
}
catch
(
error
)
{
console
.
log
(
error
);
}
};
return
(
return
(
<
SafeAreaView
>
<
SafeAreaView
>
<
View
style
=
{{
flexDirection
:
'
column
'
}}
>
<
View
style
=
{{
flexDirection
:
'
column
'
}}
>
...
@@ -57,8 +97,20 @@ export default function ReadActivity() {
...
@@ -57,8 +97,20 @@ export default function ReadActivity() {
style
=
{
styles
.
blackboard
}
style
=
{
styles
.
blackboard
}
source
=
{
require
(
'
../../assets/read/image/backboard3.png
'
)}
><
/Image
>
source
=
{
require
(
'
../../assets/read/image/backboard3.png
'
)}
><
/Image
>
<
/View
>
<
/View
>
<
View
style
=
{{
flexDirection
:
'
row
'
,
marginTop
:
120
}}
>
<
View
style
=
{
styles
.
horizontalView
}
>
<
Button
style
=
{
styles
.
button
}
title
=
"
Start
"
/>
<
TouchableHighlight
onPress
=
{
startRecording
}
>
<
Image
style
=
{
styles
.
imageButton
}
source
=
{{
uri
:
'
https://raw.githubusercontent.com/AboutReact/sampleresource/master/microphone.png
'
,
}}
/
>
<
/TouchableHighlight
>
<
Button
style
=
{
styles
.
button
}
title
=
"
Stop
"
onPress
=
{
stopRecording
}
/
>
<
/View
>
<
/View
>
<
/ImageBackground
>
<
/ImageBackground
>
<
/View
>
<
/View
>
...
@@ -120,7 +172,7 @@ const styles = StyleSheet.create({
...
@@ -120,7 +172,7 @@ const styles = StyleSheet.create({
justifyContent
:
'
center
'
,
justifyContent
:
'
center
'
,
alignItems
:
'
center
'
,
alignItems
:
'
center
'
,
color
:
'
#00008B
'
,
color
:
'
#00008B
'
,
borderRadius
:
10
,
borderRadius
:
10
,
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
backgroundColor
:
'
rgba(0,0,0,0.2)
'
,
textAlign
:
'
center
'
,
textAlign
:
'
center
'
,
fontWeight
:
'
bold
'
,
fontWeight
:
'
bold
'
,
...
@@ -131,4 +183,16 @@ const styles = StyleSheet.create({
...
@@ -131,4 +183,16 @@ const styles = StyleSheet.create({
marginLeft
:
5
,
marginLeft
:
5
,
color
:
'
#000000
'
,
color
:
'
#000000
'
,
},
},
imageButton
:
{
width
:
50
,
height
:
50
,
},
horizontalView
:
{
flexDirection
:
'
row
'
,
position
:
'
absolute
'
,
bottom
:
0
,
flexDirection
:
'
row
'
,
marginBottom
:
140
,
marginLeft
:
50
},
});
});
frontend/src/screen/reading/sample.js
0 → 100644
View file @
cd33709f
import
React
,
{
useState
,
useEffect
}
from
'
react
'
;
import
{
SafeAreaView
,
StyleSheet
,
Text
,
View
,
Image
,
TouchableHighlight
,
ScrollView
,
}
from
'
react-native
'
;
import
Voice
from
'
@react-native-voice/voice
'
;
const
App
=
()
=>
{
const
[
pitch
,
setPitch
]
=
useState
(
''
);
const
[
error
,
setError
]
=
useState
(
''
);
const
[
end
,
setEnd
]
=
useState
(
''
);
const
[
started
,
setStarted
]
=
useState
(
''
);
const
[
results
,
setResults
]
=
useState
([]);
const
[
partialResults
,
setPartialResults
]
=
useState
([]);
useEffect
(()
=>
{
//Setting callbacks for the process status
Voice
.
onSpeechStart
=
onSpeechStart
;
Voice
.
onSpeechEnd
=
onSpeechEnd
;
Voice
.
onSpeechError
=
onSpeechError
;
Voice
.
onSpeechResults
=
onSpeechResults
;
Voice
.
onSpeechPartialResults
=
onSpeechPartialResults
;
Voice
.
onSpeechVolumeChanged
=
onSpeechVolumeChanged
;
return
()
=>
{
//destroy the process after switching the screen
Voice
.
destroy
().
then
(
Voice
.
removeAllListeners
);
};
},
[]);
const
onSpeechStart
=
e
=>
{
//Invoked when .start() is called without error
console
.
log
(
'
onSpeechStart:
'
,
e
);
setStarted
(
'
√
'
);
};
const
onSpeechEnd
=
e
=>
{
//Invoked when SpeechRecognizer stops recognition
console
.
log
(
'
onSpeechEnd:
'
,
e
);
setEnd
(
'
√
'
);
};
const
onSpeechError
=
e
=>
{
//Invoked when an error occurs.
console
.
log
(
'
onSpeechError:
'
,
e
);
setError
(
JSON
.
stringify
(
e
.
error
));
};
const
onSpeechResults
=
e
=>
{
//Invoked when SpeechRecognizer is finished recognizing
console
.
log
(
'
onSpeechResults:
'
,
e
);
setResults
(
e
.
value
);
};
const
onSpeechPartialResults
=
e
=>
{
//Invoked when any results are computed
console
.
log
(
'
onSpeechPartialResults:
'
,
e
);
setPartialResults
(
e
.
value
);
};
const
onSpeechVolumeChanged
=
e
=>
{
//Invoked when pitch that is recognized changed
console
.
log
(
'
onSpeechVolumeChanged:
'
,
e
);
setPitch
(
e
.
value
);
};
const
startRecognizing
=
async
()
=>
{
//Starts listening for speech for a specific locale
try
{
await
Voice
.
start
(
'
en-US
'
);
setPitch
(
''
);
setError
(
''
);
setStarted
(
''
);
setResults
([]);
setPartialResults
([]);
setEnd
(
''
);
}
catch
(
e
)
{
//eslint-disable-next-line
console
.
error
(
e
);
}
};
const
stopRecognizing
=
async
()
=>
{
//Stops listening for speech
try
{
await
Voice
.
stop
();
}
catch
(
e
)
{
//eslint-disable-next-line
console
.
error
(
e
);
}
};
const
cancelRecognizing
=
async
()
=>
{
//Cancels the speech recognition
try
{
await
Voice
.
cancel
();
}
catch
(
e
)
{
//eslint-disable-next-line
console
.
error
(
e
);
}
};
const
destroyRecognizer
=
async
()
=>
{
//Destroys the current SpeechRecognizer instance
try
{
await
Voice
.
destroy
();
setPitch
(
''
);
setError
(
''
);
setStarted
(
''
);
setResults
([]);
setPartialResults
([]);
setEnd
(
''
);
}
catch
(
e
)
{
//eslint-disable-next-line
console
.
error
(
e
);
}
};
return
(
<
SafeAreaView
style
=
{
styles
.
container
}
>
<
View
style
=
{
styles
.
container
}
>
<
Text
style
=
{
styles
.
titleText
}
>
Speech
to
Text
Conversion
in
React
Native
|
Voice
Recognition
<
/Text
>
<
Text
style
=
{
styles
.
textStyle
}
>
Press
mike
to
start
Recognition
<
/Text
>
<
View
style
=
{
styles
.
headerContainer
}
>
<
Text
style
=
{
styles
.
textWithSpaceStyle
}
>
{
`Started:
${
started
}
`
}
<
/Text
>
<
Text
style
=
{
styles
.
textWithSpaceStyle
}
>
{
`End:
${
end
}
`
}
<
/Text
>
<
/View
>
<
View
style
=
{
styles
.
headerContainer
}
>
<
Text
style
=
{
styles
.
textWithSpaceStyle
}
>
{
`Pitch: \n
${
pitch
}
`
}
<
/Text
>
<
Text
style
=
{
styles
.
textWithSpaceStyle
}
>
{
`Error: \n
${
error
}
`
}
<
/Text
>
<
/View
>
<
TouchableHighlight
onPress
=
{
startRecognizing
}
>
<
Image
style
=
{
styles
.
imageButton
}
source
=
{{
uri
:
'
https://raw.githubusercontent.com/AboutReact/sampleresource/master/microphone.png
'
,
}}
/
>
<
/TouchableHighlight
>
<
Text
style
=
{
styles
.
textStyle
}
>
Partial
Results
<
/Text
>
<
ScrollView
>
{
partialResults
.
map
((
result
,
index
)
=>
{
return
(
<
Text
key
=
{
`partial-result-
${
index
}
`
}
style
=
{
styles
.
textStyle
}
>
{
result
}
<
/Text
>
);
})}
<
/ScrollView
>
<
Text
style
=
{
styles
.
textStyle
}
>
Results
<
/Text
>
<
ScrollView
style
=
{{
marginBottom
:
42
}}
>
{
results
.
map
((
result
,
index
)
=>
{
return
(
<
Text
key
=
{
`result-
${
index
}
`
}
style
=
{
styles
.
textStyle
}
>
{
result
}
<
/Text
>
);
})}
<
/ScrollView
>
<
View
style
=
{
styles
.
horizontalView
}
>
<
TouchableHighlight
onPress
=
{
stopRecognizing
}
style
=
{
styles
.
buttonStyle
}
>
<
Text
style
=
{
styles
.
buttonTextStyle
}
>
Stop
<
/Text
>
<
/TouchableHighlight
>
<
TouchableHighlight
onPress
=
{
cancelRecognizing
}
style
=
{
styles
.
buttonStyle
}
>
<
Text
style
=
{
styles
.
buttonTextStyle
}
>
Cancel
<
/Text
>
<
/TouchableHighlight
>
<
TouchableHighlight
onPress
=
{
destroyRecognizer
}
style
=
{
styles
.
buttonStyle
}
>
<
Text
style
=
{
styles
.
buttonTextStyle
}
>
Destroy
<
/Text
>
<
/TouchableHighlight
>
<
/View
>
<
/View
>
<
/SafeAreaView
>
);
};
export
default
App
;
const
styles
=
StyleSheet
.
create
({
container
:
{
flex
:
1
,
flexDirection
:
'
column
'
,
alignItems
:
'
center
'
,
padding
:
5
,
},
headerContainer
:
{
flexDirection
:
'
row
'
,
justifyContent
:
'
space-between
'
,
paddingVertical
:
10
,
},
titleText
:
{
fontSize
:
22
,
textAlign
:
'
center
'
,
fontWeight
:
'
bold
'
,
},
buttonStyle
:
{
flex
:
1
,
justifyContent
:
'
center
'
,
marginTop
:
15
,
padding
:
10
,
backgroundColor
:
'
#8ad24e
'
,
marginRight
:
2
,
marginLeft
:
2
,
},
buttonTextStyle
:
{
color
:
'
#fff
'
,
textAlign
:
'
center
'
,
},
horizontalView
:
{
flexDirection
:
'
row
'
,
position
:
'
absolute
'
,
bottom
:
0
,
flexDirection
:
'
row
'
,
marginTop
:
120
,
},
textStyle
:
{
textAlign
:
'
center
'
,
padding
:
12
,
},
imageButton
:
{
width
:
50
,
height
:
50
,
},
textWithSpaceStyle
:
{
flex
:
1
,
textAlign
:
'
center
'
,
color
:
'
#B0171F
'
,
},
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment