The forum on this site is closed for new comments and posts. Continue the conversation in our Snap AR Discord server.

I made a simple volume slider

  • Hi Aaron,

    Very cool. We'll also add an integrated volume slider in the audio component to the feature request list.

    Happy creating!

    Natasha

    Comment actions Permalink
  • Made a small update to this.  It can handle up to five separate sound effects.  It's easily extendible to more, but five seems about enough for an average Filter / Lens experience.

    Is it possible to dynamically add @input controls?  That would make it so you only have what you need, clean up the code, and have everything set up in the for-loop based on how many assets you add to the audioSource array.

     

    // @ui {"widget":"label", "label":"Audio Mixer"}
    // @input Component.AudioComponent[] audioSource
    // @ui {"widget":"group_start", "label":"Volume Control"}
    // @input float volume0 = 1.0 {"widget":"slider", "min":0.0, "max":1.0, "step":0.01}
    // @input float volume1 = 1.0 {"widget":"slider", "min":0.0, "max":1.0, "step":0.01}
    // @input float volume2 = 1.0 {"widget":"slider", "min":0.0, "max":1.0, "step":0.01}
    // @input float volume3 = 1.0 {"widget":"slider", "min":0.0, "max":1.0, "step":0.01}
    // @input float volume4 = 1.0 {"widget":"slider", "min":0.0, "max":1.0, "step":0.01}
    // @ui {"widget":"group_end"}
    // @ui {"widget":"separator"}

    attachVolume();

    function attachVolume()
    {
    for(var i = 0; i < script.audioSource.length; i++)
    {
    switch(i)
    {
    case 0:
    script.audioSource[i].volume = script.volume0;
    break;
    case 1:
    script.audioSource[i].volume = script.volume1;
    break;
    case 2:
    script.audioSource[i].volume = script.volume2;
    break;
    case 3:
    script.audioSource[i].volume = script.volume3;
    break;
    case 4:
    script.audioSource[i].volume = script.volume4;
    break;
    }
    }
    }
    Comment actions Permalink
  • Hi Aaron, currently you can not dynamically add inputs. 

    The @input system does have some simple conditional logic that you could exploit for hiding elements. In the below guide, check out showIf and showIfValue.

    https://lensstudio.snapchat.com/guides/scripting/custom-script-ui/

    This will allow you to show and hide elements if something is true or if something is matching a value. 

    Comment actions Permalink

We're here to help! We just need a little bit of information...

What system are you using?

Have you downloaded the latest version of Lens Studio?

Please download the latest version of Lens Studio. If you still run into this issue, please come back and report it!

Is this issue causing Lens Studio to crash?

What system do you run Lens Studio on?

Version

Graphics

Follow the next steps to help us solve your issue:

  • Copy and paste this text into your TerminalCommand Window
    open ~/Library/Preferences/Snap/Lens\ Studio/ %LOCALAPPDATA%\Snap\Lens Studio Copy Text
  • Press ReturnEnter to run the command. The Lens Studio folder will automatically open
  • Prepare to upload your files: zip the "Log" Folder by right-clicking and choosing "compress."
    Locate the Log.txt file right above it.

    Attach a screenshot of the issue:

Name:

Email:

What is this most relevant to?

Please enter a brief description of your issue:

Thanks for submitting this issue.

Unfortunately, it's likely due to the operating system or hardware you're using – since they don't meet the system requirements for Lens Studio.

Still, we hear you loud and clear, and are logging the issue in case there's ever a workaround we can provide!

Minimum Requirements

Operating System: Windows 10 (64 bit); MacOS 10.11+

Hardware: Minimum of Intel Core i3 2.5Ghz or AMD Phenom II 2.6Ghz with 4 GB RAM; Intel HD Graphics 4000 / Nvidia GeForce 710 / AMD Radeon HD 6450 or better; screen resolution of 1280x768 or higher

We'll try to resolve this issue as soon as possible. Thanks for letting us know about it!

Keep an eye out for a followup email from us. We may have a couple more questions for you, or we might already have a solution to offer.

Happy creating!