Pt-br/Bump map: Difference between revisions
(Added PT/BR translation) |
mNo edit summary |
||
Line 1: | Line 1: | ||
{{LanguageBar}} | {{LanguageBar}} | ||
[[File:Brickwall021a normalcompare.jpg|thumb|200px|O [[albedo]] de um material (esquerda) comparado ao seu bump map.]] | [[File:Brickwall021a normalcompare.jpg|thumb|200px|O [[albedo]] de um material (esquerda) comparado ao seu bump map.]] | ||
[[File:Example of bump mapping.jpg|thumb|200px|O material acima dentro do jogo.]] | [[File:Example of bump mapping.jpg|thumb|200px|O material acima dentro do jogo.]] | ||
Texturas chamadas '''Bump Maps''', ou '''Normal Maps''' são usadas para simular detalhes tridimensional em uma superfície bidimensional manipulando a como a iluminação. | Texturas chamadas '''Bump Maps''', ou '''Normal Maps''' são usadas para simular detalhes tridimensional em uma superfície bidimensional manipulando a como a iluminação. | ||
{{note|Props estáticos usando bump maps não podem ter iluminação per-vertex, exceto em {{L| | |||
{{note|Bump maps não podem ser usadas como texturas decal, exceto em {{L| | {{note|Props estáticos usando bump maps não podem ter iluminação per-vertex, exceto em {{L|csgo}} e {{L|Strata Source}}. {{L|$lightmap}} também e incompatível com {{L|$bumpmap}}.}} | ||
{{note|Bump maps não podem ser usadas como texturas decal, exceto em {{L|csgo}} e {{L|Strata Source}}. Em ordem para que esses funcionem corretamente, a superfície que eles são aplicadas devem também conter uma bumpmap.}} | |||
== Formatação == | == Formatação == | ||
Cada pixel em uma bump map contem as coordenadas (x, y, z) que definem o {{L|vector}} {{L|normal}}izado. | Cada pixel em uma bump map contem as coordenadas (x, y, z) que definem o {{L|vector}} {{L|normal}}izado. | ||
Por causa disso cada canal de cor em uma bump map tem um proposito: | Por causa disso cada canal de cor em uma bump map tem um proposito: | ||
; Red | ; Red | ||
Line 23: | Line 29: | ||
:* 128 = profundidade máxima capaz de receber luz dinâmica. É uma má ideia ir há baixo disto. | :* 128 = profundidade máxima capaz de receber luz dinâmica. É uma má ideia ir há baixo disto. | ||
:* 255 = voltado para fora da textura em direção ao observador. | :* 255 = voltado para fora da textura em direção ao observador. | ||
{{note|Uma bump map plana deve ser [128, 128, 255]. <code>dev/flat_normal</code> e uma textura bump map presente em todos os jogos.}} | {{note|Uma bump map plana deve ser [128, 128, 255]. <code>dev/flat_normal</code> e uma textura bump map presente em todos os jogos.}} | ||
Os três canais representam um vector normalizado para cada pixel que representa a direção que cada pixel estar virada no espaço 3D. Isto permite que a engine gere sombras e destaques em uma superfície bidimensional, ou dar um modelo 3D mais detalhe. | Os três canais representam um vector normalizado para cada pixel que representa a direção que cada pixel estar virada no espaço 3D. Isto permite que a engine gere sombras e destaques em uma superfície bidimensional, ou dar um modelo 3D mais detalhe. | ||
Uma bump map e grandemente inútil para superfícies bem planas, tipo superfícies suaves como concreto ou metal, mais as vezes ate concreto suave tem profundidade o suficiente para fazer uma valer a pena, especialmente se usada em conjunto com um {{L|cubemap}}. | Uma bump map e grandemente inútil para superfícies bem planas, tipo superfícies suaves como concreto ou metal, mais as vezes ate concreto suave tem profundidade o suficiente para fazer uma valer a pena, especialmente se usada em conjunto com um {{L|cubemap}}. | ||
[[file:normalmap.gif]] | [[file:normalmap.gif]] | ||
== Criação == | == Criação == | ||
Uma bump map deve ser renderizada em um espaço Tangente e fazer uso das direções do vector X+ Y- Z+. | Uma bump map deve ser renderizada em um espaço Tangente e fazer uso das direções do vector X+ Y- Z+. | ||
{{note|Há basicamente apenas duas regras para normal maps: {{L|DirectX}} e {{L|OpenGL}}. A interpretação deles de canais verde são opostas. {{L|Source}} usa o primeiro, enquanto {{L|Source 2}} usa o segundo. Assim, os canais verde talvez tenham de ser invertido dependendo do programa que usado para cria-la. }} | {{note|Há basicamente apenas duas regras para normal maps: {{L|DirectX}} e {{L|OpenGL}}. A interpretação deles de canais verde são opostas. {{L|Source}} usa o primeiro, enquanto {{L|Source 2}} usa o segundo. Assim, os canais verde talvez tenham de ser invertido dependendo do programa que usado para cria-la. }} | ||
=== Programas === | === Programas === | ||
[[File:Test_bump.jpg|thumb|600px|Exemplo de Bump maps criadas por diversos programas.]] | [[File:Test_bump.jpg|thumb|600px|Exemplo de Bump maps criadas por diversos programas.]] | ||
Vários programas podem automatizar a criação de bump maps, seja por analise de imagens ou usando geometria 3D que o usuário crie. | Vários programas podem automatizar a criação de bump maps, seja por analise de imagens ou usando geometria 3D que o usuário crie. | ||
;2D | ;2D | ||
Line 51: | Line 64: | ||
:[http://www.nvidia.com/object/melody_home.html NVIDIA Melody] | :[http://www.nvidia.com/object/melody_home.html NVIDIA Melody] | ||
:[http://planetpixelemporium.com/tutorialpages/normal2.html Cinema 4D] | :[http://planetpixelemporium.com/tutorialpages/normal2.html Cinema 4D] | ||
:{{ | :{{L|NormalMapper}} | ||
:[http://xnormal.net/ xNormal] | :[http://xnormal.net/ xNormal] | ||
;Outros | ;Outros | ||
Line 65: | Line 78: | ||
# Escolha o formato de sua imagem. Formatos descomprimidos como BGR888 são de alta qualidade quando comparada com formatos comprimidos como DXT1, mas tenha cuidado com o tamanho do arquivo. | # Escolha o formato de sua imagem. Formatos descomprimidos como BGR888 são de alta qualidade quando comparada com formatos comprimidos como DXT1, mas tenha cuidado com o tamanho do arquivo. | ||
# Cheque a caixa "Normal map" na lista de flags da textura após a importação ser concluída. Está cerca de 1/5 do caminho para baixo na lista. | # Cheque a caixa "Normal map" na lista de flags da textura após a importação ser concluída. Está cerca de 1/5 do caminho para baixo na lista. | ||
{{tip|VTFEdit pode gerar bump maps automaticamente. Veja o canto inferior direito da tela de importação.}} | {{tip|VTFEdit pode gerar bump maps automaticamente. Veja o canto inferior direito da tela de importação.}} | ||
==== Em {{L|Vtex (Source 1)|Vtex}} ==== | ==== Em {{L|Vtex (Source 1)|Vtex}} ==== | ||
# Salve suas normal maps como {{L|TGA}}. De a elas um nome que acabe em ''_normal''. O ''_normal'' no final do nome ira afetar como o {{L|Vtex (Source 1)|Vtex}} converte-as. Para uma parede de tijolo como exemplo, nos nomearíamos o arquivo como <code>brickwall_normal.tga</code>. | # Salve suas normal maps como {{L|TGA}}. De a elas um nome que acabe em ''_normal''. O ''_normal'' no final do nome ira afetar como o {{L|Vtex (Source 1)|Vtex}} converte-as. Para uma parede de tijolo como exemplo, nos nomearíamos o arquivo como <code>brickwall_normal.tga</code>. | ||
# Adicione <code>nocompress 1</code> e <code>normal 1</code> para o <texture filename>.txt na mesma pasta que sua textura, então compile-a. | # Adicione <code>nocompress 1</code> e <code>normal 1</code> para o <texture filename>.txt na mesma pasta que sua textura, então compile-a. | ||
=== Implementação === | === Implementação === | ||
Veja {{L|ent|$bumpmap}}. | Veja {{L|ent|$bumpmap}}. | ||
Latest revision as of 17:52, 10 September 2024

Texturas chamadas Bump Maps, ou Normal Maps são usadas para simular detalhes tridimensional em uma superfície bidimensional manipulando a como a iluminação.


Formatação
Cada pixel em uma bump map contem as coordenadas (x, y, z) que definem o vector normal izado.
Por causa disso cada canal de cor em uma bump map tem um proposito:
- Red
- Voltado para a horizontal (eixo X).
- 0 = esquerda
- 128 = para a frente, ou encarando o espectador
- 255 = direita
- Green
- Voltado para a vertical (eixo Y).
- 0 = cima
- 128 = para a frente, ou encarando o espectador
- 255 = baixo
- Blue
- Altura (eixo Z).
- 0 = voltado para 'dentro' da textura, longe do observador. Este é um valor 'ruim'. Qualquer coisa abaixo de 128 significa que a superfície deve estar voltada para longe do jogador, o que não é possível.
- 128 = profundidade máxima capaz de receber luz dinâmica. É uma má ideia ir há baixo disto.
- 255 = voltado para fora da textura em direção ao observador.

dev/flat_normal
e uma textura bump map presente em todos os jogos.Os três canais representam um vector normalizado para cada pixel que representa a direção que cada pixel estar virada no espaço 3D. Isto permite que a engine gere sombras e destaques em uma superfície bidimensional, ou dar um modelo 3D mais detalhe. Uma bump map e grandemente inútil para superfícies bem planas, tipo superfícies suaves como concreto ou metal, mais as vezes ate concreto suave tem profundidade o suficiente para fazer uma valer a pena, especialmente se usada em conjunto com um cubemap .
Criação
Uma bump map deve ser renderizada em um espaço Tangente e fazer uso das direções do vector X+ Y- Z+.

Programas
Vários programas podem automatizar a criação de bump maps, seja por analise de imagens ou usando geometria 3D que o usuário crie.
- 2D
- Photoshop ou Paint Shop Pro
- Substance Designer
- O GIMP
- nDo
- Filter Forge
- XBLAH's Modding Tool
- nJob
- 3D
- XSI
- ZBrush
- Lightwave
- 3ds Max
- Maya
- Blender
- Materialize
- NVIDIA Melody
- Cinema 4D
- NormalMapper
- xNormal
- Outros
- NormalMap Online: Um website para a geração de normal maps online.
- SSBump Generator 5.3: Apesar do nome, ele também pode ser usado para gerar bumpmaps, não apenas self-shadowing bump maps .
- Substance B2M3: Anteriormente conhecido como BitMap2Material.
- InsaneBump: Feito para ser especialmente uma alternativa gratuita para o agora substituído programa "CrazyBump" (pode acabar alertando o antivírus devido à incompatibilidade)
Conversão
No VTFEdit
Quando convertendo sua textura:
- Escolha o formato de sua imagem. Formatos descomprimidos como BGR888 são de alta qualidade quando comparada com formatos comprimidos como DXT1, mas tenha cuidado com o tamanho do arquivo.
- Cheque a caixa "Normal map" na lista de flags da textura após a importação ser concluída. Está cerca de 1/5 do caminho para baixo na lista.

Em Vtex
- Salve suas normal maps como TGA . De a elas um nome que acabe em _normal. O _normal no final do nome ira afetar como o Vtex converte-as. Para uma parede de tijolo como exemplo, nos nomearíamos o arquivo como
brickwall_normal.tga
. - Adicione
nocompress 1
enormal 1
para o <texture filename>.txt na mesma pasta que sua textura, então compile-a.
Implementação
Veja $bumpmap .
Veja também
- $ssbump : criação e uso do novo bump maps self-shadowing da Valve.
- Um artigo antigo que explica muito bem normal mapping
- Página wiki do Polycount sobre normal maps
- Creating a Material