(Redirected from Three Dimensional Projects)
|This article has links to websites or programs not trusted by Scratch or hosted by Wikipedia. Remember to stay safe while using the internet, as we cannot guarantee the safety of other websites.|
- "3D" redirects here. For the suggestion of a 3-dimensional stage, see Frequently Rejected Suggestions#3D Scratch.
Three-Dimensional or 3D can refer to "something having three dimensions e.g. width, length, and depth or x, y, and z." Scratch does not provide tools for displaying, creating, or manipulating 3D graphics; however, Scratch does provide blocks for 2D (x,y) sprite movement, sprite resizing, pen drawing, math functions, lists and more. Many (if not all) 3D methods can be recreated with Scratch blocks.
Creating the illusion of 3D in Scratch can be a large challenge, requiring advanced algorithms or 3D programs; there are also simpler methods, making it easy for anyone to start playing with 3D in Scratch. One of these methods is a basic raycaster.
Difference in the Third-Dimension
When computers render graphics, mainly the graphics processing unit, rendering a 3D object, landscape, or environment takes a lot more processing power than a 2D environment. This is because 3D graphics take up space (not as in storage space but the geometric property) while a 2D environment takes up a plane. Space has depth, so the processor has to perform various algorithms to create the illusion of a 3D environment on a 2D screen. Due to these algorithms and larger objects needed to render, 3D projects on Scratch typically lag more than 2D projects.
In addition, many 2D graphics are pre-rendered meaning the instructions for how to create the graphics were already carried out or pre-coded rather than the graphics card having to render the graphics anew. Rendering is the process of creating an array of coloured pixels based on a set of instructions, such as in Scratch's vector graphics. Displaying is taking what was rendered and sending it off to a monitor to be seen. Because 2D graphics are seen from one perspective, they can be pre-rendered as bitmap images, but 3D graphics can be viewed at thousands of different angles and must follow instructions for rendering the graphics. One of the common instruction engines used to render 3D graphics is Blender.
3D Methods Used in Scratch
There are many Scratch projects that use one or more of following methods to display 3D graphics. These methods are in order of difficulty. Examples are in order of creation.
Pathtracing is a subset of ray tracing that creates paths of light based on physical properties of the materials the rays intersect, and computes a final result for each pixel using the Rendering Equation. These paths are generated randomly, due to the fact that the integral in the rendering equation does not have an explicit solution, and has to be solved with Monte-Carlo integration. The use of randomness is what causes noise in path tracing. The number of paths is the number of samples, and the increase in samples reduces noise in the image and converges it to the true result. The use of randomness also allows effects like depth of field and anti-aliasing. In practice, pathtracers also have global illumination, which is the indirect bouncing of light. Pathtracing is slower than raytracing, but is more realistic. Pathtracing is also what is used to render CGI and 3D animated movies. A common misconception is that the use of Monte-Carlo integration makes a raytacer a pathtracer; this is not the case, as a pathtracer needs to create random light paths based off of material properties. A standard raytracer with Monte-Carlo integration would be classifed as a distributed raytracer.
"In computer graphics, ray tracing is a technique for generating an image by tracing the path of light through pixels in an image plane and simulating the effects of its encounters with virtual objects."
Although it is usually realtime in lower-level languages and is able to be realtime on Scratch, it can still be devastatingly slow. However, it can recreate natural effects like reflection, shading, and shadows. This complex technique is usually used in demoscene and films and TV shows using computer-generated imagery (CGI).
- projects:39385 (this project has set tutorial projects that explain the ray tracer math.)
- projects:377006401(this project teaches how to make a basic raytracer.)
- projects:398988087 (this project teaches how to make a basic raymarcher.)
Ray marching is a similar method to raytracing, but instead of jumping to objects using math it marches the ray foward until it intersects with the object. Raymarchers are slower than raytracers due to the time it takes for a ray to meet it's target. It is sometimes also called volume raycasting. The basic raymarching algorithm works by raycasting, sampling, shading, and compositing. While raytracing uses math to make the ray teleport to the object, raymarching uses math to move the ray until it hits the object. Because of this, ray marching is faster at rendering fractals such as Menger Sponges.
- projects:398988087 (this project teaches how to make a basic raymarcher.)
The painter's algorithm is the method of splitting a 3d scene into a number of polygons and filling them in order of furthest to closest rather than using a pixel-by-pixel depth buffering scan technique that rasterization uses. It is favored on Scratch for its relatively high speeds.
Rasterization is the technique of using a number of polygons to make up an image, then using a form of ray tracing to render them. First, one starts with a list of vertices making up polygons. Then, drawing a straight line from each vertex to the camera, and coloring in the area of the polygon, one can construct an image. This method is usually the method of choice for most real-time games, for its speed and relative photorealism.
- Main article: Raycaster
"Ray casting ... can be thought of as an abridged, and significantly faster, version of the ray tracing algorithm."
3d projection in Scratch can be done with this code:
define go to (x :: custom-arg) (y :: custom-arg) (z :: custom-arg) (rc_x :: custom-arg) (rc_y :: custom-arg) (rc_z :: custom-arg) (r_x :: custom-arg) (r_y :: custom-arg) (r_z :: custom-arg) (cam_x :: custom-arg) (cam_y :: custom-arg) (cam_z :: custom-arg) (fs :: custom-arg) go to x: ((((((((x :: custom-arg) - (rc_x :: custom-arg)) * ([cos v] of (r_y :: custom-arg))) - (((z :: custom-arg) - (rc_z :: custom-arg)) * ([sin v] of (r_y :: custom-arg)))) * ([cos v] of (r_z :: custom-arg))) - (((((y :: custom-arg) - (rc_y :: custom-arg)) * ([cos v] of (r_x :: custom-arg))) - (((((x :: custom-arg) - (rc_x :: custom-arg)) * ([sin v] of (r_y :: custom-arg))) + (((z :: custom-arg) - (rc_z :: custom-arg)) * ([cos v] of (r_y :: custom-arg)))) * ([sin v] of (r_x :: custom-arg)))) * ([sin v] of (r_z :: custom-arg)))) - (cam_x :: custom-arg)) * ((fs :: custom-arg) / ((fs :: custom-arg) + (((((y :: custom-arg) - (rc_y :: custom-arg)) * ([sin v] of (r_x :: custom-arg))) + (((((x :: custom-arg) - (rc_x :: custom-arg)) * ([sin v] of (r_y :: custom-arg))) + (((z :: custom-arg) - (rc_z :: custom-arg)) * ([cos v] of (r_y :: custom-arg)))) * ([cos v] of (r_x :: custom-arg)))) - (cam_z :: custom-arg))))) y: ((((((((x :: custom-arg) - (rc_x :: custom-arg)) * ([cos v] of (r_y :: custom-arg))) - (((z :: custom-arg) - (rc_z :: custom-arg)) * ([sin v] of (r_y :: custom-arg)))) * ([sin v] of (r_z :: custom-arg))) + (((((y :: custom-arg) - (rc_y :: custom-arg)) * ([cos v] of (r_x :: custom-arg))) - (((((x :: custom-arg) - (rc_x :: custom-arg)) * ([sin v] of (r_y :: custom-arg))) + (((z :: custom-arg) - (rc_z :: custom-arg)) * ([cos v] of (r_y :: custom-arg)))) * ([sin v] of (r_x :: custom-arg)))) * ([cos v] of (r_z :: custom-arg)))) - (cam_y :: custom-arg)) * ((fs :: custom-arg) / ((fs :: custom-arg) + (((((y :: custom-arg) - (rc_y :: custom-arg)) * ([sin v] of (r_x :: custom-arg))) + (((((x :: custom-arg) - (rc_x :: custom-arg)) * ([sin v] of (r_y :: custom-arg))) + (((z :: custom-arg) - (rc_z :: custom-arg)) * ([cos v] of (r_y :: custom-arg)))) * ([cos v] of (r_x :: custom-arg)))) - (cam_z :: custom-arg)))))
"3D projection is any method of mapping three-dimensional points to a two-dimensional plane."
3D projection allows projects to define an x,y,z location for a sprite, then place it on the screen. This method has been used to draw 3D objects using lists and the pen blocks.
Sprites can be resized based on the distance from the camera/viewer. This method can work very fast in Scratch, making it more ideal for games.
Lines can also be drawn between the projected points to create wireframe 3D renderings.
Perspective is usually used, but there are simpler projections, such as the orthographic projections, that are also used. It can be built using trigonometry and the perspective formula or with quaternions.
- studios:202972 (tutorial)
- projects:11343265 (quaternions)
( projects:799909 this project explains 3D projection math.)
Exporting from 3D Programs
Creating a 3D Object in a 3D Graphics Program, then saving it as a Wavefront (.obj) file. The lines and vertices are taken from the object file, and imported into 2 lists.
For every pair of number in the lines list, it will use the respective X, Y, and Z variables and draws a line using 3D projection (see above).
Although the script is complicated, some users have just provided the script and allowed anyone to change the list values to get their object.
Images created with 3D programs like Blender or Google SketchUp are imported as costumes in a sprite. Costumes portraying different angles of the object are switched quickly to make the object appear to rotate.
Sliced 3D method
- Main article: Animating a 3D Object
This is the 2nd simplest method in Scratch. It works by stacking or stamping 2D sprites, starting from the bottom up, offset up slightly for each layer. This set of drawings can be rotated to rotate the 3D object. As well as changing Y to make this image the X of an sprite can also be changed and given a "flip" effect instead of a rotating one. It uses the same idea as the "Y" stamping.
This is the simplest method in Scratch. It works by using size for the z position and does not rotate. It has an illusion that makes the sprites look like they are rotating but they are not. When a sprite touches 1 side, it goes to the other side (not touching it) and if a sprite touches the other side, it goes to the first side (again, not touching it).
Some users want a 3D editor to be implemented into Scratch. The Scratch Team has rejected this suggestion, stating that it would make Scratch confusing for beginners. Some users argue the point, saying that to make it less confusing, it could be restricted to only Scratchers, or saying that there could be two separate editors, but the suggestion remains rejected.
People have managed to create 3.5d wireframe projects, usually they are tesseracts, a type of 4-dimensional cube. However, it is impossible to project an actual 4D object to a 2D screen, so the 3.5D projects are really 3D.
2.5D projects are projects which use 2D graphics in 3D-like environments. They are less laggy and easier to create than 3D projects. Methods include cloning, stamping, and mouse locating. This term also applies to projects in which use 3D models but use them in 2D way.
- How to Make a Three-Dimensional Project
- Two Dimensional Objects
- 3D Wireframes
- 3D Patterns