forked from kscience/visionforge
Add files via upload
This commit is contained in:
parent
eb3786c5ca
commit
5bd6f98c6e
207
docs/tutorial.md
Normal file
207
docs/tutorial.md
Normal file
@ -0,0 +1,207 @@
|
|||||||
|
#Tutorial
|
||||||
|
|
||||||
|
###The main goal of this tutorial is to show all capabilities of ... (this part will be supplemented)
|
||||||
|
|
||||||
|
The simple visualization can be made with function `main`. (this part will be supplemented as well)
|
||||||
|
```kotlin
|
||||||
|
import kotlinx.html.div
|
||||||
|
import space.kscience.dataforge.context.Context
|
||||||
|
import space.kscience.visionforge.html.ResourceLocation
|
||||||
|
import space.kscience.visionforge.solid.*
|
||||||
|
import java.nio.file.Paths
|
||||||
|
|
||||||
|
fun main(){
|
||||||
|
val context = Context{
|
||||||
|
plugin(Solids)
|
||||||
|
}
|
||||||
|
|
||||||
|
context.makeVisionFile (
|
||||||
|
Paths.get("customFile.html"),
|
||||||
|
resourceLocation = ResourceLocation.EMBED
|
||||||
|
){
|
||||||
|
div {
|
||||||
|
vision {
|
||||||
|
solid {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
##Solids properties
|
||||||
|
**We will analyze which basic properties solids have using `box` solid.**
|
||||||
|
|
||||||
|
Basic properties:
|
||||||
|
1. `opacity` - It is set in `float`. It takes on values from 0 to 1, which represent percents of solid opacity. It's initial value is 1.
|
||||||
|
2. `color` - It can be specified as `Int`, `String`, or as three `Ubytes`, which represent color in `rgb`. Elementally, the solid will have `green` color.
|
||||||
|
3. `rotation` - it's the point, around which the solid will be rotated. Initially, the value is `Point3D(0, 0, 0)`
|
||||||
|
4. position, which is given by values `x`, `y`, `z`. Initial values are `x = 0`, `y = 0`, `z = 0`
|
||||||
|
|
||||||
|
Let's see how properties are set in solids.
|
||||||
|
The `small box` will have elemental values of properties. If you will not set properties, it will have the same `position`, `color`, `rotation`, and `opacity` values.
|
||||||
|
|
||||||
|
***You can see that `box` take four values. Later, we will discuss what they are doing in more detail. Now, it does not really matter.***
|
||||||
|
```kotlin
|
||||||
|
box(10, 10, 10, name = "small box"){
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
opacity = 1 //100% opacity
|
||||||
|
color("red") //as string
|
||||||
|
rotation = Point3D(0, 0, 0)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/83271/83271064e6a92f664b2ecabf996bd0425051c677" alt=""
|
||||||
|
|
||||||
|
The `big box` will have properties with custom values.
|
||||||
|
```kotlin
|
||||||
|
box(40, 40, 40, name = "big box"){
|
||||||
|
x = 20
|
||||||
|
y = 10
|
||||||
|
z = 60
|
||||||
|
opacity = 0.5 //50% opacity
|
||||||
|
color(0u, 179u, 179u) //color in rgb
|
||||||
|
rotation = Point3D(60, 80, 0)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/57561/57561f0afe1c008431694c88c0346025078a0bf7" alt=""
|
||||||
|
If we compare these boxes, we will see all differences.
|
||||||
|
|
||||||
|
Here is the function `main` with both boxes.
|
||||||
|
```kotlin
|
||||||
|
fun main(){
|
||||||
|
val context = Context{
|
||||||
|
plugin(Solids)
|
||||||
|
}
|
||||||
|
|
||||||
|
context.makeVisionFile (
|
||||||
|
Paths.get("customFile.html"),
|
||||||
|
resourceLocation = ResourceLocation.EMBED
|
||||||
|
){
|
||||||
|
div {
|
||||||
|
vision {
|
||||||
|
solid {
|
||||||
|
box(10, 10, 10, name = "small box"){
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
opacity = 1 //100% opacity
|
||||||
|
color("red") //as string
|
||||||
|
rotation = Point3D(0, 0, 0)
|
||||||
|
}
|
||||||
|
box(40, 40, 40, name = "big box"){
|
||||||
|
x = 20
|
||||||
|
y = 10
|
||||||
|
z = 60
|
||||||
|
opacity = 0.5 //50% opacity
|
||||||
|
color(0u, 179u, 179u) //rgb
|
||||||
|
rotation = Point3D(60, 80, 0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/185ea/185ea970b381c1d11b37ab3af1104e18afd12f79" alt=""
|
||||||
|
data:image/s3,"s3://crabby-images/c4877/c487779069b3d12f6e68f28b53f9655a1e4c2ab3" alt=""
|
||||||
|
|
||||||
|
###Basic Solids
|
||||||
|
Now, let's see which solids can be visualized:
|
||||||
|
1) PolyLine
|
||||||
|
2) Box
|
||||||
|
```kotlin
|
||||||
|
box(50, 50, 50, name = "box") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("pink")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/83478/83478b5efeb6a53d6f69afcc96468ca46041cc2b" alt=""
|
||||||
|
```kotlin
|
||||||
|
box(10, 25, 10, name = "high_box") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("black")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/339aa/339aa639a6916b341936b2cea667970f8eb8d9e1" alt=""
|
||||||
|
|
||||||
|
```kotlin
|
||||||
|
box(65, 40, 40, name = "wide_box") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("black")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/f427a/f427a70eed09d70180de1d3dd6cd7bfa6b1cfc07" alt=""
|
||||||
|
|
||||||
|
3) Sphere
|
||||||
|
```kotlin
|
||||||
|
sphere(50, name = "sphere") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("blue")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/73dc3/73dc36d105acaad8a762a13d691887457b0f0ba1" alt=""
|
||||||
|
4) Hexagon
|
||||||
|
```kotlin
|
||||||
|
hexagon(
|
||||||
|
Point3D(25, 30, 25),
|
||||||
|
Point3D(35, 30, 25),
|
||||||
|
Point3D(35, 30, 15),
|
||||||
|
Point3D(25, 30, 15),
|
||||||
|
Point3D(30, 18, 20),
|
||||||
|
Point3D(40, 18, 20),
|
||||||
|
Point3D(40, 18, 10),
|
||||||
|
Point3D(30, 18, 10),
|
||||||
|
name = "classic_hexagon"){
|
||||||
|
color("green")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/f53f4/f53f409826b8450f83879c5014cbc8ced9d17f8a" alt=""
|
||||||
|
```kotlin
|
||||||
|
hexagon(
|
||||||
|
Point3D(5, 30, 5),
|
||||||
|
Point3D(24, 30, 8),
|
||||||
|
Point3D(20, 30, -10),
|
||||||
|
Point3D(5, 30, -7),
|
||||||
|
Point3D(8, 16, 0),
|
||||||
|
Point3D(12, 16, 0),
|
||||||
|
Point3D(10, 16, -5),
|
||||||
|
Point3D(6.5, 12, -3),
|
||||||
|
name = "custom_hexagon"){
|
||||||
|
color("brown")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/d820b/d820bb4650fb83b82836d72167351b594633a381" alt=""
|
||||||
|
5) Cone
|
||||||
|
```kotlin
|
||||||
|
cone(60, 80, name = "cone") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("beige")
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/512b3/512b3843d2ae40f1a98f75b64937a480718827a8" alt=""
|
||||||
|
data:image/s3,"s3://crabby-images/1158f/1158f917b506b39c947b7dbc229e79c6f535a72a" alt=""
|
||||||
|
6) Cone Surface
|
||||||
|
```kotlin
|
||||||
|
coneSurface(60, 50, 30, 10, 100, name = "cone_surface") {
|
||||||
|
x = 0
|
||||||
|
y = 0
|
||||||
|
z = 0
|
||||||
|
color("red")
|
||||||
|
rotation = Point3D(2, 50, -9)
|
||||||
|
}
|
||||||
|
```
|
||||||
|
data:image/s3,"s3://crabby-images/c14ef/c14efceb67cf0876735d7948d53612b4e390286a" alt=""
|
||||||
|
data:image/s3,"s3://crabby-images/ae34b/ae34bf8b467efd10c0dc1b3911454d8788135c43" alt=""
|
||||||
|
7) Extruded
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user