» fr.EX9.HLSL.Introduction
This site relies heavily on Javascript. You should enable it if you want the full experience. Learn more.

fr.EX9.HLSL.Introduction

English | Italian

The original english version of this page is newer and may contain information this translation does not have! Click here to view the english version.

Semantics

à venir...

Vecteurs et Swizzles

En dehors des types de donnée simples comme bool (booléen), int (nombres entiers), float (virgule flottante) et double, vous pouvez aussi avec l'HLSL utiliser tous ces types de données comme vecteurs en écrivant quelque chose comme:

{CODE(ln=>0)}
float4 ff = {4, 3, 2, 1};
bool2 bb = {1, 0};
^

A présent vous pouvez accéder à chaque composante de vecteur en utilisant les swizzles, qui fonctionnent comme des suffixes aux noms de variables:

 .x, .y, .z, .w 

est la même chose que:

 .r, .g, .b, .a
{CODE(ln=>0)}
float f = ff.a; // f = 1
bool b = bb.y; // b = 0
float2 f2 = ff.xz // f2 = {4, 2}
^

Tableaux

Avec les types de données basiques vous pouvez également déclarer des tableaux, mais notez bien que leur longueur est limitée en fonction du nombre de registre de constante correspondant au profile de shader utilisé. Vous pouvez trouver des informations sur le nombre de constantes autorisées sur msdn:
vs_2_0 registers
ps_2_0 registers
vs_3_0 registers
ps_3_0 registers

Vous pouvez définir et accéder aux tableaux comme le montre l'exemple suivant:

{CODE(ln=>0)}
float4 ff[2] = {{0, 1, 2, 3}, {4, 5, 6, 7}}
float4 f1 = f[0]; //f1 = {0, 1, 2, 3}
float3 f2 = f[1].rgb; //f2 = {4, 5, 6}
^

Fonctions Intrinsèques

L'HLSL a une courte liste de fonctions intégrées. Un clic-droit dans l'éditeur de shader de vvvv fait apparaître la liste.

Fonctions et Inclusions

En parallèle aux principales fonctions vertex shader et pixel shader, vous pouvez définir n'importe quel nombre de fonctions d'aide dans un fichier d'effet externe. Si votre code devient trop confus, des fonctions peuvent être exportées vers un fichier texte puis incorporées à l'effet grâce à une simple déclaration comme:

{CODE(ln=>0)}#include "myfunctions.fxh"^

Le fichier spécifié doit être placé dans le même dossier que le fichier .fx qui l'inclus.

Profiles de Shader

Dans chaque technique vous devez spécifier un profile de shader avec lequel vous voulez que les vertex shader et pixel shader soient compilés. En règle générale, plus le profile est élevé, plus il est flexible. Si votre shader renvoie une erreur disant que vous êtes hors des instructions, alors vous devriez essayer un profile plus élevé.

Des détails concernant les profiles de shader et leurs caractéristiques peuvent être trouvés sur msdn: Shader Models vs. Shader Profiles

En fonction des capacités de votre carte graphique, vvvv supporte les profiles suivants:

  • vs_1_0, ps_1_0
  • vs_1_1, ps_1_1
  • vs_2_0, ps_2_0
  • vs_2_a, ps_2_a
  • vs_2_b, ps_2_b
  • vs_3_0, ps_3_0 //notez que si vous utilisez vs_3_0 alors vous devez aussi utiliser ps_3_0

anonymous user login

Shoutbox

~2d ago

cznickesz: @tonfilm thanks for the info. Can´t wait to give it a try!

~3d ago

tonfilm: @cznickesz #vvvv #vl #xenko integration is not ready for the public yet, it's still under heavy development... more updates soon.

~3d ago

cznickesz: Possibly dumb question: is there any release containing xenko-integration right now?

~4d ago

~5d ago

~6d ago

joreg: looking for latest #vvvv gamma preview? it is here: vvvv-gamma-2019.1-preview

~6d ago

udo2013: I just want to know why the camera does not work. should be easy to be answered.

~6d ago

udo2013: an answer, please. also there was a 4d julia set in dx9. that must have programmed one. haalllooo!!

~6d ago

udo2013: where are the people who have translated shadertoy's mandelbulb in hlsl ?? for vvvv