forked from kscience/visionforge
Delete tutorial.md
This commit is contained in:
parent
4bdea746fc
commit
2643d2b587
333
docs/tutorial.md
333
docs/tutorial.md
@ -1,333 +0,0 @@
|
||||
# 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)`. Changing `x` coordinate of the point, you make pivot around `x axis`. The same for other coordinates: changing `y` - pivot around `y axis`, changing `z` - pivot around `z axis`.
|
||||
4. position, which is given by values `x`, `y`, `z`. Initial values are `x = 0`, `y = 0`, `z = 0`. The coordinate system is Cartesian. It's elemental position is this - vertical `y` axis and horizontal `Oxz` plane.
|
||||
|
||||
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 do 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/aa21e/aa21ed13ec92f1e948cfe23564e28d66c59ef709" 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/8f93c/8f93c40ccd74c89120be11af6d8d04f06b570693" 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=""
|
||||
|
||||
***There is plenty of other properties, especially of those, which you can create by yourself. Here we mention just small part.***
|
||||
|
||||
## Basic Solids
|
||||
Now, let's see which solids can be visualized:
|
||||
### 1) PolyLine
|
||||
### 2) Box
|
||||
|
||||
First thing which has to be mentioned is that `box` takes four values: `box(x, y, z, name)`
|
||||
* `x` - x-axis length of the `box`
|
||||
* `y` - y-axis length of the `box`
|
||||
* `z` - z-axis length of the `box`
|
||||
|
||||
These values have `Float` type. *`x`, `y`, and `z` are necessary values, which cannot be ignored. You have to set them.*
|
||||
|
||||
* `name` - `box`'es identifier with `String` type. *It's an optional value, but without it you won't be able to control solid.*
|
||||
|
||||
Let's create just usual `box` with equal ribs.
|
||||
|
||||
```kotlin
|
||||
box(50, 50, 50, name = "box") {
|
||||
color("pink")
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/83478/83478b5efeb6a53d6f69afcc96468ca46041cc2b" alt=""
|
||||
|
||||
Now, let's make `box` with bigger `y` value.
|
||||
```kotlin
|
||||
box(10, 25, 10, name = "high box") {
|
||||
color("black")
|
||||
}
|
||||
```
|
||||
As you can see, only rib of `y-axis` differs from other ribs.
|
||||
|
||||
data:image/s3,"s3://crabby-images/339aa/339aa639a6916b341936b2cea667970f8eb8d9e1" alt=""
|
||||
|
||||
For final trial, let's create `box` with bigger `x` value.
|
||||
|
||||
```kotlin
|
||||
box(65, 40, 40, name = "wide box") {
|
||||
x = 0
|
||||
y = 0
|
||||
z = 0
|
||||
color("black")
|
||||
}
|
||||
```
|
||||
Predictably, only `x-axis` rib bigger than other ribs.
|
||||
|
||||
data:image/s3,"s3://crabby-images/f427a/f427a70eed09d70180de1d3dd6cd7bfa6b1cfc07" alt=""
|
||||
|
||||
### 3) Sphere
|
||||
|
||||
It takes in two values: `radius`, and `name`.
|
||||
Actually, `name` is general value for all solids, so do not wonder, since all solids need their own identifier.
|
||||
|
||||
As for `radius`, it has `Float` type, and, as you can guess, it sets radius of the sphere, which will be created.
|
||||
```kotlin
|
||||
sphere(50, name = "sphere") {
|
||||
x = 0
|
||||
y = 0
|
||||
z = 0
|
||||
opacity = 0.9
|
||||
color("blue")
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/73dc3/73dc36d105acaad8a762a13d691887457b0f0ba1" alt=""
|
||||
|
||||
### 4) Hexagon
|
||||
|
||||
It is solid which has six edges. It is set by eight values: `node1`,..., `node8`. They all have `Point3D` type, so they are just points, vertices.
|
||||
|
||||
*Six edges are these:*
|
||||
1) Edge with vertices `node1`, `node4`, `node3`, `node2`
|
||||
2) Edge with vertices `node1`, `node2`, `node6`, `node5`
|
||||
3) Edge with vertices `node2`, `node3`, `node7`, `node6`
|
||||
4) Edge with vertices `node4`, `node8`, `node7`, `node3`
|
||||
5) Edge with vertices `node1`, `node5`, `node8`, `node4`
|
||||
6) Edge with vertices `node8`, `node5`, `node6`, `node7`
|
||||
|
||||
data:image/s3,"s3://crabby-images/a7cf1/a7cf17b60c2ce990f7a0a808428263534d706389" alt=""
|
||||
|
||||
As hexagon takes in specific points, we understand that this solid cannot be moved, it fixed in space, and it can't make pivots.
|
||||
|
||||
Let's make classic parallelepiped.
|
||||
```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=""
|
||||
|
||||
Now, let's make a custom hexagon.
|
||||
|
||||
```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=""
|
||||
### 3) Cone
|
||||
It takes in six values: `bottomRadius`, `height`, `upperRadius`, `startAngle`, `angle`, and `name`.
|
||||
|
||||
Obviously, `bottomRadius` is responsible for radius of a bottom base, and `height` sets height of a cone along the `z-axis`.
|
||||
|
||||
As it takes such values as `upperRadius`, `startAngle`, `angle`, `cone` can build not only usual cones, but also cone segments. Initially, `upperRadius` will have `0.0` value, `startAngle` - `0f`, `angle` - `PI2`, so if you don't set them, you'll get just a simple cone.
|
||||
|
||||
Setting `upperRadius`, you make a frustum cone, since it sets a radius of the upper base of a cone. Set `startAngle`, and `angle` let to cut off segments by planes perpendicular to the base. `startAngle` - an angle, starting with which segment will be left, `angle` - an angle of cone, which will be set from `startAngle`.
|
||||
|
||||
Let's build a classic cone:
|
||||
```kotlin
|
||||
cone(60, 80, name = "cone") {
|
||||
color("beige")
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/512b3/512b3843d2ae40f1a98f75b64937a480718827a8" alt=""
|
||||
data:image/s3,"s3://crabby-images/1158f/1158f917b506b39c947b7dbc229e79c6f535a72a" alt=""
|
||||
|
||||
First of all, we have to try to build a frustum cone:
|
||||
```kotlin
|
||||
cone(60, 80, name = "cone") {
|
||||
color(0u, 40u, 0u)
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/5f222/5f2223d739ae9c8649e8c18ea9673d577efff99e" alt=""
|
||||
|
||||
Now, we need to make a try to build a cone segment:
|
||||
|
||||
```kotlin
|
||||
cone(60, 80, angle = PI, name = "cone") {
|
||||
color(0u, 0u, 200u)
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/46dd6/46dd6567859ab53b15caee819b8497090f49bb06" alt=""
|
||||
data:image/s3,"s3://crabby-images/28244/28244a0e0aa503c4778e6373f3467183d5d3334b" alt=""
|
||||
|
||||
Finally, the segment of frustum cone is left for a try:
|
||||
```kotlin
|
||||
cone(60, 100, 20, PI*3/4, angle = PI/3, name = "cone") {
|
||||
color(190u, 0u, 0u)
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/945e3/945e31da0d58072cc11efb73e65b85b0936f1493" alt=""
|
||||
|
||||
### 4) Cone Surface
|
||||
This solid is set by seven values:`bottomOuterRadius`, `bottomInnerRadius`, `height`, `topOuterRadius`, `topInnerRadius`, `startAngle`, and `angle`.
|
||||
|
||||
In addition to `height`, `startAngle`, and `angle`, which work as they work in `cone`, there are some new values.
|
||||
`bottomOuterRadius`, and `bottomInnerRadius` set properties of the bottom circle, `topOuterRadius`, `topInnerRadius` - of the upper circle. They have no initial value, so that means they have to be set.
|
||||
|
||||
Generally, `cone`, and `coneSurface` buildings work in the same way, it's possible to make `coneSurface`'s fragments as in `cone`
|
||||
|
||||
Let's build usual cone surface with almost all properties set:
|
||||
```kotlin
|
||||
coneSurface(60, 50, 30, 10, 100, name = "cone surface") {
|
||||
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=""
|
||||
|
||||
Now, let's create a cone surface and set all it's properties:
|
||||
|
||||
```kotlin
|
||||
coneSurface(30, 25, 10, 10, 8,0f, pi*3/4, name = "cone surface") {
|
||||
color("fuchsia")
|
||||
rotation = Point3D(2, 50, -9)
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/81656/816560bf15e95a2824456614086650a390d0a7c5" alt=""
|
||||
data:image/s3,"s3://crabby-images/c1787/c1787a87000eb890a5c4c636fbf8048604dca58c" alt=""
|
||||
|
||||
### 5) Cylinder
|
||||
|
||||
This solid is set by `radius`, and `height`. As you can see by accepting values, there's no option of building fragments of cylinders.
|
||||
|
||||
Here's a demonstration of a cylinder:
|
||||
|
||||
```kotlin
|
||||
cylinder(40, 100, "cylinder"){
|
||||
rotation = Point3D(40, 0, 0)
|
||||
color("indigo")
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/4559e/4559e1d684fff36729c38ccd475aa2238f893cc6" alt=""
|
||||
data:image/s3,"s3://crabby-images/dce7b/dce7b250d6509c9d52cb0b21258c5ebc7d000f64" alt=""
|
||||
### 6) Tube
|
||||
|
||||
`tube` takes in `radius`, `height`, `innerRadius`, `startAngle`, `angle`, and `name`. *All values are familiar from `cone`, and `coneSurface` solids.*
|
||||
|
||||
Here is an example of classic tube:
|
||||
```kotlin
|
||||
tube(50, 40, 20, name = "usual tube"){
|
||||
opacity = 0.4
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/a1b3a/a1b3ab87f988aa2606b00a8a32d65d097f11cd74" alt=""
|
||||
|
||||
This is an example of tube fragment:
|
||||
|
||||
```kotlin
|
||||
tube(50, 40, 20, 0f, PI, name = "fragmented tube"){
|
||||
color("white")
|
||||
}
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/32fbf/32fbfe0fa96e40cd71ec32462e807103d1828c65" alt=""
|
||||
### 7) Extruded
|
||||
|
Loading…
x
Reference in New Issue
Block a user