Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohnny Matthews <guitargeek>2021-09-24 22:03:42 +0300
committerHans Goudey <h.goudey@me.com>2021-09-24 22:03:42 +0300
commit536f9eb82e07778565b789f7408f3ce81aa6d675 (patch)
treec851490f5a7c7b76f32f44657591641b675ecf62 /source/blender/modifiers
parentc87e6b23be5683e006d75a69281ecf64dc86c7d6 (diff)
Geometry Nodes: Random Value Node
This node replaces the deprecated Attribute Randomize node, populating a vector, float, integer or boolean field with random values. Vector, float, and integer have min/max settings, which are also field aware. The boolean type has a probability value for controlling what portion of the output should be true. All four types have a field seed input which is implicitly driven by the index, otherwise, all values would be the same "random" value. The Random Float node is now deprecated like other nodes, since it is redundant with this node. Differential Revision: https://developer.blender.org/D12603
Diffstat (limited to 'source/blender/modifiers')
-rw-r--r--source/blender/modifiers/intern/MOD_nodes_evaluator.cc4
1 files changed, 4 insertions, 0 deletions
diff --git a/source/blender/modifiers/intern/MOD_nodes_evaluator.cc b/source/blender/modifiers/intern/MOD_nodes_evaluator.cc
index e50c07ce6f2..9f296f4cfe9 100644
--- a/source/blender/modifiers/intern/MOD_nodes_evaluator.cc
+++ b/source/blender/modifiers/intern/MOD_nodes_evaluator.cc
@@ -334,6 +334,10 @@ static void get_socket_value(const SocketRef &socket, void *r_value)
std::make_shared<bke::AttributeFieldInput>("position", CPPType::get<float3>()));
return;
}
+ if (bsocket.type == SOCK_INT && bnode.type == FN_NODE_RANDOM_VALUE) {
+ new (r_value) Field<int>(std::make_shared<fn::IndexFieldInput>());
+ return;
+ }
}
const bNodeSocketType *typeinfo = socket.typeinfo();
typeinfo->get_geometry_nodes_cpp_value(*socket.bsocket(), r_value);