Nothing
#' Interactively create a TextGrid object
#'
#' Annotate a sound file by interacting with waveform or spectrogram plots,
#' resulting in a TextGrid object which can be used for creating various
#' acoustic plots with time-aligned annotations with [praatpicture()].
#'
#' @param sound String giving the file name of a sound file with the .wav
#' extension.
#' @param tierNames String or vector of strings giving the name(s) of tiers in
#' the new TextGrid object.
#' @param start Start time (in seconds) of desired plotted area. Default is `0`.
#' @param end End time (in seconds) of desired plotted area. Default is `0`
#' (= the entire file).
#' @param show String giving the type of plot to show. Default is `wave`,
#' another option is `spectrogram`. Note that spectrogram plotting is relatively
#' slow within this function.
#' @param channel Number indicating which audio channel to show. Default is `1`.
#' @param sampa2ipa Logical; should SAMPA transcriptions be converted to IPA?
#' Default is `FALSE`.
#' @param audioInViewer Logical; should audio be playable from the Viewer pane
#' in RStudio?
#'
#' @details Running this function will show either a waveform or a spectrogram
#' in a separate `X11` graphics device window. Click on this figure in the
#' locations where you want to add boundaries to your TextGrid objects. This
#' should be done sequentially, starting with the first boundary along the
#' time axis and ending with the last. It does not matter where on the y-axis
#' you click.
#'
#' Once you have indicated all the desired boundaries, you will be prompted
#' in the R console to say whether the tier is an interval tier or a point tier
#' by typing `y` (for interval tier) or `n` (for point tier). Subsequently
#' you will be prompted in the console to write labels corresponding to each
#' interval or point.
#'
#' If you are creating a TextGrid with multiple tiers (i.e., if `tierNames`
#' is longer than 1), this process will be repeated for all tiers.
#'
#' @return A list object identical to those created by [rPraat::tg.read()] when
#' loading TextGrid objects into R. This object can be passed to the `tg_obj`
#' argument when using `praatpicture`.
#' @seealso `make_TextGrid()` is largely a wrapper around the function
#' [tg_createTier()] which does most of the work.
#' @export
#'
#' @examples
#' \dontrun{
#' datapath <- system.file('extdata', package='praatpicture')
#' soundFile <- paste0(datapath, '/2.wav')
#' tg <- make_TextGrid(soundFile, tierNames=c('Mary', 'John', 'Bell'))
#' # Follow the steps shown in the console
#'
#' praatpicture(soundFile, tg_obj=tg)
#' }
make_TextGrid <- function(sound, tierNames, start=0, end=0, audioInViewer=TRUE,
show='wave', channel=1, sampa2ipa=FALSE) {
if (audioInViewer) {
if (end == 0) end <- Inf
snd <- tuneR::readWave(sound, from=start, to=end, units='seconds')
tempDir <- tempfile()
dir.create(tempDir)
htmlFile <- file.path(tempDir, 'index.html')
wavFile <- file.path(tempDir, 'tmp.wav')
tuneR::writeWave(snd, filename=wavFile, extensible=FALSE)
writeLines(
text='<audio controls>\n<source src="tmp.wav" type="audio/wav">\n</audio>',
con=htmlFile)
rstudioapi::viewer(htmlFile)
}
tg <- list()
for (t in tierNames) {
tg[[t]] <- tg_createTier(sound, t, start, end, show, channel, sampa2ipa)
}
return(tg)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.