diff --git a/0.2.x/404.html b/0.2.x/404.html index 9d9db9f..308ab24 100755 --- a/0.2.x/404.html +++ b/0.2.x/404.html @@ -510,7 +510,7 @@

404 - Not found

- + diff --git a/0.2.x/assets/cover.png b/0.2.x/assets/cover.png new file mode 100755 index 0000000..3d99b2e Binary files /dev/null and b/0.2.x/assets/cover.png differ diff --git a/0.2.x/features/index.html b/0.2.x/features/index.html index 1049a5b..4f56ad2 100755 --- a/0.2.x/features/index.html +++ b/0.2.x/features/index.html @@ -719,7 +719,7 @@

Features & Options

Bioxel Design Concept

-

According to Bioxel design concept, Bioxel Nodes imports volume data and put it into a Container as a Layer. One container may has more than one layer, and each layer stores the information of different fields under the same location, which is similar to the view layer of map app, except that here it is in 3D space. In order to render the volume the way we want it to, we need to build a renderable object from layers. We call this object Component. The following diagram shows the relationship of Container, Layer, and Component:

+

According to Bioxel design concept, Bioxel Nodes imports volume data and put it into a Container as a Layer. One container may has more than one layer, and each layer stores the information of different fields under the same location, which is similar to the view layers in map app, except that here it is in 3D space. In order to render the volume the way we want it to, we need to build renderable objects from layers. We call those objects Component. The following diagram shows the relationship of Container, Layer, and Component:

alt text

Bioxel Nodes staging the layer as an openvdb file. The process of building from layers to a component is taking place in blender geometry nodes graph with blender native geometry nodes. Therefore, the blender file works without Bioxel Nodes.

Container Structure

@@ -864,7 +864,7 @@

Export Biovel Layer as VDB

- + diff --git a/0.2.x/getting-started/index.html b/0.2.x/getting-started/index.html index 8d10c45..81c80eb 100755 --- a/0.2.x/getting-started/index.html +++ b/0.2.x/getting-started/index.html @@ -427,6 +427,30 @@ + +
  • @@ -568,6 +592,30 @@ + +
  • @@ -618,8 +666,16 @@

    Getting Started

    Currently only support Blender 4.0 or above, make sure you have the correct version of Blender.

    Add-on Installation

    -

    Download the latest version https://github.com/OmooLab/BioxelNodes/releases/latest
    -In Blender, Edit > Preferences > Add-ons > Install, select the BioxelNodes_{version}.zip you just downloaded.

    +

    For Blender 4.2 or higher

    +

    Download the Extension version BioxelNodes_Extension_{version}.zip from https://github.com/OmooLab/BioxelNodes/releases/latest
    +In Blender, Edit > Preferences > Extensions > Install from Disk, select the zip file you just downloaded.

    +

    Thats it!

    +
    +

    If it cannot be enable, just reboot blender.

    +
    +

    For Blender 4.0 or 4.1

    +

    Download the Addon version BioxelNodes_Addon_{version}.zip from https://github.com/OmooLab/BioxelNodes/releases/latest
    +In Blender, Edit > Preferences > Add-ons > Install, select the zip file you just downloaded.

    The add-on requires a third-party python dependency called SimpleITK, click Install SimpleITK button below to install the dependency. After clicking, blender may get stuck, it is downloading and installing, just wait for a moment. After that, click Reboot Blender button.

    dependency

    This step may have failed due to network factors, just click "Set PyPI Mirror" to change the mirror.

    @@ -778,7 +834,7 @@

    Share Your File

    - + diff --git a/0.2.x/index.html b/0.2.x/index.html index 43c15eb..073c54f 100755 --- a/0.2.x/index.html +++ b/0.2.x/index.html @@ -546,7 +546,7 @@

    Bioxel Nodes

    About

    Before us, there have been many tutorials and add-ons for importing volumetric data into Blender. However, we found that there were many details that were not addressed in place, some scientific facts were ignored, and the volume rendering was not pretty enough. With Bioxel Nodes, you can easily import the volumetric data into Blender, and more importantly, it can quickly make a beautiful realistic rendering of it.

    Below are some examples with Bioxel Nodes. Thanks to Cycles Render, the volumetric data can be rendered with great detail:

    -

    gallery

    +

    cover

    The "Bioxel" in "Bioxel Nodes", is a combination of the words "Bio-" and "Voxel". Bioxel is a voxel that stores biological data. We are developing a toolkit around Bioxel for better biological data visualization. but before its release, we made this Blender version of bioxels toolkit first, in order to let more people to have fun with volumetric data. Getting Started

    Supported Format

    @@ -723,7 +723,7 @@

    To Upgrade Add-on

    - + diff --git a/0.2.x/misc/index.html b/0.2.x/misc/index.html index bbf90db..54a1455 100755 --- a/0.2.x/misc/index.html +++ b/0.2.x/misc/index.html @@ -683,7 +683,7 @@

    Based on Geometry Nodes

    - + diff --git a/0.2.x/nodes/index.html b/0.2.x/nodes/index.html index 7e9679d..6b82c7a 100755 --- a/0.2.x/nodes/index.html +++ b/0.2.x/nodes/index.html @@ -604,39 +604,6 @@ - - -
  • - - - Utils - - - - -
  • @@ -697,6 +664,30 @@ +
  • + +
  • + + + Utils + + + + +
  • @@ -904,39 +895,6 @@ - - -
  • - - - Utils - - - - -
  • @@ -997,6 +955,30 @@ +
  • + +
  • + + + Utils + + + + +
  • @@ -1298,40 +1280,6 @@

    🧀 Plane Object Cutter

    -

    Utils

    -

    📦 Join Component

    -
    - -
    -

    🗂️ Separate Component

    -
    - -

    Colors

    This type of node is responsible for setting the color properties of the shader

    🎨 Color Presents

    @@ -1459,6 +1407,23 @@

    5️⃣ Color Ramp 5

    +

    Utils

    +

    📦 Join Component

    +
    + +
    @@ -1549,7 +1514,7 @@

    5️⃣ Color Ramp 5

    - + diff --git a/0.2.x/search/search_index.json b/0.2.x/search/search_index.json index 0a3f1e7..6ebb6cf 100755 --- a/0.2.x/search/search_index.json +++ b/0.2.x/search/search_index.json @@ -1 +1 @@ -{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Bioxel Nodes","text":"

    Bioxel Nodes is a Blender add-on for scientific volumetric data visualization. It using Blender's powerful Geometry Nodes | Cycles to process and render volumetric data.

    "},{"location":"#about","title":"About","text":"

    Before us, there have been many tutorials and add-ons for importing volumetric data into Blender. However, we found that there were many details that were not addressed in place, some scientific facts were ignored, and the volume rendering was not pretty enough. With Bioxel Nodes, you can easily import the volumetric data into Blender, and more importantly, it can quickly make a beautiful realistic rendering of it.

    Below are some examples with Bioxel Nodes. Thanks to Cycles Render, the volumetric data can be rendered with great detail:

    The \"Bioxel\" in \"Bioxel Nodes\", is a combination of the words \"Bio-\" and \"Voxel\". Bioxel is a voxel that stores biological data. We are developing a toolkit around Bioxel for better biological data visualization. but before its release, we made this Blender version of bioxels toolkit first, in order to let more people to have fun with volumetric data. Getting Started

    "},{"location":"#supported-format","title":"Supported Format","text":"Format EXT Test DICOM .dcm, .DICOM \u2705 pass BMP .bmp, .BMP \u2705 pass JPEG .jpg, .JPG, .jpeg, .JPEG \u2705 pass PNG .png, .PNG \u2705 pass TIFF .tif, .TIF, .tiff, .TIFF \u2705 pass Nifti .nia, .nii, .nii.gz, .hdr, .img, .img.gz \u2705 pass Nrrd .nrrd, .nhdr \u2705 pass Meta .mha, .mhd yet HDF5 .hdf, .h4, .hdf4, .he2, .h5, .hdf5, .he5 \u2705 pass VTK .vtk yet BioRad .PIC, .pic yet Gipl .gipl, .gipl.gz yet LSM .lsm, .LSM yet MINC .mnc, .MNC yet MRC .mrc, .rec yet"},{"location":"#known-limitations","title":"Known Limitations","text":""},{"location":"#to-upgrade-add-on","title":"To Upgrade Add-on","text":"

    To upgrade from an older version of the add-on to the latest, you need to do the following:

    1. Remove the old version of Bioxel Nodes at Preferences > Add-ons
    2. Add the new version and restart Blender.

    It is not support editing the same blender file across add-on versions. In order to make sure that the previous file works properly. You need to save the staged data before upgrading ( read the last section of Getting Started ).

    But even then, there is still no guarantee that the new version of the add-on will work on the old blender file. Therefore, it is highly recommended to open a new blender file to start the creating, not based on the old one.

    Alternatively, objects from the old file that have nothing to do with Bioxel Nodes could be append to the new blender file.

    "},{"location":"features/","title":"Features & Options","text":""},{"location":"features/#bioxel-design-concept","title":"Bioxel Design Concept","text":"

    According to Bioxel design concept, Bioxel Nodes imports volume data and put it into a Container as a Layer. One container may has more than one layer, and each layer stores the information of different fields under the same location, which is similar to the view layer of map app, except that here it is in 3D space. In order to render the volume the way we want it to, we need to build a renderable object from layers. We call this object Component. The following diagram shows the relationship of Container, Layer, and Component:

    Bioxel Nodes staging the layer as an openvdb file. The process of building from layers to a component is taking place in blender geometry nodes graph with blender native geometry nodes. Therefore, the blender file works without Bioxel Nodes.

    "},{"location":"features/#container-structure","title":"Container Structure","text":"

    In Blender, container structure is like this:

    Case_0000 # Container\n|-- Case_0000_CT # Layer\n|-- Case_0000_Label_1 # Layer\n`-- Case_0000_Label_2 # Layer\n

    The container also stores the build process in geometry nodes:

    The layer is categorized into these by data type:

    "},{"location":"features/#first-time-import-volume-data","title":"First Time Import Volume Data","text":"

    File > Import > Volume Data as Bioxel Layer

    "},{"location":"features/#resample","title":"Resample","text":"

    Sometimes the original data is too big, or the spacing in the original data is not reasonable, you can modify the Bioxel Size and Original Spacing to adjust the Shape of the layer.

    A bioxel is like a pixel, the larger the Bioxel Size, the lower the resolution of the image, Original Spacing will be read from the original data record, but sometimes the image doesn't have original spacing, you may need to input it manually to get the correct shape.

    "},{"location":"features/#read-as","title":"Read as","text":""},{"location":"features/#others","title":"Others","text":"

    Scene Scale determines how many units of length in the Blender world correspond to one unit of length in the Bioxel world. Since Blender defaults to meters, and the default size of blender primitives are around 1 blender unit. Therefore Scene Scale set to 0.01 is appropriate.

    Orient to RAS determines whether the layer should be converted to the RAS coordinate system. Regardless of the format of the medical image data, the coordinate system is mostly the LPS coordinate system. Bioxel, however, are in the RAS coordinate system and therefore need to be transformed in most cases.

    "},{"location":"features/#adding-volume-data-to-an-existing-container","title":"Adding Volume Data to an existing container","text":"

    In 3D view or outliner panel, select the container and right click, Bioxel Nodes > Add Volume Data to Container. The import settings are the same as for the first time import.

    "},{"location":"features/#convert-bioxel-components-to-mesh","title":"Convert Bioxel Components to Mesh","text":"

    In 3D view or outliner panel, select the container and right click, Bioxel Nodes > Bioxel Components To Mesh Once it has been turned into a mesh model, you can perform any traditional 3D editing operations on it, such as sculpting, boolean, etc.

    "},{"location":"features/#export-biovel-layer-as-vdb","title":"Export Biovel Layer as VDB","text":"

    File > Export > Biovel Layer as VDB

    "},{"location":"getting-started/","title":"Getting Started","text":"

    Currently only support Blender 4.0 or above, make sure you have the correct version of Blender.

    "},{"location":"getting-started/#add-on-installation","title":"Add-on Installation","text":"

    Download the latest version https://github.com/OmooLab/BioxelNodes/releases/latest In Blender, Edit > Preferences > Add-ons > Install, select the BioxelNodes_{version}.zip you just downloaded.

    The add-on requires a third-party python dependency called SimpleITK, click Install SimpleITK button below to install the dependency. After clicking, blender may get stuck, it is downloading and installing, just wait for a moment. After that, click Reboot Blender button.

    This step may have failed due to network factors, just click \"Set PyPI Mirror\" to change the mirror.

    "},{"location":"getting-started/#prepare-your-data","title":"Prepare Your Data","text":"

    First you need to have your volumetric data ready. If not, you can access open research data from list below.

    Note that just because they are open and available for download does not mean you can use them for anything! Be sure to look at the description of the available scopes from website.

    Source Object Dryad Open Research Data OpenOrganelle Cells Embodi3D Medical Images Github Medical Images NIHR Medical Images Medical Segmentation Decathlon Medical Images Allen Cell Explorer Cells Visible Human Project Medical Images"},{"location":"getting-started/#import-volume-data","title":"Import Volume Data","text":"

    File > Import > Volume Data as Bioxel Layer, select one of the .dcm files and click on \"Volume Data as Bioxel Layer\" (you can also drag one of the .dcm files directly into the 3D viewport to trigger the import)

    It may take a while to read data. After finishing reading, it will pop up a dialog box. Ignore all the options, just click OK (we will tell about these options later).

    After importing the data, the add-on will automatically add the necessary nodes to build the component. Click on the new created object in outliner, open the geometry nodes panel, set Threshold in \"Mask by Threshold\" node to 200, and then connect a Slime Shader node (Add > Bioxel Nodes > Slime Shader) after it. The node graph should be as following:

    and then turned on the cycles rendering to directly see the result.

    You can change the \"Threshold\" to modify the preview model, or change the \"Color\", \"Density\" to modify the shader effect. All the parameters are straightforward, you can understand them by changing the values.

    "},{"location":"getting-started/#share-your-file","title":"Share Your File","text":"

    The VDB cache and the Bioxel nodes are not reachable to other computers if you don't save them. If you want to give your blender file to someone else, you will need to perform the following steps first:

    1. Save your blender file
    2. Click Scene > Bioxels > Save All Bioxels in the properties panel.
    3. Click Scene > Custom Nodes > Save All Custom Nodes in the properties panel.

    After that, both the VDB cache and the Bioxel nodes are restored in relative locations. When you share this file with someone, pack the entire directory so that the resources will be not lost. The other person will be able to open it correctly, regardless of whether they have Bioxel Nodes installed or not.

    "},{"location":"misc/","title":"Future Features","text":""},{"location":"misc/#bioxels","title":"Bioxels","text":"

    Bioxels is based on the RAS coordinate system, Right Aanterior Superior, which was chosen over LPS because it is more compatible with most 3D CG software coordinate systems, and is in line with the 3D artist's understanding of space.

    All distances within Bioxels are in Units, and are specified in Meter pre unit. However, when Bioxels is imported into 3D CG software, its size in the software is not scaled by reading the Meter pre unit directly. The reason for this is that many 3D operations in software require that the primtives not be too large or too small.

    "},{"location":"misc/#based-on-openvdb","title":"Based on OpenVDB","text":"

    Bioxels is based entirely on OpenVDB for storage and rendering. The main reason for choosing OpenVDB is that as a volumetric data format, it is the fastest way to work with most CG renderers.

    "},{"location":"misc/#based-on-geometry-nodes","title":"Based on Geometry Nodes","text":"

    Bioxel Nodes relies on Blender Geometry Nodes to reconstruct and render volumetric data. Node-based operations ensure that the original data is not permanently altered during reconstruction and rendering operations. The fact that the processing is based on Geometry Nodes without any additional dependencies also ensures that Blender can open files without this plugin installed. Look for more support for OpenVDB in GeometryNodes so that Bioxel Nodes can do more in the future.

    "},{"location":"nodes/","title":"Nodes","text":""},{"location":"nodes/#nodes-design-concept","title":"Nodes Design Concept","text":"

    In order to build a component, the general process is to first use a \"Mask Method\" node to build the surface of the component based on its layers, and then connect to a \"Assign Shader\" node to add the material physical properties. Finally, if you need to cut the cross-section, then connect to a \"Cut\" node. The whole process is shown in the following diagram

    A typical example looks like this:

    The \"Mask Method\" node tends to be very computationally intensive, and if it consumes too much time, then you can bake it with a \"Bake\" node after it (but you need to save the Blender file first).

    "},{"location":"nodes/#mask-methods","title":"Mask Methods","text":"

    This type of node is responsible for culling out the extent of the component that does not need to be rendered, forming the interface between the object and the object, or the surface of the object (i.e., the interface between the object and the air)

    "},{"location":"nodes/#mask-by-threshold","title":"\u2b06\ufe0f Mask by Threshold","text":""},{"location":"nodes/#mask-by-range","title":"\u2195 Mask by Range","text":""},{"location":"nodes/#mask-by-label","title":"\ud83d\udd24 Mask by Label","text":""},{"location":"nodes/#shaders","title":"Shaders","text":"

    This type of node is responsible for setting material physical properties to the component to reflect the differences in rendering effects of different components.

    "},{"location":"nodes/#solid-shader","title":"\ud83e\udd5a Solid Shader","text":""},{"location":"nodes/#slime-shader","title":"\ud83e\udda0 Slime Shader","text":""},{"location":"nodes/#volume-shader","title":"\u2601\ufe0f Volume Shader","text":""},{"location":"nodes/#universal-shader","title":"\ud83d\udd2c Universal Shader","text":""},{"location":"nodes/#cutters","title":"Cutters","text":"

    This type of node is responsible for cutting components to present cross-section

    "},{"location":"nodes/#cut","title":"\ud83e\ude9a Cut","text":""},{"location":"nodes/#plane-cutter","title":"\ud83e\uddc0 Plane Cutter","text":""},{"location":"nodes/#plane-object-cutter","title":"\ud83e\uddc0 Plane Object Cutter","text":""},{"location":"nodes/#utils","title":"Utils","text":""},{"location":"nodes/#join-component","title":"\ud83d\udce6 Join Component","text":""},{"location":"nodes/#separate-component","title":"\ud83d\uddc2\ufe0f Separate Component","text":""},{"location":"nodes/#colors","title":"Colors","text":"

    This type of node is responsible for setting the color properties of the shader

    "},{"location":"nodes/#color-presents","title":"\ud83c\udfa8 Color Presents","text":""},{"location":"nodes/#2-color-ramp-2","title":"2\ufe0f\u20e3 Color Ramp 2","text":""},{"location":"nodes/#3-color-ramp-3","title":"3\ufe0f\u20e3 Color Ramp 3","text":""},{"location":"nodes/#4-color-ramp-4","title":"4\ufe0f\u20e3 Color Ramp 4","text":""},{"location":"nodes/#5-color-ramp-5","title":"5\ufe0f\u20e3 Color Ramp 5","text":""}]} \ No newline at end of file +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Bioxel Nodes","text":"

    Bioxel Nodes is a Blender add-on for scientific volumetric data visualization. It using Blender's powerful Geometry Nodes | Cycles to process and render volumetric data.

    "},{"location":"#about","title":"About","text":"

    Before us, there have been many tutorials and add-ons for importing volumetric data into Blender. However, we found that there were many details that were not addressed in place, some scientific facts were ignored, and the volume rendering was not pretty enough. With Bioxel Nodes, you can easily import the volumetric data into Blender, and more importantly, it can quickly make a beautiful realistic rendering of it.

    Below are some examples with Bioxel Nodes. Thanks to Cycles Render, the volumetric data can be rendered with great detail:

    The \"Bioxel\" in \"Bioxel Nodes\", is a combination of the words \"Bio-\" and \"Voxel\". Bioxel is a voxel that stores biological data. We are developing a toolkit around Bioxel for better biological data visualization. but before its release, we made this Blender version of bioxels toolkit first, in order to let more people to have fun with volumetric data. Getting Started

    "},{"location":"#supported-format","title":"Supported Format","text":"Format EXT Test DICOM .dcm, .DICOM \u2705 pass BMP .bmp, .BMP \u2705 pass JPEG .jpg, .JPG, .jpeg, .JPEG \u2705 pass PNG .png, .PNG \u2705 pass TIFF .tif, .TIF, .tiff, .TIFF \u2705 pass Nifti .nia, .nii, .nii.gz, .hdr, .img, .img.gz \u2705 pass Nrrd .nrrd, .nhdr \u2705 pass Meta .mha, .mhd yet HDF5 .hdf, .h4, .hdf4, .he2, .h5, .hdf5, .he5 \u2705 pass VTK .vtk yet BioRad .PIC, .pic yet Gipl .gipl, .gipl.gz yet LSM .lsm, .LSM yet MINC .mnc, .MNC yet MRC .mrc, .rec yet"},{"location":"#known-limitations","title":"Known Limitations","text":""},{"location":"#to-upgrade-add-on","title":"To Upgrade Add-on","text":"

    To upgrade from an older version of the add-on to the latest, you need to do the following:

    1. Remove the old version of Bioxel Nodes at Preferences > Add-ons
    2. Add the new version and restart Blender.

    It is not support editing the same blender file across add-on versions. In order to make sure that the previous file works properly. You need to save the staged data before upgrading ( read the last section of Getting Started ).

    But even then, there is still no guarantee that the new version of the add-on will work on the old blender file. Therefore, it is highly recommended to open a new blender file to start the creating, not based on the old one.

    Alternatively, objects from the old file that have nothing to do with Bioxel Nodes could be append to the new blender file.

    "},{"location":"features/","title":"Features & Options","text":""},{"location":"features/#bioxel-design-concept","title":"Bioxel Design Concept","text":"

    According to Bioxel design concept, Bioxel Nodes imports volume data and put it into a Container as a Layer. One container may has more than one layer, and each layer stores the information of different fields under the same location, which is similar to the view layers in map app, except that here it is in 3D space. In order to render the volume the way we want it to, we need to build renderable objects from layers. We call those objects Component. The following diagram shows the relationship of Container, Layer, and Component:

    Bioxel Nodes staging the layer as an openvdb file. The process of building from layers to a component is taking place in blender geometry nodes graph with blender native geometry nodes. Therefore, the blender file works without Bioxel Nodes.

    "},{"location":"features/#container-structure","title":"Container Structure","text":"

    In Blender, container structure is like this:

    Case_0000 # Container\n|-- Case_0000_CT # Layer\n|-- Case_0000_Label_1 # Layer\n`-- Case_0000_Label_2 # Layer\n

    The container also stores the build process in geometry nodes:

    The layer is categorized into these by data type:

    "},{"location":"features/#first-time-import-volume-data","title":"First Time Import Volume Data","text":"

    File > Import > Volume Data as Bioxel Layer

    "},{"location":"features/#resample","title":"Resample","text":"

    Sometimes the original data is too big, or the spacing in the original data is not reasonable, you can modify the Bioxel Size and Original Spacing to adjust the Shape of the layer.

    A bioxel is like a pixel, the larger the Bioxel Size, the lower the resolution of the image, Original Spacing will be read from the original data record, but sometimes the image doesn't have original spacing, you may need to input it manually to get the correct shape.

    "},{"location":"features/#read-as","title":"Read as","text":""},{"location":"features/#others","title":"Others","text":"

    Scene Scale determines how many units of length in the Blender world correspond to one unit of length in the Bioxel world. Since Blender defaults to meters, and the default size of blender primitives are around 1 blender unit. Therefore Scene Scale set to 0.01 is appropriate.

    Orient to RAS determines whether the layer should be converted to the RAS coordinate system. Regardless of the format of the medical image data, the coordinate system is mostly the LPS coordinate system. Bioxel, however, are in the RAS coordinate system and therefore need to be transformed in most cases.

    "},{"location":"features/#adding-volume-data-to-an-existing-container","title":"Adding Volume Data to an existing container","text":"

    In 3D view or outliner panel, select the container and right click, Bioxel Nodes > Add Volume Data to Container. The import settings are the same as for the first time import.

    "},{"location":"features/#convert-bioxel-components-to-mesh","title":"Convert Bioxel Components to Mesh","text":"

    In 3D view or outliner panel, select the container and right click, Bioxel Nodes > Bioxel Components To Mesh Once it has been turned into a mesh model, you can perform any traditional 3D editing operations on it, such as sculpting, boolean, etc.

    "},{"location":"features/#export-biovel-layer-as-vdb","title":"Export Biovel Layer as VDB","text":"

    File > Export > Biovel Layer as VDB

    "},{"location":"getting-started/","title":"Getting Started","text":"

    Currently only support Blender 4.0 or above, make sure you have the correct version of Blender.

    "},{"location":"getting-started/#add-on-installation","title":"Add-on Installation","text":""},{"location":"getting-started/#for-blender-42-or-higher","title":"For Blender 4.2 or higher","text":"

    Download the Extension version BioxelNodes_Extension_{version}.zip from https://github.com/OmooLab/BioxelNodes/releases/latest In Blender, Edit > Preferences > Extensions > Install from Disk, select the zip file you just downloaded.

    Thats it!

    If it cannot be enable, just reboot blender.

    "},{"location":"getting-started/#for-blender-40-or-41","title":"For Blender 4.0 or 4.1","text":"

    Download the Addon version BioxelNodes_Addon_{version}.zip from https://github.com/OmooLab/BioxelNodes/releases/latest In Blender, Edit > Preferences > Add-ons > Install, select the zip file you just downloaded.

    The add-on requires a third-party python dependency called SimpleITK, click Install SimpleITK button below to install the dependency. After clicking, blender may get stuck, it is downloading and installing, just wait for a moment. After that, click Reboot Blender button.

    This step may have failed due to network factors, just click \"Set PyPI Mirror\" to change the mirror.

    "},{"location":"getting-started/#prepare-your-data","title":"Prepare Your Data","text":"

    First you need to have your volumetric data ready. If not, you can access open research data from list below.

    Note that just because they are open and available for download does not mean you can use them for anything! Be sure to look at the description of the available scopes from website.

    Source Object Dryad Open Research Data OpenOrganelle Cells Embodi3D Medical Images Github Medical Images NIHR Medical Images Medical Segmentation Decathlon Medical Images Allen Cell Explorer Cells Visible Human Project Medical Images"},{"location":"getting-started/#import-volume-data","title":"Import Volume Data","text":"

    File > Import > Volume Data as Bioxel Layer, select one of the .dcm files and click on \"Volume Data as Bioxel Layer\" (you can also drag one of the .dcm files directly into the 3D viewport to trigger the import)

    It may take a while to read data. After finishing reading, it will pop up a dialog box. Ignore all the options, just click OK (we will tell about these options later).

    After importing the data, the add-on will automatically add the necessary nodes to build the component. Click on the new created object in outliner, open the geometry nodes panel, set Threshold in \"Mask by Threshold\" node to 200, and then connect a Slime Shader node (Add > Bioxel Nodes > Slime Shader) after it. The node graph should be as following:

    and then turned on the cycles rendering to directly see the result.

    You can change the \"Threshold\" to modify the preview model, or change the \"Color\", \"Density\" to modify the shader effect. All the parameters are straightforward, you can understand them by changing the values.

    "},{"location":"getting-started/#share-your-file","title":"Share Your File","text":"

    The VDB cache and the Bioxel nodes are not reachable to other computers if you don't save them. If you want to give your blender file to someone else, you will need to perform the following steps first:

    1. Save your blender file
    2. Click Scene > Bioxels > Save All Bioxels in the properties panel.
    3. Click Scene > Custom Nodes > Save All Custom Nodes in the properties panel.

    After that, both the VDB cache and the Bioxel nodes are restored in relative locations. When you share this file with someone, pack the entire directory so that the resources will be not lost. The other person will be able to open it correctly, regardless of whether they have Bioxel Nodes installed or not.

    "},{"location":"misc/","title":"Future Features","text":""},{"location":"misc/#bioxels","title":"Bioxels","text":"

    Bioxels is based on the RAS coordinate system, Right Aanterior Superior, which was chosen over LPS because it is more compatible with most 3D CG software coordinate systems, and is in line with the 3D artist's understanding of space.

    All distances within Bioxels are in Units, and are specified in Meter pre unit. However, when Bioxels is imported into 3D CG software, its size in the software is not scaled by reading the Meter pre unit directly. The reason for this is that many 3D operations in software require that the primtives not be too large or too small.

    "},{"location":"misc/#based-on-openvdb","title":"Based on OpenVDB","text":"

    Bioxels is based entirely on OpenVDB for storage and rendering. The main reason for choosing OpenVDB is that as a volumetric data format, it is the fastest way to work with most CG renderers.

    "},{"location":"misc/#based-on-geometry-nodes","title":"Based on Geometry Nodes","text":"

    Bioxel Nodes relies on Blender Geometry Nodes to reconstruct and render volumetric data. Node-based operations ensure that the original data is not permanently altered during reconstruction and rendering operations. The fact that the processing is based on Geometry Nodes without any additional dependencies also ensures that Blender can open files without this plugin installed. Look for more support for OpenVDB in GeometryNodes so that Bioxel Nodes can do more in the future.

    "},{"location":"nodes/","title":"Nodes","text":""},{"location":"nodes/#nodes-design-concept","title":"Nodes Design Concept","text":"

    In order to build a component, the general process is to first use a \"Mask Method\" node to build the surface of the component based on its layers, and then connect to a \"Assign Shader\" node to add the material physical properties. Finally, if you need to cut the cross-section, then connect to a \"Cut\" node. The whole process is shown in the following diagram

    A typical example looks like this:

    The \"Mask Method\" node tends to be very computationally intensive, and if it consumes too much time, then you can bake it with a \"Bake\" node after it (but you need to save the Blender file first).

    "},{"location":"nodes/#mask-methods","title":"Mask Methods","text":"

    This type of node is responsible for culling out the extent of the component that does not need to be rendered, forming the interface between the object and the object, or the surface of the object (i.e., the interface between the object and the air)

    "},{"location":"nodes/#mask-by-threshold","title":"\u2b06\ufe0f Mask by Threshold","text":""},{"location":"nodes/#mask-by-range","title":"\u2195 Mask by Range","text":""},{"location":"nodes/#mask-by-label","title":"\ud83d\udd24 Mask by Label","text":""},{"location":"nodes/#shaders","title":"Shaders","text":"

    This type of node is responsible for setting material physical properties to the component to reflect the differences in rendering effects of different components.

    "},{"location":"nodes/#solid-shader","title":"\ud83e\udd5a Solid Shader","text":""},{"location":"nodes/#slime-shader","title":"\ud83e\udda0 Slime Shader","text":""},{"location":"nodes/#volume-shader","title":"\u2601\ufe0f Volume Shader","text":""},{"location":"nodes/#universal-shader","title":"\ud83d\udd2c Universal Shader","text":""},{"location":"nodes/#cutters","title":"Cutters","text":"

    This type of node is responsible for cutting components to present cross-section

    "},{"location":"nodes/#cut","title":"\ud83e\ude9a Cut","text":""},{"location":"nodes/#plane-cutter","title":"\ud83e\uddc0 Plane Cutter","text":""},{"location":"nodes/#plane-object-cutter","title":"\ud83e\uddc0 Plane Object Cutter","text":""},{"location":"nodes/#colors","title":"Colors","text":"

    This type of node is responsible for setting the color properties of the shader

    "},{"location":"nodes/#color-presents","title":"\ud83c\udfa8 Color Presents","text":""},{"location":"nodes/#2-color-ramp-2","title":"2\ufe0f\u20e3 Color Ramp 2","text":""},{"location":"nodes/#3-color-ramp-3","title":"3\ufe0f\u20e3 Color Ramp 3","text":""},{"location":"nodes/#4-color-ramp-4","title":"4\ufe0f\u20e3 Color Ramp 4","text":""},{"location":"nodes/#5-color-ramp-5","title":"5\ufe0f\u20e3 Color Ramp 5","text":""},{"location":"nodes/#utils","title":"Utils","text":""},{"location":"nodes/#join-component","title":"\ud83d\udce6 Join Component","text":""}]} \ No newline at end of file diff --git a/0.2.x/sitemap.xml b/0.2.x/sitemap.xml index a4f880f..99d9bcf 100755 --- a/0.2.x/sitemap.xml +++ b/0.2.x/sitemap.xml @@ -2,27 +2,27 @@ https://omoolab.github.io/BioxelNodes/0.2.x/ - 2024-05-29 + 2024-06-05 daily https://omoolab.github.io/BioxelNodes/0.2.x/features/ - 2024-05-29 + 2024-06-05 daily https://omoolab.github.io/BioxelNodes/0.2.x/getting-started/ - 2024-05-29 + 2024-06-05 daily https://omoolab.github.io/BioxelNodes/0.2.x/misc/ - 2024-05-29 + 2024-06-05 daily https://omoolab.github.io/BioxelNodes/0.2.x/nodes/ - 2024-05-29 + 2024-06-05 daily \ No newline at end of file diff --git a/0.2.x/sitemap.xml.gz b/0.2.x/sitemap.xml.gz index 50f4e4f..af27a1d 100755 Binary files a/0.2.x/sitemap.xml.gz and b/0.2.x/sitemap.xml.gz differ