360-panorama
360-panorama copied to clipboard
360-panorama for happy designer mini#2
360-panorama
WebGL
three.js Example
- Use Case:
- Google Street View
- Equirectangular Projection(等距圓柱投影)
data:image/s3,"s3://crabby-images/052f4/052f4e044fdded208ea58057fdd038459152c2d0" alt="equirectangular projection"
- Paste this image on a sphere.
- Saw this kind of image before?
data:image/s3,"s3://crabby-images/5c6c4/5c6c402451b8f3e0a6282fcf0a942c3fcfaaf17c" alt="equirectangular earth"
data:image/s3,"s3://crabby-images/3396c/3396c09087ec8171f5b90c2f0f4f19394bb7d767" alt="earth"
- Problems:
- ProblemsMobile device not support WebGL
- Android 4.1 native supports this format
- Want to build a web service to serve this image format and support mobile device
CSS
- How about
- Use hyperrectangular instead of sphere Which is much simpler
- Cubic Projection !!
Demo: CSS cubic
- Images!!
data:image/s3,"s3://crabby-images/cbb25/cbb2563c53e7459b3877326ccf7d61e9033bd032" alt=""
data:image/s3,"s3://crabby-images/41ca9/41ca9ca9de2fa946fe00741a1c75747af472a30f" alt=""
data:image/s3,"s3://crabby-images/64a73/64a73c646741462fee09a713d077ff39385f3c91" alt=""
data:image/s3,"s3://crabby-images/ba005/ba005c633d8be6541997e02d78d23eb6c8f2bea9" alt=""
data:image/s3,"s3://crabby-images/870b5/870b559b3c928866899f143c8d8d386ea18f5e2e" alt=""
data:image/s3,"s3://crabby-images/19009/190092ff3b49dc5ea134ed4f28d6d35ee8e14a0b" alt=""
- How to get the image for six faces?
- Ref: Converting an Equirectangular Panorama to Cubic Faces
How to control mouse drag?
-
θ is ?
theta = Math.atan2(0.5l, d);
Demo: CSS #1
- Somthing still wrong
- How about increase the face of the polygon
More Faces
- Hard to generate images for dodecahedron
- Use google stree view image API
- Not perfect
Demo: CSS dodecahedron
-
Learned:
- Use SVG clippath to clip the pentagon(五邊形) or you will see face overlape
- Remember to center pentagon, it is smaller than the square.
-
Problems
- Must support SVG
- Must work well when use both SVG and 3D transform
Back to Cubic
- Actually…
- My perspective is wrong on cubic version
- Thanks bigcat
Demo: CSS
- Problem:
- Canvas support is better than 3D transform (ref: caniuse)
Canvas 2D
- three.js supports 2d canvas….
- Other 3D library also supports too.
Demo: three.js 2D example, please open in Firefox.
- Implement 3d projection by 3D JS library