-
Notifications
You must be signed in to change notification settings - Fork 370
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
OSL built-in displace() and bump() were documented but never implemented #887
base: main
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -407,6 +407,35 @@ int hash (point p, float t) BUILTIN; | |
|
||
|
||
// Displacement functions | ||
void displace (vector offset) { | ||
P += offset; | ||
N = normalize (calculatenormal (P)); | ||
} | ||
void displace (float amp) { | ||
displace (amp * N); | ||
} | ||
void displace (string space, float amp) { | ||
float len = length (transform (space, N)); | ||
displace (amp * len * N); | ||
} | ||
void displace (string space, vector offset) { | ||
displace (transform (space, "common", offset)); | ||
} | ||
|
||
void bump (vector offset) { | ||
N = normalize (calculatenormal (P+offset)); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Isn't it discouraged to change There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think I would prefer for There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The idea is that you should call one of these in the "root" shader, which is passed in the accumulated offset or amount. If you're randomly calling it in mid-graph nodes, perhaps multiple times, you're probably going to do weird things. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also, the idea was, some day (or in some renderers) we might want displace() to have additional side effects. For example, maybe it modifies dPdu, dPdv? Or do other renderer-specific things? I wanted a function that does the "assignment to global variables" part, which may someday grow to have per-renderer trickiness. The "accumulate and return total" part is already trivial. |
||
} | ||
void bump (float amp) { | ||
bump (amp * N); | ||
} | ||
void bump (string space, float amp) { | ||
float len = length (transform (space, N)); | ||
bump (amp * len * N); | ||
} | ||
void bump (string space, vector offset) { | ||
bump (transform (space, "common", offset)); | ||
} | ||
|
||
|
||
|
||
// String functions | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does this do the right thing if the scale is not uniform?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think. But it might depend on what you think is "right".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
:) Yeah... I've been using this idiom forever. It makes intuitive sense, and it does give the user some form of non-uniform control over the displacement magnitude. However, lately I've switched to using the cube-root of abs(determinant(matrix(space,"common"))) as the scale factor. This change of heart is due to my experience using non-uniformly scaled coordinate systems to control displacement. With the simple length(transform(N)) method, the results are never quite what I expect or desire, and so the presumed control it allows doesn't, in my recent opinion, live up to the expectation. As a result, I've concluded that preserving a volumetric sense of relative scale is more useful in the rare instance when a user must use a non-uniformly scaled space to control displacement magnitude. Since displacement can be viewed as a volumetric operation, I now see this as making more intuitive sense. But, all that said, the simple approach works perfectly in the case of uniformly scaled coordinates, and is cheaper to compute. And since that's by far the most likely scenario, it may be the right implementation choice.