Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/podgorskiy/envmaptool
https://github.com/podgorskiy/envmaptool
converts-cube-map cubemap dds dds-format environment environment-mapping map sphere sphere-map texture tga
Last synced: 3 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/podgorskiy/envmaptool
- Owner: podgorskiy
- License: mit
- Created: 2015-08-01T20:24:58.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2015-08-23T07:13:35.000Z (over 9 years ago)
- Last Synced: 2024-03-20T13:30:37.933Z (11 months ago)
- Topics: converts-cube-map, cubemap, dds, dds-format, environment, environment-mapping, map, sphere, sphere-map, texture, tga
- Language: C
- Size: 9.64 MB
- Stars: 30
- Watchers: 4
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
#[EnvMapTool](https://github.com/podgorskiy/EnvMapTool) - Cross-platform tool for working with environmental maps.
============================================================================Performs a set of different actions:
* Converts cube map to sphere map
* Converts sphere map to cube map
* Blurs cubmap
* Assembles cubemaps from a set of images
* Disassembles cubemap to a set of imagesSupported formats fow read/write:
* DDS. Not compressed.
* TARGA
* PNG#Usage:
Input and output files can be specified in two ways:* As single file. Use keys -i / -o
* As six files that represent x+, x-, y+, y-, z+, z- faces, use keys -I / -OSpecify output format with key -f. It can be: TGA, PNG, DDS. For example `-f PNG`. Default is TGA.
Specify desired action:
* `cube2sphere` - converts cube map to sphere map
* `sphere2cube` - converts sphere map to cube map
* `blurCubemap` - blurs cubemap using Monte Carlo method. Accurate but slow approach.
* `fastBlurCubemap` - blurs cubemap using Monte Carlo method. Inaccurate but fast approach.
* `convert` - this action does nothing. Should be used to convert cubemap from one format to other.If you specifed a single file for output, that does not support multiple faces (not DDS format), than omly one face will be written. This face can be specified by flag `-F`
You may specify gamma for input texture `-g`, and gamma for output texture `-G`. Default is 2.2
You may specify size of output texture using keys `-W` and `-H`.
For actions *blurCubemap* and *fastBlurCubemap* you may set bluring radius by use of key `-b`
For action *blurCubemap* blur quality can be specified by key `-q`. Effects the number of samples in Monte Carlo integration. Reasonable values are between 4 - 10. Large values will increase calculation time dramatically. Default is 4
#Exapmles
----------------------------------------------------------------------------
##Converting DDS to a series of png files:
Let we have cubemap in DDS format: uffizi_cros.dds
To convert it to six *.png files that represent x+, x-, y+, y-, z+, z- faces you need to execite following command:
```
EnvMapTool -i uffizi_cros.dds -O 1.png -O 2.png -O 3.png -O 4.png -O 5.png -O 6.png -f PNG convert
```
The output will be:data:image/s3,"s3://crabby-images/e948a/e948a6250df93a08929a0d0a6e725fb8605d2314" alt="xp"
data:image/s3,"s3://crabby-images/e47ed/e47edcc59d099b52b9c8ddef67ff9c3d7f324bbf" alt="xm"
data:image/s3,"s3://crabby-images/87b5b/87b5be00b7b9b25b554715a0583cf6d88cb77fe5" alt="yp"
data:image/s3,"s3://crabby-images/9d3ad/9d3adc36b0d51fd60990c169beb97147c6de156a" alt="ym"
data:image/s3,"s3://crabby-images/92d4b/92d4b34016453073ba5752913b31a7b12239ec12" alt="zp"
data:image/s3,"s3://crabby-images/0f4e8/0f4e8a7480adec6faa165406433fccb08bbcba23" alt="zm"##Converting DDS cubemap to sphere map
Lets convert uffizi_cros.dds to sphere map and specify size of sphere map of 765x765:
```
EnvMapTool -i uffizi_cros.dds -o sphere.png -W 765 -H 765 -f PNG cube2sphere
```
data:image/s3,"s3://crabby-images/57527/575278ac893a2d669331a6603f306ec35551a888" alt="sphere"##Converting sphere map to cubemap
Lets convert generated in previous example sphere map to a series of png texture of size 256x256:
```
EnvMapTool -i sphere.png -O xp_.png -O xm_.png -O yp_.png -O ym_.png -O zp_.png -O zm_.png -W 256 -H 256 -f PNG sphere2cube
```data:image/s3,"s3://crabby-images/89e43/89e432399ae95cb742b9906041e13f137d158492" alt="xp_"
data:image/s3,"s3://crabby-images/2b65b/2b65b743b6ce789ef377bac1d3411be4fbc867a8" alt="xm_"
data:image/s3,"s3://crabby-images/cddff/cddff6f2b29868f26053f86e1c6d381c4bff4c45" alt="yp_"
data:image/s3,"s3://crabby-images/de61d/de61d75fac11f4583e0743cf940d396c901d0b65" alt="ym_"
data:image/s3,"s3://crabby-images/5c9a8/5c9a8a62f43f725ea4007a81301bd640acc13282" alt="zp_"
data:image/s3,"s3://crabby-images/1cd13/1cd13cb4a60a1293633f825c5a6a483b45ad6583" alt="zm_"##Bluring cubemap using Monte-Carlo approach and converting it to spheremap:
```
EnvMapTool -i uffizi_cros.dds -O 1.png -O 2.png -O 3.png -O 4.png -O 5.png -O 6.png -W 256 -H 256 -f PNG blurCubemap -b 60 -q 10
EnvMapTool -I 1.png -I 2.png -I 3.png -I 4.png -I 5.png -I 6.png -o bluredSphere.png -W 765 -H 765 -f PNG cube2sphere
```
data:image/s3,"s3://crabby-images/28350/28350d1d6cf145e310b26763b99f5b5620e9a8fc" alt="bluredsphere"##The same as above, but using fast blur:
```
EnvMapTool -i uffizi_cros.dds -O 1.png -O 2.png -O 3.png -O 4.png -O 5.png -O 6.png -f PNG fastBlurCubemap -b 30
EnvMapTool -I 1.png -I 2.png -I 3.png -I 4.png -I 5.png -I 6.png -o fastBluredSphere.png -W 765 -H 765 -f PNG cube2sphere
```
data:image/s3,"s3://crabby-images/8ab78/8ab78e68a6eac4c61ca525024aa892115d699a86" alt="fastbluredsphere"##Detailed usage:
```
USAGE:./EnvMapTool {-o |-O ... } {-i
|-I ... } [-f ] [-F ] [-q ] [-b ] [-l] [-g
] [-G ] [-H ] [-W ] [--version] [-h]
Where:
-o , --output
(OR required) The output texture file.
-- OR --
-O , --outputSequence (accepted multiple
times)
(OR required) The output texture files for cube map. You need specify
six files: xp, xn yp, yn, zp, zn-i , --input
(OR required) The input texture file. Can be of the following
formats: *.tga, *.png, *.dds
-- OR --
-I , --inputSequence (accepted multiple
times)
(OR required) The input texture files for cube map. You need specify
six files: xp, xn yp, yn, zp, zn. WARNING! All the files MUST be the
same format and size!-f , --format
Output texture file format. Can be one of the following "TGA", "DDS",
"PNG". Default TGA.-F , --faceToWrite
If cubemap texture is written to format that does not support faces,
this face will be written-q , --blurQuality
Effects the number of samples in Monte Carlo integration. Reasonable
values are between 4 - 8. Large values will increase calculation time
dramatically. Default is 4-b , --blurRadius
Gaussian blur radius. Default is 10.0-l, --leaveOuter
If flag is set, than while cubemap -> sphere transform area around the
sphere circule are not filled black, but represent mathematical
extrapolation.-g , --inputGamma
Gamma of input texture. Default is 2.2-G , --outputGamma
Gamma of output texture. Default is 2.2-H , --outputHeight
Height of output texture. Default is the same as input, or 4 times
upscaled in case of cube2sphere transform, or 4 times downscaled in
case of sphere2cube transform-W , --outputWidth
Width of output texture. Default is the same as input, or 4 times
upscaled in case of cube2sphere transform, or 4 times downscaled in
case of sphere2cube transform--version
Displays version information and exits.-h, --help
Displays usage information and exits.
(required) Action. Can be:cube2sphere - Converts cube map texture to spherical map
sphere2cube - Converts spherical map texture to cube map
blurCubemap - Gaussian blur of cubemap
convert - Do nothing. Just to convert txture from one format to
other
```