WebGLRenderingContext: Methode getUniformLocation()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Hinweis: Diese Funktion ist in Web Workers verfügbar.
Teil der WebGL API, die Methode WebGLRenderingContext
getUniformLocation()
gibt die Position einer spezifischen uniform-Variable zurück, die Teil eines bestimmten WebGLProgram
ist.
Die uniform-Variable wird als ein WebGLUniformLocation
-Objekt zurückgegeben, welches als undurchsichtiger Bezeichner verwendet wird, um zu spezifizieren, wo im GPU-Speicher diese uniform-Variable liegt.
Sobald Sie die Position des uniforms haben, können Sie auf das uniform selbst mit einer der anderen Zugriffs-Methoden zugreifen, indem Sie die Position des uniforms als eine der Eingaben übergeben:
getUniform()
-
Gibt den Wert des uniforms an der angegebenen Position zurück.
WebGLRenderingContext.uniform[1234][fi][v]()
-
Setzt den Wert des uniforms auf den angegebenen Wert, der eine einzelne Gleitkomma- oder Ganzzahl oder ein 2-4 Komponenten-Vektor sein kann, der entweder als eine Liste von Werten oder als eine
Float32Array
oderInt32Array
dargestellt wird. WebGLRenderingContext.uniformMatrix[234][fv]()
-
Setzt den Wert des uniforms auf die angegebene Matrix, möglicherweise mit Transposition. Der Wert wird als eine Sequenz von
GLfloat
-Werten oder alsFloat32Array
dargestellt.
Das uniform selbst wird im Shader-Programm unter Verwendung von GLSL deklariert.
Syntax
getUniformLocation(program, name)
Parameter
program
-
Das
WebGLProgram
, in dem die angegebene uniform-Variable lokalisiert werden soll. name
-
Ein String, der den Namen der uniform-Variable angibt, deren Position zurückgegeben werden soll. Der Name darf keine Leerzeichen enthalten, und Sie können diese Funktion nicht verwenden, um die Position von Uniforms zu erhalten, die mit dem reservierten String
"gl_"
beginnen, da diese intern in der WebGL-Schicht sind.Die möglichen Werte entsprechen den uniform-Namen, die durch
getActiveUniform
zurückgegeben werden; sehen Sie sich diese Funktion für genauere Informationen darüber an, wie deklarierte uniforms auf uniform-Namen abgebildet werden.Zusätzlich sind für als Arrays deklarierte uniforms auch die folgenden Namen gültig:
- Der uniform-Name ohne den
[0]
-Suffix. Z.B. ist die Position, die fürarrayUniform
zurückgegeben wird, äquivalent zu der fürarrayUniform[0]
. - Der uniform-Name, der mit einer Ganzzahl indexiert ist. Z.B. würde die Position, die für
arrayUniform[2]
zurückgegeben wird, direkt auf den dritten Eintrag desarrayUniform
uniforms verweisen.
- Der uniform-Name ohne den
Rückgabewert
Ein WebGLUniformLocation
-Wert, der die Position der benannten Variable angibt, falls sie existiert. Falls die spezifizierte Variable nicht existiert, wird null
zurückgegeben.
Die WebGLUniformLocation
ist ein undurchsichtiger Wert, der verwendet wird, um die Position im GPU-Speicher, an der sich die uniform-Variable befindet, eindeutig zu identifizieren. Mit diesem Wert in der Hand können Sie andere WebGL-Methoden aufrufen, um auf den Wert der uniform-Variable zuzugreifen.
Hinweis:
Der WebGLUniformLocation
-Typ ist kompatibel mit dem GLint
-Typ, wenn der Index oder die Position eines uniform-Attributs angegeben wird.
Fehler
Die folgenden Fehler können auftreten; um nach Fehlern zu prüfen, nachdem getUniformLocation()
zurückkehrt, rufen Sie getError()
auf.
GL_INVALID_VALUE
-
Der
program
-Parameter ist kein Wert oder Objekt, das von WebGL generiert wurde. GL_INVALID_OPERATION
-
Der
program
-Parameter entspricht keinem durch WebGL generierten GLSL-Programm oder das spezifizierte Programm wurde nicht erfolgreich verlinkt.
Beispiele
In diesem Beispiel, entnommen aus der Methode animateScene()
im Artikel Ein einfaches 2D-WebGL-Animationsbeispiel, werden die Positionen von drei uniforms aus dem Shaderprogramm abgerufen und dann die Werte jedes der drei uniforms gesetzt.
gl.useProgram(shaderProgram);
uScalingFactor = gl.getUniformLocation(shaderProgram, "uScalingFactor");
uGlobalColor = gl.getUniformLocation(shaderProgram, "uGlobalColor");
uRotationVector = gl.getUniformLocation(shaderProgram, "uRotationVector");
gl.uniform2fv(uScalingFactor, currentScale);
gl.uniform2fv(uRotationVector, currentRotation);
gl.uniform4fv(uGlobalColor, [0.1, 0.7, 0.2, 1.0]);
Hinweis:
Dieser Codeausschnitt stammt aus der Funktion animateScene()
im Artikel "Ein einfaches 2D-WebGL-Animationsbeispiel." Sehen Sie sich diesen Artikel für das vollständige Beispiel an und um die resultierende Animation in Aktion zu sehen.
Nachdem das aktuelle Shaderprogramm auf shaderProgram
gesetzt wurde, ruft dieser Code die drei uniforms "uScalingFactor"
, "uGlobalColor"
und "uRotationVector"
ab, indem getUniformLocation()
jeweils einmal für jedes uniform aufgerufen wird.
Dann werden die Werte der drei uniforms gesetzt:
- Das uniform
uScalingFactor
— ein 2-Komponenten-Vektor — erhält die horizontalen und vertikalen Skalierungsfaktoren aus der VariablencurrentScale
. - Das uniform
uRotationVector
wird auf den Inhalt der VariablencurrentRotation
gesetzt. Auch dies ist ein 2-Komponenten-Vektor. - Schließlich wird das uniform
uGlobalColor
auf die Farbe[0.1, 0.7, 0.2, 1.0]
gesetzt, wobei die Komponenten in diesem 4-Komponenten-Vektor die Werte von Rot, Grün, Blau und Alpha repräsentieren.
Nachdem dies getan ist, haben die eigenen Variablen der Shader-Funktionen uScalingFactor
, uGlobalColor
und uRotationVector
alle die Werte, die vom JavaScript-Code bereitgestellt wurden.
Spezifikationen
Specification |
---|
WebGL Specification # 5.14.10 |
Browser-Kompatibilität
BCD tables only load in the browser