Getting started with WebGL - Web APIs (2024)

Next »

WebGL enables web content to use an APIbased on OpenGLES 2.0 to perform 3D rendering in an HTMLcanvas in browsers that support it without the use of plug-ins. WebGL programs consist of control code written in JavaScript and special effects code (shader code) that is executed on a computer's Graphics Processing Unit (GPU). WebGL elements can be mixed with other HTML elements and composited with other parts of the page or page background.

This article will introduce you to the basics of using WebGL. It's assumed that you already have an understanding of the mathematics involved in 3D graphics, and this article doesn't pretend to try to teach you OpenGL itself.

The code examples in this tutorial can also be found in the webgl-examples GitHub repository.

Preparing to render in 3D

The first thing you need in order to use WebGL to render in 3D is a canvas. The HTMLfragment below establishes a canvas and sets up an onload event handler that will be used to initialize our WebGL context.

<body onload="start()"> <canvas id="glCanvas" width="640" height="480"> Your browser doesn't appear to support the <code>&lt;canvas&gt;</code> element. </canvas></body>

Preparing the WebGLcontext

The start()function, in our JavaScript code, is called after the document is loaded. Its mission is to set up the WebGLcontext and start rendering content.

var gl; // A global variable for the WebGL contextfunction start() { var canvas = document.getElementById('glCanvas'); // Initialize the GL context gl = initWebGL(canvas); // Only continue if WebGL is available and working if (!gl) { return; } // Set clear color to black, fully opaque gl.clearColor(0.0, 0.0, 0.0, 1.0); // Enable depth testing gl.enable(gl.DEPTH_TEST); // Near things obscure far things gl.depthFunc(gl.LEQUAL); // Clear the color as well as the depth buffer. gl.clear(gl.COLOR_BUFFER_BIT | gl.DEPTH_BUFFER_BIT);}

The first thing we do here is obtain a reference to the canvas, stashing it in a variable called canvas. Obviously if you don't need to repeatedly reference the canvas, you should avoid saving this value globally, and just save it in a local variable or member field of an object.

Once we have the canvas, we call a function called initWebGL(); this is a function we'll define momentarily; its job is to initialize the WebGL context.

If the context is successfully initialized, gl is a reference to it. In this case, we set the clear color to black, then clear the context to that color. After that, the context is configured by setting parameters. In this case, we're enabling depth testing and specifying that closer objects will obscure objects that are farther away.

For the purposes of this initial pass at the code, that's all we're going to do. We'll look at how to actually start doing something a little later.

Creating a WebGLcontext

The initWebGL()function looks like this:

function initWebGL(canvas) { gl = null;// Try to grab the standard context. If it fails, fallback to experimental. gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl'); // If we don't have a GL context, give up now if (!gl) { alert('Unable to initialize WebGL. Your browser may not support it.'); } return gl;}

To obtain a WebGL context for a canvas, we request the context named "webgl" from the canvas. If this fails, we try the name "experimental-webgl". If that, too, fails, we display an alert letting the user know they appear not to have WebGL support. That's all there is to it. At this point, gl is either null (meaning there is no WebGL context available) or is a reference to the WebGL context into which we'll be rendering.

At this point, you have enough code that the WebGL context should successfully initialize, and you should wind up with a big black, empty box, ready and waiting to receive content.

View the complete code | Open this demo on a new page

Resizing the WebGL context

A new WebGL context will set its viewport resolution to the height and width of its canvas element, without CSS, at the instant the context was obtained. Editing the style of a canvas element will change its displayed size but will not change its rendering resolution. Editing the width and height attributes of a canvas element after the context has been created will also not change the number of pixels to be drawn. To change the resolution which WebGL renders at, such as when the user resizes the window of a full-document canvas or you wish to provide in-app adjustable graphics settings, you will need to call the WebGL context's viewport() function to acknowledge the change.

To modify the rendered resolution of a WebGL context with variables gl and canvas as used in the above example:

gl.viewport(0, 0, canvas.width, canvas.height);

A canvas will experience scaling when it is rendered at a different resolution than its CSS style makes it occupy on the display. Resizing with CSS is mostly useful to save resources by rendering at a low resolution and allowing the browser to upscale; downscaling is possible which would produce a super sample antialiasing (SSAA) effect (albeit with naive results and a severe performance cost). It is often best to rely upon the MSAA and texture filtering implementations of the user's browser, if available and appropriate, rather than doing it via brute force and hoping that the browser's image reduction algorithm produces a cleaner result.

See also

  • An introduction to WebGL: Written by Luz Caballero, published at dev.opera.com. This article addresses that what WebGL is, explains how WebGL works (including the rendering pipeline concept), and introduces some WebGL libraries.
  • WebGL Fundamentals
  • An intro to modern OpenGL: A series of nice articles about OpenGL written by Joe Groff, providing a clear intro about OpenGL from its history to the important graphics pipeline concept, and some examples to demo how OpenGL works. If you have no idea about OpenGL, this is a good place to start.

Next »

Getting started with WebGL - Web APIs (2024)
Top Articles
Is Being a PSE Mail Processing Clerk at USPS a Good Job? An In-Depth Look - Marketing Scoop
Directions To Franklin Mills Mall
The Young And The Restless Two Scoops
Pga Scores Cbs
Ray Romano Made a Movie for Sports Parents Everywhere
Minus8 Patreon
Why are you the best candidate for financial advisor position?
Caremount Medical Flu Shots 2022
Tamilyogi Download 2021
Ups Cc Center
Hidden Goblin Stash Failed Perception
Anchor Martha MacCallum Talks Her 20-Year Journey With FOX News and How She Stays Grounded (EXCLUSIVE)
Ropro Cloud Play
Espn Masters Leaderboard
Voy Pageant Discussion
Unit 5 Lesson 6 Coding Activity
Lighthouse Diner Taylorsville Menu
Dimbleby Funeral Home
Craigslist Pets Baton Rouge La
Https //Myapps.microsoft.com Portal
Software For Organizing A Pledge Drive Crossword Clue
Monahan's By The Cove Charlestown Menu
Dr. Nicole Arcy Dvm Married To Husband
Huntress Neighborhood Watch
Eaglecraft Minecraft Unblocked
Katmoie
Sharkbrew
Venus Nail Lounge Lake Elsinore
Walgreens On Nacogdoches And O'connor
Hendraheim Skyrim
Lolalytics Aram
Craigslist Chester Sc
JetBlue, Spirit end $3.8 billion merger agreement after losing antitrust suit
Northern Va Bodyrubs
Home Theater and Home Theater Systems at Crutchfield.com
Walmart Car Service Near Me
The Legend of Maula Jatt | Rotten Tomatoes
Mellow Mushroom Nutrition Facts: What to Order & Avoid
Taylor Swift: The Eras Tour Showtimes Near Marcus Pickerington Cinema
Seller Feedback
Lenscrafters Westchester Mall
5417873087
Puppies For Sale in Netherlands (98) | Petzlover
Ati Recommended Cut Scores 2023
Foolproof Module 6 Test Answers
Baroque Violin Shop Cincinnati Oh
Disney Immersive Experience Cleveland Discount Code
2024 USAF & USSF Almanac: DAF Personnel | Air & Space Forces Magazine
Battlenet We Couldn't Verify Your Account With That Information
Ap Bio Unit 2 Progress Check Mcq
A Man Called Otto Showtimes Near Cinemark Palace 20
Craigslist Org Las Vegas Cars
Latest Posts
Article information

Author: Terrell Hackett

Last Updated:

Views: 6630

Rating: 4.1 / 5 (52 voted)

Reviews: 83% of readers found this page helpful

Author information

Name: Terrell Hackett

Birthday: 1992-03-17

Address: Suite 453 459 Gibson Squares, East Adriane, AK 71925-5692

Phone: +21811810803470

Job: Chief Representative

Hobby: Board games, Rock climbing, Ghost hunting, Origami, Kabaddi, Mushroom hunting, Gaming

Introduction: My name is Terrell Hackett, I am a gleaming, brainy, courageous, helpful, healthy, cooperative, graceful person who loves writing and wants to share my knowledge and understanding with you.