Blender V4.3
node_shader_volume_scatter.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2005 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
5#include "node_shader_util.hh"
6
7#include "BLI_string.h"
8
9#include "UI_interface.hh"
10#include "UI_resources.hh"
11
12#include "BKE_node_runtime.hh"
13
15
17{
18 b.add_input<decl::Color>("Color").default_value({0.8f, 0.8f, 0.8f, 1.0f});
19#define SOCK_COLOR_ID 0
20 b.add_input<decl::Float>("Density").default_value(1.0f).min(0.0f).max(1000.0f);
21#define SOCK_DENSITY_ID 1
22 b.add_input<decl::Float>("Anisotropy")
23 .default_value(0.0f)
24 .min(-1.0f)
25 .max(1.0f)
27 .description(
28 "Directionality of the scattering. Zero is isotropic, negative is backward, "
29 "positive is forward");
30 b.add_input<decl::Float>("IOR")
31 .default_value(1.33f)
32 .min(1.0f)
33 .max(2.0f)
35 .description("Index Of Refraction of the scattering particles");
36 b.add_input<decl::Float>("Backscatter")
37 .default_value(0.1f)
38 .min(0.0f)
39 .max(0.5f)
41 .description("Fraction of light that is scattered backwards");
42 b.add_input<decl::Float>("Alpha").default_value(0.5f).min(0.0f).max(500.0f);
43 b.add_input<decl::Float>("Diameter")
44 .default_value(20.0f)
45 .min(5.0f)
46 .max(50.0f)
47 .description("Diameter of the water droplets, in micrometers");
48 b.add_input<decl::Float>("Weight").available(false);
49 b.add_output<decl::Shader>("Volume").translation_context(BLT_I18NCONTEXT_ID_ID);
50}
51
53{
54 uiItemR(layout, ptr, "phase", UI_ITEM_R_SPLIT_EMPTY_NAME, "", ICON_NONE);
55}
56
57static void node_shader_init_scatter(bNodeTree * /*ntree*/, bNode *node)
58{
59 node->custom1 = SHD_PHASE_HENYEY_GREENSTEIN;
60}
61
62static void node_shader_update_scatter(bNodeTree *ntree, bNode *node)
63{
64 const int phase_function = node->custom1;
65
66 LISTBASE_FOREACH (bNodeSocket *, sock, &node->inputs) {
67 if (STR_ELEM(sock->name, "IOR", "Backscatter")) {
69 }
70 else if (STR_ELEM(sock->name, "Anisotropy")) {
72 ntree, sock, ELEM(phase_function, SHD_PHASE_HENYEY_GREENSTEIN, SHD_PHASE_DRAINE));
73 }
74 else if (STR_ELEM(sock->name, "Alpha")) {
75 bke::node_set_socket_availability(ntree, sock, phase_function == SHD_PHASE_DRAINE);
76 }
77 else if (STR_ELEM(sock->name, "Diameter")) {
78 bke::node_set_socket_availability(ntree, sock, phase_function == SHD_PHASE_MIE);
79 }
80 }
81}
82
84 bNode *node,
85 bNodeExecData * /*execdata*/,
86 GPUNodeStack *in,
87 GPUNodeStack *out)
88{
90 /* Consider there is absorption phenomenon when there is scattering since
91 * `extinction = scattering + absorption`. */
93 }
94 return GPU_stack_link(mat, node, "node_volume_scatter", in, out);
95}
96
97#undef SOCK_COLOR_ID
98#undef SOCK_DENSITY_ID
99
100} // namespace blender::nodes::node_shader_volume_scatter_cc
101
102/* node type definition */
104{
106
107 static blender::bke::bNodeType ntype;
108
109 sh_node_type_base(&ntype, SH_NODE_VOLUME_SCATTER, "Volume Scatter", NODE_CLASS_SHADER);
110 ntype.declare = file_ns::node_declare;
112 ntype.draw_buttons = file_ns::node_shader_buts_scatter;
114 ntype.initfunc = file_ns::node_shader_init_scatter;
115 ntype.gpu_fn = file_ns::node_shader_gpu_volume_scatter;
116 ntype.updatefunc = file_ns::node_shader_update_scatter;
117
119}
#define NODE_CLASS_SHADER
Definition BKE_node.hh:417
#define LISTBASE_FOREACH(type, var, list)
#define STR_ELEM(...)
Definition BLI_string.h:653
#define ELEM(...)
#define BLT_I18NCONTEXT_ID_ID
@ SHD_PHASE_DRAINE
@ SHD_PHASE_HENYEY_GREENSTEIN
@ SHD_PHASE_MIE
@ SHD_PHASE_FOURNIER_FORAND
bool GPU_stack_link(GPUMaterial *mat, const bNode *node, const char *name, GPUNodeStack *in, GPUNodeStack *out,...)
@ GPU_MATFLAG_VOLUME_SCATTER
@ GPU_MATFLAG_VOLUME_ABSORPTION
void GPU_material_flag_set(GPUMaterial *mat, eGPUMaterialFlag flag)
@ PROP_FACTOR
Definition RNA_types.hh:154
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
@ UI_ITEM_R_SPLIT_EMPTY_NAME
local_group_size(16, 16) .push_constant(Type b
void node_type_size_preset(bNodeType *ntype, eNodeSizePreset size)
Definition node.cc:4614
void node_set_socket_availability(bNodeTree *ntree, bNodeSocket *sock, bool is_available)
Definition node.cc:3911
void node_register_type(bNodeType *ntype)
Definition node.cc:1708
static int node_shader_gpu_volume_scatter(GPUMaterial *mat, bNode *node, bNodeExecData *, GPUNodeStack *in, GPUNodeStack *out)
static void node_shader_update_scatter(bNodeTree *ntree, bNode *node)
static void node_declare(NodeDeclarationBuilder &b)
static void node_shader_init_scatter(bNodeTree *, bNode *node)
static void node_shader_buts_scatter(uiLayout *layout, bContext *, PointerRNA *ptr)
void sh_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
bool object_shader_nodes_poll(const bContext *C)
bool node_socket_not_black(const GPUNodeStack &socket)
bool node_socket_not_zero(const GPUNodeStack &socket)
#define SOCK_DENSITY_ID
#define SOCK_COLOR_ID
void register_node_type_sh_volume_scatter()
Defines a node type.
Definition BKE_node.hh:218
bool(* add_ui_poll)(const bContext *C)
Definition BKE_node.hh:288
void(* initfunc)(bNodeTree *ntree, bNode *node)
Definition BKE_node.hh:267
NodeGPUExecFunction gpu_fn
Definition BKE_node.hh:318
void(* draw_buttons)(uiLayout *, bContext *C, PointerRNA *ptr)
Definition BKE_node.hh:238
NodeDeclareFunction declare
Definition BKE_node.hh:347
void(* updatefunc)(bNodeTree *ntree, bNode *node)
Definition BKE_node.hh:257
PointerRNA * ptr
Definition wm_files.cc:4126