2021-08-04 22:09:15 +03:00
# Tutorial
2021-08-06 10:43:20 +03:00
#### The main goal of this tutorial is to show the main capabilities of the visualization instrument.
2021-08-04 22:09:15 +03:00
The simple visualization can be made with function `main` . (this part will be supplemented)
```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("nameFile.html"),
resourceLocation = ResourceLocation.EMBED
){
div {
//first vision
vision {
solid {
//solids which you want to visualize
}
}
//second vision
vision {
solid {
//solids which you want to visualize
}
}
}
}
}
```
## Solids properties
**We will analyze which basic properties solids have using `box` solid.**
*Basic properties:*
2021-08-06 10:56:44 +03:00
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.
2021-08-06 17:10:30 +03:00
2021-08-06 10:56:44 +03:00
3. `rotation` — it's the point, which sets rotations along axes. 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` .
2021-08-06 17:10:30 +03:00
2021-08-06 10:56:44 +03:00
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.
2021-08-04 22:09:15 +03:00
Let's see how properties are set in solids.
The `small box` will have elemental values of properties. If you don't 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/aba78/aba7801552ce16078a1afe4811697deda931d7f7" 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/607f9/607f995449a412ba6cbcd52e1e52400662e7f447" 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/690b8/690b811823aec9c51f739a447119134e196074fb" alt=""
data:image/s3,"s3://crabby-images/0c3d0/0c3d0bea98b40c426fafdfeae2d4d43b24b204ee" alt=""
2021-08-06 10:48:56 +03:00
***There is plenty of other properties, especially those, which you can create by yourself. Here we mention just a small part.***
2021-08-04 22:09:15 +03:00
## Basic Solids
Now, let's see which solids can be visualized:
### 1) PolyLine
2021-08-06 10:43:34 +03:00
It's scarcely a solid, but it can be visualized, so we mention it.
2021-08-04 22:09:15 +03:00
`polyline` build lines, obviously. Let's take a look at it's work.
2021-08-06 10:56:44 +03:00
`polyline` requires two values — `points` , and `name` :
2021-08-04 22:09:15 +03:00
* `points` is a `vararg` with `Point3D` type. It takes pairs of points, which you want to connect.
2021-08-06 10:49:11 +03:00
* `name` is an identifier of *any solid* ; but in this case, it is an identifier of `polyline` .
2021-08-04 22:09:15 +03:00
It's type is `String` . **This value can be required by any solid;
you can set it, you can not to set it, but without you won't be able to control solid, since it won't be inherited.**
This is an example of polyline with other solid `box` :
```kotlin
box(100, 100, 100, name = "box"){
x = -10
y = -10
z = -10
opacity = 0.4
}
polyline(Point3D(30, 20, 10), Point3D(30, -100, 30), Point3D(30, -100, 30), Point3D(50, -100, 30), name = "polyline"){
color("red")
}
```
data:image/s3,"s3://crabby-images/69825/69825460e63367bbcd7cd2f9cce28013d1fabf97" alt=""
data:image/s3,"s3://crabby-images/e0b7a/e0b7af4154ab60e8c05bddb2912367c192caadbb" alt=""
### 2) Box
First thing which has to be mentioned is that `box` takes four values: `box(x, y, z, name)`
2021-08-06 10:56:44 +03:00
* `x` — x-axis length of the `box`
* `y` — y-axis length of the `box`
* `z` — z-axis length of the `box`
2021-08-04 22:09:15 +03:00
These values have `Float` type.
*`x` , `y` , and `z` are necessary values, which cannot be ignored. You have to set them.*
2021-08-06 10:56:44 +03:00
* `name` — `box` 'es identifier. You've already met it.
2021-08-04 22:09:15 +03:00
Let's create just usual `box` with equal ribs.
```kotlin
box(50, 50, 50, name = "box") {
color("pink")
}
```
data:image/s3,"s3://crabby-images/831b5/831b52852d83edbd2d21eb16a401841202f2bd33" alt=""
Now, let's make `box` with bigger `y` value.
```kotlin
box(10, 25, 10, name = "high box") {
color("black")
}
```
2021-08-06 10:49:21 +03:00
As you can see, only the rib of `y-axis` differs from other ribs.
2021-08-04 22:09:15 +03:00
data:image/s3,"s3://crabby-images/54665/54665727db78ebe046996aaa46f45ae6acd1ff6d" alt=""
2021-08-06 10:49:37 +03:00
For a final trial, let's create a `box` with a bigger `x` value.
2021-08-04 22:09:15 +03:00
```kotlin
box(65, 40, 40, name = "wide box") {
x = 0
y = 0
z = 0
color("black")
}
```
2021-08-06 10:43:57 +03:00
Predictably, only the `x-axis` rib is bigger than other ribs.
2021-08-04 22:09:15 +03:00
data:image/s3,"s3://crabby-images/4c836/4c836976971acaac54a3b5443c219ac7cf0509ce" alt=""
### 3) Sphere
It takes in two values: `radius` , and `name` .
We bring you to mind that `name` is a general value for all solids, so do not wonder, since all solids need their own identifier.
2021-08-06 10:44:28 +03:00
As for `radius` , it has `Float` type, and, as you can guess, it sets the radius of the sphere which will be created.
2021-08-04 22:09:15 +03:00
```kotlin
sphere(50, name = "sphere") {
x = 0
y = 0
z = 0
opacity = 0.9
color("blue")
}
```
data:image/s3,"s3://crabby-images/375b2/375b2da6027cef0f84c0009cdc4da6eb839ac417" 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/44542/44542f7132e806f002ca653e78bb94172c3375f9" alt=""
2021-08-06 10:48:26 +03:00
As the hexagon takes in specific points, we understand that this solid cannot be moved, it is fixed in space, and it can't make pivots.
2021-08-04 22:09:15 +03:00
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/711b7/711b7cbd68aee8147fe9f4ba22c83d9e18c31ea0" alt=""
Now, let's make a custom hexagon.
```kotlin
2021-08-06 10:43:13 +03:00
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")
}
2021-08-04 22:09:15 +03:00
```
data:image/s3,"s3://crabby-images/391f1/391f19a8b30ec08f4333f32bbb2605bfabd2e777" alt=""
### 3) Cone
It takes in six values: `bottomRadius` , `height` , `upperRadius` , `startAngle` , `angle` , and `name` .
2021-08-06 10:44:38 +03:00
Obviously, `bottomRadius` is responsible for the radius of a bottom base, and `height` sets the height of a cone along the `z-axis` .
2021-08-04 22:09:15 +03:00
2021-08-06 10:56:44 +03:00
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.
2021-08-04 22:09:15 +03:00
2021-08-06 10:56:44 +03:00
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` .
2021-08-04 22:09:15 +03:00
Let's build a classic cone:
```kotlin
cone(60, 80, name = "cone") {
color("beige")
}
```
data:image/s3,"s3://crabby-images/66e8c/66e8ca6674fa89f77bc5ce5b2d3b46ff192c5d52" alt=""
data:image/s3,"s3://crabby-images/74952/74952fd6a58d8ace23a8069cb497f00b592b2987" 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/48ad2/48ad2426c382ddb9a37491d2bb85f8a09f7d1442" 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/e7b4c/e7b4c12aab20cd6dbf06a07faa1777f0db672328" alt=""
data:image/s3,"s3://crabby-images/56e09/56e094bdca8034708d108a1a805412e3ebb938a9" 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/f9f55/f9f55cf97babe21b56314583a796383ce52a9dbc" 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.
2021-08-06 10:56:44 +03:00
`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.
2021-08-04 22:09:15 +03:00
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/4bcec/4bcec090f76f6d6ea903cfb8324c66e5fddd9791" alt=""
data:image/s3,"s3://crabby-images/de7a2/de7a20b51cd599bd256fb205694d04710fe81c78" 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/8bf3e/8bf3ebfdc75c65b82a9721f9c3fd2863ce5252d1" alt=""
data:image/s3,"s3://crabby-images/d8588/d8588c3bad497e60e56784cd7a1b666ffb346910" 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/a9c11/a9c111e444be781f3c30ae095ad401f8ee267d22" alt=""
data:image/s3,"s3://crabby-images/0dd43/0dd43ceddf93249a8b3c060f667b4cafe103430f" 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/e62db/e62dba1a7c7c1d72b3241cd08b4e1d9fa1e4321b" 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/8fd8a/8fd8a5c8f936513fb26c232adf6d535258faab75" alt=""
### 7) Extruded
`extruded` is set by two values: `shape` , and `layer` .
2021-08-06 10:43:51 +03:00
* `shape` is a value of `List<Point2D>` type. It's just a list of all points of the solid. *`shape` has to consist of not less than two points!*
2021-08-06 10:44:44 +03:00
* `layer` is `MutableList` types variable. (here is a sentence with a description of the work of this function). *The amount of `layer`-s has to be more than one*