This repository has been archived by the owner on Jul 27, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
5c31606
commit 1cae76f
Showing
16 changed files
with
211 additions
and
157 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,152 +1,206 @@ | ||
# Welcome | ||
|
||
data:image/s3,"s3://crabby-images/e8480/e84807e4a8935af3b0d2e5c694e0ffef7cf66c1f" alt="" | ||
|
||
*The following is an in-progress quick start guide* | ||
|
||
ArmorPaint is a stand-alone tool specialized in physically based texture painting of 3D models. Import geometry and start painting right away. A modern viewport provides instant visual feedback as you paint. | ||
|
||
--- | ||
|
||
# Download | ||
|
||
Runs on **Windows** and **Linux**. **macOS** builds are provided, but currently as unsigned app. | ||
|
||
- [Get ArmorPaint](http://armorpaint.org/download.html) | ||
|
||
### Requirements | ||
|
||
As of now ArmorPaint is known to work on Intel HD4000 graphics card for 4K texture painting. For 16K textures, GTX 1060/6GB or better is recommended. ArmorPaint runs on the GPU and the performance mainly depends on a graphics card. | ||
|
||
### Limitations | ||
|
||
Only one-step undo is supported and masking features are limited to color id maps. These issues will be resolved in upcoming builds. | ||
|
||
# Get Started | ||
|
||
<iframe width="560" height="315" src="https://www.youtube.com/embed/OzRqXIsvahg?rel=0" frameborder="0" allow="autoplay; encrypted-media" allowfullscreen></iframe> | ||
|
||
### Windows | ||
|
||
Run `ArmorPaint.exe`. In some cases, Windows may propt you with the [unrecognized app dialog](http://armorpaint.org/manual/img/startup_win.png) - press `More Info - Run Anyway`. | ||
|
||
### Linux | ||
|
||
Open terminal in the extracted folder and run `./ArmorPaint`. | ||
|
||
### macOS | ||
|
||
*Experimental:* See `instructions.txt` file in the extracted folder. | ||
|
||
### Controls | ||
|
||
- `Left mouse button` to paint | ||
- `Right mouse button` to rotate the mesh | ||
- `Middle mouse button` to pan camera | ||
- `Mouse wheel` to zoom in and out | ||
- `Tab` to show material nodes | ||
- `Ctrl+Z` to undo | ||
- `Shift+[1,2,3,4,5]` to quick-select tool | ||
- `Alt+[1,2,3,4,5]` to quick-select material | ||
- `x` or `backspace` to delete node | ||
|
||
# Assets | ||
|
||
### Import Meshes | ||
|
||
Drag and drop unwrapped `.obj` file into the viewport. This will replace the currently painted mesh. `.fbx` and `.gltf` files are supported, but the importer is not 100% reliable yet and may fail. Importing `.blend` format is in progress but not yet supported. Use Blender to do the conversion in the meantime. | ||
|
||
As a quick test, you can import the `monkey.obj` file located in the extracted ArmorPaint folder. | ||
|
||
data:image/s3,"s3://crabby-images/0a06a/0a06a6aba344eb967d254577369ab70dbccb0aab" alt="" | ||
|
||
### Import Materials | ||
|
||
Importing Cycles materials from `.blend` format is in progress but not yet supported. Assemble materials in the built-in node editor for now. | ||
|
||
### Import Textures | ||
|
||
Drag and drop `.jpg`, `.png`, `.tga` or `.hdr` images into the node editor. This will import the image and create a new `Image` node. | ||
|
||
### Export Textures | ||
|
||
Click `Export - Export Textures`. Format, resolution and channels to export can be configured. | ||
|
||
# Materials | ||
|
||
Material nodes in ArmorPaint are based on Cycles nodes. When painting, brush applies a material onto the surface. To setup material, invoke node editor with `Tools - Material - Nodes`. Use toolbar at the top to add new nodes. | ||
|
||
data:image/s3,"s3://crabby-images/23aa3/23aa313d5596220b6fa4ded9ed053a3b0605edf5" alt="" | ||
|
||
# Painting | ||
|
||
### Draw | ||
|
||
Select `Draw` tool from toolbar. Configure brush parameters in `Tools - Draw`. `Left mouse button` to paint strokes. | ||
|
||
### Sticker | ||
|
||
Select `Draw` tool from toolbar. Set `Paint` combo propertry located in `Tools - Draw` to `Sticker`. `Left mouse button` to project stickers onto surface. | ||
|
||
data:image/s3,"s3://crabby-images/fb0db/fb0db226aa06d313cf9c85120d9dfa53bc9dc289" alt="" | ||
|
||
### Erase | ||
|
||
Select `Erase` tool from toolbar. Only strokes on the second layer can be erased currently. | ||
|
||
### Fill | ||
|
||
Select `Fill` tool from toolbar. `Left mouse button` to fill active layer with selected material. | ||
|
||
### Bake Ambient Occlusion | ||
|
||
*Experimental:* Select `Bake` tool from toolbar and click on a model in viewport to bake AO. | ||
|
||
### Pick Color ID | ||
|
||
Select `Color ID` tool from toolbar. Drag and drop color-id texture onto the viewport and assign it into the `Color ID Map` field. Afterwards, click on a model to pick a specific color. All drawing operations will now be restricted to this color. Picked color can be removed with a `Clear` button. | ||
|
||
### Painting height | ||
|
||
Select `Draw` tool from toolbar. Enable `Height` checkbox located in `Tools - Draw`. Afterwards, `Height` socket exposed in material node editor will take effect. | ||
|
||
### Layers | ||
|
||
To create a new layer, click `Tools - Layers - New`. Brushes will be painted on the currently selected layer. Afterwards, layer can be deleted or applied to the base layer 1. Only two layers at once are supported as of now. | ||
|
||
data:image/s3,"s3://crabby-images/f1579/f15791a92bf0acfb99553068e5f29291a96c1b44" alt="" | ||
|
||
### 2D View | ||
|
||
Click `Layers - 2D View` to show the texture of the selected layer. The 2D View is updated immediatelly as you paint. | ||
|
||
# Preferences | ||
|
||
### Scaling | ||
|
||
*Experimental:* It is possible to scale up the user interface in `Preferences - UI Scale`. Once set, hit `Save` to remember the setting. | ||
|
||
### Pen Pressure | ||
|
||
When painting with a pen, pressure affects the radius of brush. | ||
|
||
### Theming | ||
|
||
UI theme can be configured by editing the `theme.arm` file placed alongside the ArmorPaint binary. A proper theme editor will be provided in the future. | ||
|
||
### Undo | ||
|
||
Controls whether undo system is active. Disabling may improve performance when running on slower GPU. | ||
|
||
# Plugins | ||
|
||
To enable plugins, edit the `config.arm` file placed in the `ArmorPaint/data` folder. A plugin filename can be entered into the `plugins` array. A proper plugin manager will be provided in the future. | ||
|
||
Plugins are written in JavaScript or WebAssembly. For a minimal example, see the bundled [plugin_hello.js](https://github.com/armory3d/armorpaint/blob/master/Bundled/plugin_hello.js) and [plugin_rotate.js](https://github.com/armory3d/armorpaint/blob/master/Bundled/plugin_rotate.js). | ||
|
||
```json | ||
{ | ||
... | ||
"plugins": ["plugin_hello.js"] | ||
} | ||
``` | ||
# Welcome | ||
|
||
data:image/s3,"s3://crabby-images/e8480/e84807e4a8935af3b0d2e5c694e0ffef7cf66c1f" alt="" | ||
|
||
ArmorPaint is an in-development software specialized in PBR texture painting of 3D models. Import geometry and start painting right away. A modern viewport provides instant visual feedback as you paint. | ||
|
||
*The preview version has many rough edges and the experience may be frustrating.* | ||
|
||
--- | ||
|
||
# Download | ||
|
||
**Windows** and **Linux** is recommended. An unsigned **macOS** build is also provided. ArmorPaint is a portable application with no installation, just unpack and run. Download size is ~6MB, ~15MB unpacked. | ||
|
||
- [Get ArmorPaint](http://armorpaint.org/download.html) | ||
|
||
#### Requirements | ||
|
||
ArmorPaint runs on the GPU and the performance mainly depends on a graphics card. Recommended minimum for 4K painting is an Intel HD4000 graphics card. For 16K painting, GTX 1060/6GB or better is recommended. | ||
|
||
# Get Started | ||
|
||
<iframe width="560" height="315" src="https://www.youtube.com/embed/OzRqXIsvahg?rel=0" frameborder="0" allow="autoplay; encrypted-media" allowfullscreen></iframe> | ||
|
||
#### Windows | ||
|
||
Unpack downloaded archive and run `ArmorPaint.exe`. In some cases, Windows may prompt you with the [unrecognized app dialog](http://armorpaint.org/manual/img/startup_win.png) - press `More Info - Run Anyway`. | ||
|
||
#### Linux | ||
|
||
Open terminal in the extracted folder and run `./ArmorPaint`. | ||
|
||
#### macOS | ||
|
||
*Experimental:* Unsigned app is provided. See `instructions.txt` file in the extracted folder. | ||
|
||
#### Controls | ||
|
||
- `Left mouse button / Pen` to paint | ||
- `Right mouse button` to rotate the mesh | ||
- `Middle mouse button` to pan camera | ||
- `Mouse wheel` to zoom in and out | ||
- See `Preferences - Controls` for keyboard shortcuts | ||
|
||
# Workflow | ||
|
||
data:image/s3,"s3://crabby-images/c8acf/c8acfa121ba50e5bb89e056700ec1fde186e7395" alt="" | ||
|
||
You can download sample assets for testing [here](https://github.com/armory3d/armorpaint_samples/releases). | ||
|
||
#### Import Meshes | ||
|
||
Drag and drop unwrapped `.obj` file into the viewport. This will replace the currently painted mesh. `.fbx`, `.blend` and `.gltf` files are supported, but the importer is not 100% reliable yet. | ||
|
||
#### Import Materials | ||
|
||
Drag and drop a folder with PBR texture set onto the viewport. ArmorPaint will automatically create a new material from imported textures. Importing Cycles materials from `.blend` format is in progress but not yet supported. | ||
|
||
#### Import Textures | ||
|
||
Drag and drop `.jpg`, `.png`, `.tga` or `.hdr` images into the node editor. This will import the image and create a new `Image` node. | ||
|
||
#### Export Textures | ||
|
||
Click on the `File - Export - Export Textures` button. Format, resolution and channels to export can be configured. | ||
|
||
#### Export Mesh | ||
|
||
Export the currently loaded mesh into an `.obj` file. This is handy if you only have access to the project file. Click on the `File - Export - Export Mesh` button. | ||
|
||
#### Save / Load Project | ||
|
||
Click on the `File - Project Save` button or hit `Ctrl + S` to save the currently opened project. Mesh, layers and materials will be saved into `.arm` project file. | ||
|
||
To open the project file, drag and drop `.arm` file onto the viewport. | ||
|
||
# Materials | ||
|
||
data:image/s3,"s3://crabby-images/23aa3/23aa313d5596220b6fa4ded9ed053a3b0605edf5" alt="" | ||
|
||
Materials in ArmorPaint are composed with nodes. When painting, brush applies a material onto the surface. To setup a material, open node editor by clicking `Tools - Material - Nodes` or hit `TAB`. Use toolbar at the top to add new nodes. | ||
|
||
You can see the material preview instantly in the `Materials` panel as the nodes are assembled. | ||
|
||
*See [Import Materials](http://localhost:3000/#/?id=import-materials)* | ||
|
||
# Painting | ||
|
||
data:image/s3,"s3://crabby-images/f1579/f15791a92bf0acfb99553068e5f29291a96c1b44" alt="" | ||
|
||
#### Draw | ||
|
||
data:image/s3,"s3://crabby-images/1c216/1c2166e49af0cfc1290a3f56b6744b90d897dcaa" alt="" | ||
|
||
Select `Draw` tool from toolbar. Configure brush parameters in `Tools - Draw`. Press `Left mouse button` to paint strokes. | ||
|
||
**Sticker** | ||
|
||
Set `Paint` combo property located in `Tools - Draw` to `Sticker`. `Left mouse button` to project stickers onto surface. | ||
|
||
#### Erase | ||
|
||
data:image/s3,"s3://crabby-images/1b350/1b350f0803f66ec6142ab4f37501f54b2d1767fc" alt="" | ||
|
||
Select `Erase` tool from toolbar. Only strokes on the second layer or higher can be erased. | ||
|
||
#### Fill | ||
|
||
data:image/s3,"s3://crabby-images/73136/73136d30074938ee82d23854f00ba7b2f4834cc5" alt="" | ||
|
||
Select `Fill` tool from toolbar. `Left mouse button` to fill active object and layer with selected material. | ||
|
||
**Auto-Fill** | ||
|
||
Enable this option to perform a fill instantly as you change the material. This is useful to quickly preview material on target surface. | ||
|
||
#### Bake Ambient Occlusion | ||
|
||
data:image/s3,"s3://crabby-images/d96d5/d96d5f447000c668d4363979d5a8615f441bae81" alt="" | ||
|
||
Select `Bake` tool from toolbar and click on a model in viewport to bake AO. Strength, radius and offset can be configured. Afterwards, you can prevent the occlusion texture from being painted on by disabling it in the `Paint Maps` panel. | ||
|
||
#### Pick Color ID | ||
|
||
data:image/s3,"s3://crabby-images/f39c9/f39c9a9ba32fdc7a2eafc3cdec94018e3de4a194" alt="" | ||
|
||
Select `Color ID` tool from toolbar. Drag and drop color-id texture onto the viewport and assign it into the `Color ID Map` field. Afterwards, click on a model to pick a specific color. All drawing operations will now be restricted to this color. Picked color can be removed with a `Clear` button. | ||
|
||
#### Painting height | ||
|
||
Select `Draw` tool from toolbar. Enable `Height` checkbox located in `Tools - Paint Maps` panel. Afterwards, `Height` socket exposed in material node editor will take effect. | ||
|
||
#### Paint Maps | ||
|
||
This panel allows to set which textures can be painted on. | ||
|
||
#### Layers | ||
|
||
To create a new layer, click `Tools - Layers - New`. Brush will paint on the currently selected layer. Afterwards, layer can be deleted or applied to the base layer 1. | ||
|
||
#### Objects | ||
|
||
If you import a geometry containing multiple objects, you can list them in the `Objects` panel. Set `Mask` property to `Object` to restrict painting to selected object only. | ||
|
||
Objects are assumed to be using a single UV map for now. `.obj` format is recommended for multi-object support. | ||
|
||
#### 2D View | ||
|
||
Click `Layers - 2D View` to show the texture of the selected layer. The 2D View is updated immediately as you paint. In the top panel, you can select which texture to show or display UV map. | ||
|
||
#### Camera | ||
|
||
Set camera type and parameters. | ||
|
||
- `ArcBall` - rotate mesh around the origin | ||
- `Orbit` - rotate camera around the mesh | ||
- `Fly` - move camera freely using the `WASD` keys | ||
|
||
#### Viewport | ||
|
||
- Set light and environment intensity | ||
- Set specific texture channel to show in the viewport | ||
- Based on imported model, you can flip `Up Axis` to `Y` or `Z` | ||
- Enable `Show Envmap` to draw environment map in the viewport | ||
- *Experimental:* You can drag and drop 2K `.hdr` file onto the viewport to change the environment map | ||
|
||
# Preferences | ||
|
||
data:image/s3,"s3://crabby-images/1f99e/1f99ea9a993437fc8f499829d3ce65b13ff63354" alt="" | ||
|
||
#### UI Scale | ||
|
||
When running on high-resolution display, scale up the user interface in `Preferences - UI Scale`. | ||
|
||
#### Layout | ||
|
||
User interface can be displayed either on the left or right side. | ||
|
||
#### Theming | ||
|
||
Theme can be tweaked by editing the `theme.arm` file placed in the `data` folder. A proper theme editor will be provided in the future. | ||
|
||
#### Pen Pressure | ||
|
||
When painting with a pen, pressure affects the radius of brush. | ||
|
||
#### Undo Steps | ||
|
||
Sets the number of undo steps to preserve. Using less undo steps may improve performance when running on slower GPU with constrained memory. | ||
|
||
#### Viewport | ||
|
||
Configure viewport effects. On faster GPUs, raise the shadows quality or set super-samling to 2.0x for improved anti-aliasing. On slower GPUs, disable SSAO, shadows or set super-sampling to 0.5x for improved performance. | ||
|
||
# Plugins | ||
|
||
To enable plugins, edit the `config.arm` file placed in the `data` folder. A plugin filename can be entered into the `plugins` array. A proper plugin manager will be provided in the future. | ||
|
||
Plugins are written in JavaScript or WebAssembly. For a minimal example, see the bundled [plugin_hello.js](https://github.com/armory3d/armorpaint/blob/master/Bundled/plugin_hello.js) and [plugin_rotate.js](https://github.com/armory3d/armorpaint/blob/master/Bundled/plugin_rotate.js) located in the `data` folder. | ||
|
||
```json | ||
{ | ||
... | ||
"plugins": ["plugin_hello.js"] | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
* Getting Started | ||
|
||
* [Home](/) | ||
* Manual | ||
|
||
* [Home](/) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters