1
0
Fork 0
mirror of https://github.com/juce-framework/JUCE.git synced 2026-01-10 23:44:24 +00:00

Add WebView related helper classes for implementing AudioProcessorEditor::getControlParameterIndex

This commit is contained in:
attila 2024-06-03 14:32:13 +02:00
parent d61e516bbc
commit abdf9a6b75
3 changed files with 143 additions and 0 deletions

View file

@ -158,3 +158,4 @@
#include "misc/juce_AnimatedAppComponent.h"
#include "detail/juce_WebControlRelayEvents.h"
#include "misc/juce_WebControlRelays.h"
#include "misc/juce_WebControlParameterIndexReceiver.h"

View file

@ -0,0 +1,74 @@
/*
==============================================================================
This file is part of the JUCE framework.
Copyright (c) Raw Material Software Limited
JUCE is an open source framework subject to commercial or open source
licensing.
By downloading, installing, or using the JUCE framework, or combining the
JUCE framework with any other source code, object code, content or any other
copyrightable work, you agree to the terms of the JUCE End User Licence
Agreement, and all incorporated terms including the JUCE Privacy Policy and
the JUCE Website Terms of Service, as applicable, which will bind you. If you
do not agree to the terms of these agreements, we will not license the JUCE
framework to you, and you must discontinue the installation or download
process and cease use of the JUCE framework.
JUCE End User Licence Agreement: https://juce.com/legal/juce-8-licence/
JUCE Privacy Policy: https://juce.com/juce-privacy-policy
JUCE Website Terms of Service: https://juce.com/juce-website-terms-of-service/
Or:
You may also use this code under the terms of the AGPLv3:
https://www.gnu.org/licenses/agpl-3.0.en.html
THE JUCE FRAMEWORK IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL
WARRANTIES, WHETHER EXPRESSED OR IMPLIED, INCLUDING WARRANTY OF
MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, ARE DISCLAIMED.
==============================================================================
*/
namespace juce
{
#if JUCE_WEB_BROWSER || DOXYGEN
/** This is a helper class for implementing AudioProcessorEditor::getControlParameterIndex with GUIs
using a WebBrowserComponent.
Create an instance of this class and attach it to the WebBrowserComponent by using
WebBrowserComponent::Options::withOptionsFrom.
In your frontend code you can use the ControlParameterIndexUpdater class, that emits
controlParameterIndexChanged events based on the mouse movement, and control parameter index
annotations attached to DOM elements.
*/
class JUCE_API WebControlParameterIndexReceiver : public OptionsBuilder<WebBrowserComponent::Options>
{
public:
/* Returns the control parameter index last reported by the WebBrowserComponent GUI to be
active.
*/
int getControlParameterIndex() const { return controlParameterIndex; }
//==============================================================================
WebBrowserComponent::Options buildOptions (const WebBrowserComponent::Options& initialOptions) override
{
return initialOptions.withEventListener ("__juce__controlParameterIndexChanged",
[this] (auto newIndex)
{
controlParameterIndex = (int) newIndex;
});
}
private:
int controlParameterIndex = -1;
};
#endif
}

View file

@ -415,10 +415,78 @@ function getBackendResourceAddress(path) {
return path;
}
/**
* This helper class is intended to aid the implementation of
* AudioProcessorEditor::getControlParameterIndex() for editors using a WebView interface.
*
* Create an instance of this class and call its handleMouseMove() method in each mousemove event.
*
* This class can be used to continuously report the controlParameterIndexAnnotation attribute's
* value related to the DOM element that is currently under the mouse pointer.
*
* This value is defined at all times as follows
* * the annotation attribute's value for the DOM element directly under the mouse, if it has it,
* * the annotation attribute's value for the first parent element, that has it,
* * -1 otherwise.
*
* Whenever there is a change in this value, an event is emitted to the frontend with the new value.
* You can use a ControlParameterIndexReceiver object on the backend to listen to these events.
*
* @param {String} controlParameterIndexAnnotation
*/
class ControlParameterIndexUpdater {
constructor(controlParameterIndexAnnotation) {
this.controlParameterIndexAnnotation = controlParameterIndexAnnotation;
this.lastElement = null;
this.lastControlParameterIndex = null;
}
handleMouseMove(event) {
const currentElement = document.elementFromPoint(
event.clientX,
event.clientY
);
if (currentElement === this.lastElement) return;
this.lastElement = currentElement;
let controlParameterIndex = -1;
if (currentElement !== null)
controlParameterIndex = this.#getControlParameterIndex(currentElement);
if (controlParameterIndex === this.lastControlParameterIndex) return;
this.lastControlParameterIndex = controlParameterIndex;
window.__JUCE__.backend.emitEvent(
"__juce__controlParameterIndexChanged",
controlParameterIndex
);
}
//==============================================================================
#getControlParameterIndex(element) {
const isValidNonRootElement = (e) => {
return e !== null && e !== document.documentElement;
};
while (isValidNonRootElement(element)) {
if (element.hasAttribute(this.controlParameterIndexAnnotation)) {
return element.getAttribute(this.controlParameterIndexAnnotation);
}
element = element.parentElement;
}
return -1;
}
}
export {
getNativeFunction,
getSliderState,
getToggleState,
getComboBoxState,
getBackendResourceAddress,
ControlParameterIndexUpdater,
};