Audio Frame

Create Audio Frame

Aspose.Slides for PHP via Java allows you to add audio files to slides. The audio files are embedded in slides as audio frames.

  1. Create an instance of the Presentation class.
  2. Get a slide’s reference through its index.
  3. Load the audio file stream you want to embed in the slide.
  4. Add the embedded audio frame (containing the audio file) to the slide.
  5. Set PlayMode and Volume exposed by the IAudioFrame object.
  6. Save the modified presentation.

This PHP code shows you how to add an embedded audio frame to a slide:

// Instantiates a Presentation class that represents a presentation file
  $pres = new Presentation();
  try {
    # Gets the first slide
    $sld = $pres->getSlides()->get_Item(0);
    # Loads the wav sound file to stream
    $fstr = new Java("java.io.FileInputStream", new Java("java.io.File", "audio.wav"));
    # Adds the Audio Frame
    $audioFrame = $sld->getShapes()->addAudioFrameEmbedded(50, 150, 100, 100, $fstr);
    $fstr->close();
    # Sets the Play Mode and Volume of the Audio
    $audioFrame->setPlayMode(AudioPlayModePreset->Auto);
    $audioFrame->setVolume(AudioVolumeMode->Loud);
    # Writes the PowerPoint file to disk
    $pres->save("AudioFrameEmbed_out.pptx", SaveFormat::Pptx);
} catch(JavaException e) {
} finally {
    if (!java_is_null($pres)) $pres.dispose();
}

Change Audio Frame Thumbnail

When you add an audio file to a presentation, the audio appears as a frame with a standard default image (see the image in the section below). You change the audio frame’s preview image (set your preferred image).

This PHP code shows you how to change an audio frame’s thumbnail or preview image:

  $presentation = new Presentation();
  try {
    $slide = $presentation->getSlides()->get_Item(0);
    # Adds an audio frame to the slide with a specified position and size.
    $audioStream = new Java("java.io.FileInputStream", "sample2.mp3");
    $audioFrame = $slide->getShapes()->addAudioFrameEmbedded(150, 100, 50, 50, $audioStream);
    $audioStream->close();
    # Adds an image to presentation resources.
    $picture;
    $image = Images->fromFile("eagle.jpeg");
    try {
      $picture = $presentation->getImages()->addImage($image);
    } finally {
      if (!java_is_null($image)) {
        $image->dispose();
      }
    }
    # Sets the image for the audio frame.
    $audioFrame->getPictureFormat()->getPicture()->setImage($picture);// <-----

    # Saves the modified presentation to disk
    $presentation->save("example_out.pptx", SaveFormat::Pptx);
  } catch (JavaException $e) {
  } finally {
    if (!java_is_null($presentation)) {
      $presentation->dispose();
    }
  }

Change Audio Play Options

Aspose.Slides for PHP via Java allows you to change options that control an audio’s playback or properties. For example, you can adjust an audio’s volume, set the audio to play looped, or even hide the audio icon.

The Audio Options pane in Microsoft PowerPoint:

example1_image

PowerPoint Audio options that correspond to Aspose.Slides AudioFrame properties:

This is how you change the Audio Play options:

  1. Сreate or get the Audio Frame.
  2. Set new values for the Audio Frame properties you want to adjust.
  3. Save the modified PowerPoint file.

This PHP code demonstrates an operation in which an audio’s options are adjusted:

  $pres = new Presentation("AudioFrameEmbed_out.pptx");
  try {
    # Gets the AudioFrame shape
    $audioFrame = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
    # Sets the Play mode to play on click
    $audioFrame->setPlayMode(AudioPlayModePreset->OnClick);
    # Sets the volume to Low
    $audioFrame->setVolume(AudioVolumeMode->Low);
    # Sets the audio to play across slides
    $audioFrame->setPlayAcrossSlides(true);
    # Disables loop for the audio
    $audioFrame->setPlayLoopMode(false);
    # Hides the AudioFrame during the slide show
    $audioFrame->setHideAtShowing(true);
    # Rewinds the audio to start after playing
    $audioFrame->setRewindAudio(true);
    # Saves the PowerPoint file to disk
    $pres->save("AudioFrameEmbed_changed.pptx", SaveFormat::Pptx);
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

Extract Audio

Aspose.Slides for PHP via Java allows you to extract the sound used in slide show transitions. For example, you can extract the sound used in a specific slide.

  1. Create an instance of the Presentation class and load the presentation containing the audio.
  2. Get the relevant slide’s reference through its index.
  3. Access the slideshow transitions for the slide.
  4. Extract the sound in byte data.

This code shows you how to extract the audio used in a slide:

  # Instantiates a Presentation class that represents a presentation file
  $pres = new Presentation("AudioSlide.pptx");
  $Array = new java_class("java.lang.reflect.Array");
  try {
    # Accesses the desired slide
    $slide = $pres->getSlides()->get_Item(0);
    # Gets the slideshow transition effects for the slide
    $transition = $slide->getSlideShowTransition();
    # Extracts the sound in byte array
    $audio = $transition->getSound()->getBinaryData();
    echo("Length: " . $Array->getLength($audio));
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }