iiVisu
A player/ recorder visualizer with the swipe to seek functionality.
Demo
Setup
Step 1. Add the JitPack repository to your build file
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Step 2. Add the dependency
dependencies {
implementation 'com.github.imnirdst:iivisu:1.1.0'
}
Usage
This repository contains a sample app that shows how to use iiVisu.
Recorder
RecorderVisualizer
doesn't support swipe to seek functionality.
<com.imn.iivisu.RecorderVisualizer
android:id="@+id/visualizer"
android:layout_width="0dp"
android:layout_height="256dp"
app:maxAmp="100"
app:barWidth="3dp"
app:spaceBetweenBar="2dp"
app:loadedBarPrimeColor="@color/primaryLight"
app:backgroundBarPrimeColor="@color/gray"
app:layout_constraintBottom_toTopOf="@id/timeline_text_view"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent" />
visualizer.ampNormalizer = { sqrt(it.toFloat()).toInt() }
recorder.apply {
onStop = { visualizer.clear() }
onAmpListener = {
runOnUiThread {
visualizer.addAmp(it)
}
}
}
Player
<com.imn.iivisu.PlayerVisualizer
android:id="@+id/visualizer"
android:layout_width="0dp"
android:layout_height="256dp"
app:barWidth="3dp"
app:spaceBetweenBar="2dp"
app:approximateBarDuration="50"
app:loadedBarPrimeColor="@color/primaryLight"
app:backgroundBarPrimeColor="@color/gray"
app:layout_constraintBottom_toTopOf="@id/timeline_text_view"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent" />
visualizer.apply {
onStartSeeking = { player.pause() }
onSeeking = { timelineTextView.text = it.formatAsTime() }
onFinishedSeeking = { time, isPlayingBefore ->
player.seekTo(time)
if (isPlayingBefore) {
player.resume()
}
onAnimateToPositionFinished = { time, isPlaying ->
player.seekTo(time)
}
}
}
visualizer.ampNormalizer = { sqrt(it.toFloat()).toInt() }
player.onProgress = { time, isPlaying ->
visualizer.updateTime(time.toInt(), isPlaying)
}
val amps = player.loadAmps()
visualizer.setWaveForm(amps, player.tickDuration)
Documentation
-
maxAmp
: Maximum amp that you expected to receive from the mic. Amps with higher than maxAmp are shown as a full height bar. This is calculated automatically in thePlayerVisualizer
. -
barWidth
: Width of each bar. -
spaceBetweenBar
: Space between each bar. -
approximateBarDuration
: Defines approximate duration of each bar. The exact duration of each bar is calculated and stored in thebarDuration
variable. -
loadedBarPrimeColor
: Defines loaded bar color. -
backgroundBarPrimeColor
: Defines background (unloaded) bar color. -
ampNormalizer
: Receives a lambda method for normalizing amps. (for better visualization) -
addAmp
: Used for adding an amp toRecorderVisualizer
and its bar gets drawn Immediately. -
setWaveForm
: Receives a list of integeramps
and atickDuration
which defines the time per each amp. -
updateTime
: Used for updatingPlayerVisualizer
timeline to specified location.isPlaying
param is used for defining behaviour ofonFinishedSeeking
callback. -
onStartSeeking
: Receives a callback for the action needed to happen when seeking starts. -
onSeeking
: Receives a callback for the action needed to happen during the seeking process and contains current time position of the visualizer. -
onFinishedSeeking
: Receives a callback for the action needed to happen after the seeking finishes and contains time position of the visualizer and a variable for deciding whether you need to resume player after seeking or not. -
seekOver(amount)
: Moves visualizer's cursoramount
ahead/back and notifies usingonAnimateToPositionFinished
callback. -
seekTo(position)
: Moves visualizer's cursor toposition
and notifies usingonAnimateToPositionFinished
callback. -
onAnimateToPositionFinished
: Receives a callback for the action needed to happen after the moving to position finishes and contains time position of the visualizer and a variable for deciding whether you need to resume player after seeking or not.
License
MIT. See the LICENSE file for details.