-This is a GLSL fragment shader I originally made on [Shadertoy](https://www.shadertoy.com/view/Ds3XRl) when learning raymarching. Later I switched to analytic raycasting for better performance. It's made by raycasting simple spheres with a bunch of fbm noises used for the normals and colors, and a complete hack for the atmosphere.
+This is a GLSL fragment shader I originally made on [Shadertoy](https://www.shadertoy.com/view/Ds3XRl) when learning raymarching. Later I switched to analytic raycasting for better performance. It's made by raycasting simple spheres with a bunch of fbm noises used for the normals and colors, and a fake atmosphere computed with distance functions.
-I wanted to display it on a web page so that I can make a nice GUI to tweak some uniforms. Here it is !
+I wanted to display it on a web page so that I can make a nice GUI to tweak the uniforms. Here it is !
It runs at 60fps on my old low-end phone, so it should also be quite smooth on whatever device you have.
@@ -24,7 +24,7 @@ It runs at 60fps on my old low-end phone, so it should also be quite smooth on w
## Textures
-
data:image/s3,"s3://crabby-images/37d35/37d35a95705e8b8c36decf03420e5caf2623c699" alt="screenshot of the earth shader"
+
@@ -34,17 +34,22 @@ It runs at 60fps on my old low-end phone, so it should also be quite smooth on w
-This one uses textures (colors, specular, bump) borrowed and adapted from NASA [Visible Earth](https://visibleearth.nasa.gov/collection/1484/blue-marble) collection in order to render a realistic view of our home planet. Still with a few controls, and no quality setting because it should already run at full fps on most devices.
+After the procedural version, I found a bunch of textures to display a realistic view of some planets of our solar system. Still with a few controls, and no quality setting because it should already run at full fps on most devices.
## Note
If you want a minimalist setup to render GLSL shaders on a canvas like this one, you can check out the [little study](https://github.com/jsulpis/webgl-libs-comparison) I made before this project.
-## More samples
+## More renders
-
data:image/s3,"s3://crabby-images/b16c0/b16c0443a067f8b1e53009745ae9559505bf4734" alt="screenshot with different settings"
-
data:image/s3,"s3://crabby-images/bca87/bca87ec851f6621f0cdcd06fdfdae57ae0926006" alt="screenshot with different settings"
-
data:image/s3,"s3://crabby-images/22edd/22eddef4fe8dd2fea623304666da6ea6ecd67947" alt="screenshot with different settings"
-
data:image/s3,"s3://crabby-images/ba584/ba584e91aca3bff2882cfa11e7bdad0d51d5b01f" alt="screenshot with different settings"
+
data:image/s3,"s3://crabby-images/8b21d/8b21de00d75ee81c1578e2e8eb4970a7c9102697" alt="a render of the Earth"
+
data:image/s3,"s3://crabby-images/c2c0d/c2c0d786e7eea7449b585f5de4a5fa71e2e785c6" alt="a render of the Moon"
+
data:image/s3,"s3://crabby-images/ae2be/ae2becf26e1fb011b2d01f907163e8d2a60571ac" alt="a render of Mercury"
+
data:image/s3,"s3://crabby-images/eb9b9/eb9b9b1713233ed7f6c6107949f37c72da59eca3" alt="a render of Venus"
+
data:image/s3,"s3://crabby-images/c5364/c5364434b0bbb7d31e5cb9e57105eb93978a2929" alt="a render of Mars"
+
data:image/s3,"s3://crabby-images/5521d/5521d2878d6ac6fed1fb93020324225e897d8cdf" alt="a render of Jupiter"
+
data:image/s3,"s3://crabby-images/bca87/bca87ec851f6621f0cdcd06fdfdae57ae0926006" alt="a render of the procedural planet"
+
data:image/s3,"s3://crabby-images/22edd/22eddef4fe8dd2fea623304666da6ea6ecd67947" alt="a render of the procedural planet"
+
diff --git a/screenshots/earth-1.jpg b/screenshots/earth-1.jpg
deleted file mode 100644
index 63fc736..0000000
Binary files a/screenshots/earth-1.jpg and /dev/null differ
diff --git a/screenshots/earth-ui.jpg b/screenshots/earth-ui.jpg
index 83573b3..dd1dcf2 100644
Binary files a/screenshots/earth-ui.jpg and b/screenshots/earth-ui.jpg differ
diff --git a/screenshots/earth.jpg b/screenshots/earth.jpg
new file mode 100644
index 0000000..a59f599
Binary files /dev/null and b/screenshots/earth.jpg differ
diff --git a/screenshots/jupiter.jpg b/screenshots/jupiter.jpg
new file mode 100644
index 0000000..91f756f
Binary files /dev/null and b/screenshots/jupiter.jpg differ
diff --git a/screenshots/mars.jpg b/screenshots/mars.jpg
new file mode 100644
index 0000000..cf465ab
Binary files /dev/null and b/screenshots/mars.jpg differ
diff --git a/screenshots/mercury.jpg b/screenshots/mercury.jpg
new file mode 100644
index 0000000..a8dc03c
Binary files /dev/null and b/screenshots/mercury.jpg differ
diff --git a/screenshots/moon.jpg b/screenshots/moon.jpg
new file mode 100644
index 0000000..7817298
Binary files /dev/null and b/screenshots/moon.jpg differ
diff --git a/screenshots/procedural-1.jpg b/screenshots/procedural-1.jpg
index 2bdf74b..d02903d 100644
Binary files a/screenshots/procedural-1.jpg and b/screenshots/procedural-1.jpg differ
diff --git a/screenshots/procedural-2.jpg b/screenshots/procedural-2.jpg
index a42dd45..0287a75 100644
Binary files a/screenshots/procedural-2.jpg and b/screenshots/procedural-2.jpg differ
diff --git a/screenshots/procedural-3.jpg b/screenshots/procedural-3.jpg
index b52d329..77bd181 100644
Binary files a/screenshots/procedural-3.jpg and b/screenshots/procedural-3.jpg differ
diff --git a/screenshots/procedural-ui.jpg b/screenshots/procedural-ui.jpg
index a9f723d..83ef9be 100644
Binary files a/screenshots/procedural-ui.jpg and b/screenshots/procedural-ui.jpg differ
diff --git a/screenshots/venus.jpg b/screenshots/venus.jpg
new file mode 100644
index 0000000..7b832a4
Binary files /dev/null and b/screenshots/venus.jpg differ
diff --git a/src/pages/mars.astro b/src/pages/mars.astro
index 9ab5e95..22b889d 100644
--- a/src/pages/mars.astro
+++ b/src/pages/mars.astro
@@ -28,7 +28,7 @@ import Layout from "../layouts/Layout.astro";
uniforms: {
...defaultUniforms,
uAtmosphereColor: [0.9, 0.15, 0],
- uAtmosphereDensity: 0.1,
+ uAtmosphereDensity: 0.2,
uQuality: Math.min(window.devicePixelRatio, 2),
uPlanetColor,
uStars,