Drawing an image using WebGL - html5 canvas - Stack Overflow
文章推薦指數: 80 %
2D Image Processing With WebGL - javascript - Stack Overflow
Home
Public
Questions
Tags
Users
Companies
Collectives
ExploreCollectives
Teams
StackOverflowforTeams
–Startcollaboratingandsharingorganizationalknowledge.
CreateafreeTeam
WhyTeams?
Teams
CreatefreeTeam
Collectives™onStackOverflow
Findcentralized,trustedcontentandcollaboratearoundthetechnologiesyouusemost.
Learnmore
Teams
Q&Aforwork
Connectandshareknowledgewithinasinglelocationthatisstructuredandeasytosearch.
Learnmore
DrawinganimageusingWebGL
AskQuestion
Asked
9years,8monthsago
Modified
5years,4monthsago
Viewed
21ktimes
12
5
PleasecouldanyoneexplainhowtodrawanimageonaWebGLcanvas?Atthemoment,onaregular'2d'canvas,I'musingthis:
varcanvas=document.getElementById("canvas");
varcxt=canvas.getContext('2d');
img.onload=function(){
cxt.drawImage(img,0,0,canvas.width,canvas.height);
}
img.src="data:image/jpeg;base64,"+base64var;
WithWebGLitseemsyouhavetousetextures,etc.CananyoneexplainhowIwouldadaptthiscodeforWebGL?Thanksforthehelp!:)
html5-canvaswebgl
Share
Improvethisquestion
Follow
editedSep3,2012at16:53
MikkoOhtamaa
75.7k4646goldbadges227227silverbadges373373bronzebadges
askedSep3,2012at15:53
JoeyMoraniJoeyMorani
23.5k3232goldbadges8181silverbadges128128bronzebadges
Addacomment
|
2Answers
2
Sortedby:
Resettodefault
Highestscore(default)
Datemodified(newestfirst)
Datecreated(oldestfirst)
26
IfitwasuptomeI'ddoitwithaunitquadandamatrixlikethis
Giventheseshaders
vertexshader
attributevec2a_position;
uniformmat3u_matrix;
varyingvec2v_texCoord;
voidmain(){
gl_Position=vec4(u_matrix*vec3(a_position,1),1);
//becausewe'reusingaunitquadwecanjustuse
//thesamedataforourtexcoords.
v_texCoord=a_position;
}
fragmentshader
precisionmediumpfloat;
//ourtexture
uniformsampler2Du_image;
//thetexCoordspassedinfromthevertexshader.
varyingvec2v_texCoord;
voidmain(){
gl_FragColor=texture2D(u_image,v_texCoord);
}
I'dcreateaunitquadandthenfillouta3x3matrixtotranslate,rotate,andscaleitwhereIneededittobe
vardstX=20;
vardstY=30;
vardstWidth=64;
vardstHeight=64;
//convertdstpixelcoordstoclipspacecoords
varclipX=dstX/gl.canvas.width*2-1;
varclipY=dstY/gl.canvas.height*-2+1;
varclipWidth=dstWidth/gl.canvas.width*2;
varclipHeight=dstHeight/gl.canvas.height*-2;
//buildamatrixthatwillstretchour
//unitquadtoourdesiredsizeandlocation
gl.uniformMatrix3fv(u_matrixLoc,false,[
clipWidth,0,0,
0,clipHeight,0,
clipX,clipY,1,
]);
"usestrict";
window.onload=main;
functionmain(){
varimage=newImage();
//usingadataURLbecausestackoverflow
image.src="";//MUSTBESAMEDOMAIN!!!
image.onload=function(){
render(image);
}
}
functionrender(image){
//GetAWebGLcontext
varcanvas=document.getElementById("c");
vargl=canvas.getContext("webgl");
if(!gl){
return;
}
//setupGLSLprogram
varprogram=webglUtils.createProgramFromScripts(gl,["2d-vertex-shader","2d-fragment-shader"]);
gl.useProgram(program);
//lookupwherethevertexdataneedstogo.
varpositionLocation=gl.getAttribLocation(program,"a_position");
//lookupuniformlocations
varu_imageLoc=gl.getUniformLocation(program,"u_image");
varu_matrixLoc=gl.getUniformLocation(program,"u_matrix");
//providetexturecoordinatesfortherectangle.
varpositionBuffer=gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER,positionBuffer);
gl.bufferData(gl.ARRAY_BUFFER,newFloat32Array([
0.0,0.0,
1.0,0.0,
0.0,1.0,
0.0,1.0,
1.0,0.0,
1.0,1.0]),gl.STATIC_DRAW);
gl.enableVertexAttribArray(positionLocation);
gl.vertexAttribPointer(positionLocation,2,gl.FLOAT,false,0,0);
vartexture=gl.createTexture();
gl.bindTexture(gl.TEXTURE_2D,texture);
//Settheparameterssowecanrenderanysizeimage.
gl.texParameteri(gl.TEXTURE_2D,gl.TEXTURE_WRAP_S,gl.CLAMP_TO_EDGE);
gl.texParameteri(gl.TEXTURE_2D,gl.TEXTURE_WRAP_T,gl.CLAMP_TO_EDGE);
gl.texParameteri(gl.TEXTURE_2D,gl.TEXTURE_MIN_FILTER,gl.NEAREST);
gl.texParameteri(gl.TEXTURE_2D,gl.TEXTURE_MAG_FILTER,gl.NEAREST);
//Uploadtheimageintothetexture.
gl.texImage2D(gl.TEXTURE_2D,0,gl.RGBA,gl.RGBA,gl.UNSIGNED_BYTE,image);
vardstX=20;
vardstY=30;
vardstWidth=64;
vardstHeight=64;
//convertdstpixelcoordstoclipspacecoords
varclipX=dstX/gl.canvas.width*2-1;
varclipY=dstY/gl.canvas.height*-2+1;
varclipWidth=dstWidth/gl.canvas.width*2;
varclipHeight=dstHeight/gl.canvas.height*-2;
//buildamatrixthatwillstretchour
//unitquadtoourdesiredsizeandlocation
gl.uniformMatrix3fv(u_matrixLoc,false,[
clipWidth,0,0,
0,clipHeight,0,
clipX,clipY,1,
]);
//Drawtherectangle.
gl.drawArrays(gl.TRIANGLES,0,6);
}
canvas{
border:1pxsolidblack;
}
延伸文章資訊
- 1WebGL Image Processing
To draw images in WebGL we need to use textures. Similarly to the way WebGL expects clip space co...
- 2Drawing an image using WebGL - html5 canvas - Stack Overflow
2D Image Processing With WebGL - javascript - Stack Overflow
- 3jongomez/numgl: Image processing with WebGL. - GitHub
Apply image processing algorithms using WebGL. Supports pictures, videos, webcam streams and user...
- 4Using textures in WebGL - Web APIs | MDN
To load the texture from the image file, it then creates an Image object and assigns the src to t...
- 5Image Processing with WebGL - Medium
Image processing with HTML Canvas. Before delving into WebGL rendering, I think it's worth briefl...