forked from bartvdbraak/blender
Texture Paint: changing paint slots and viewport could go out of sync
When changing to another texture paint slot, the texture displayed in the viewport should change accordingly (as well as the image displayed in the Image Editor). The procedure to find the texture to display in the viewport (BKE_texpaint_slot_material_find_node) could fail though because it assumed iterating nodes would always happen in the same order (it was index based). This is not the case though, nodes can get sorted differently based on selection (see ED_node_sort). Now check the actual image being referenced in the paint slot for comparison. ref T88788 (probably enough to call this a fix, the other issue(s) mentioned in the report are more likely a feature request) Reviewed By: mano-wii Maniphest Tasks: T88788 Differential Revision: https://developer.blender.org/D11496
This commit is contained in:
parent
b6d6d8a1aa
commit
56005ef499
@ -1513,16 +1513,16 @@ void BKE_texpaint_slots_refresh_object(Scene *scene, struct Object *ob)
|
||||
}
|
||||
|
||||
struct FindTexPaintNodeData {
|
||||
bNode *node;
|
||||
short iter_index;
|
||||
short index;
|
||||
Image *ima;
|
||||
bNode *r_node;
|
||||
};
|
||||
|
||||
static bool texpaint_slot_node_find_cb(bNode *node, void *userdata)
|
||||
{
|
||||
struct FindTexPaintNodeData *find_data = userdata;
|
||||
if (find_data->iter_index++ == find_data->index) {
|
||||
find_data->node = node;
|
||||
Image *ima = (Image *)node->id;
|
||||
if (find_data->ima == ima) {
|
||||
find_data->r_node = node;
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -1531,10 +1531,10 @@ static bool texpaint_slot_node_find_cb(bNode *node, void *userdata)
|
||||
|
||||
bNode *BKE_texpaint_slot_material_find_node(Material *ma, short texpaint_slot)
|
||||
{
|
||||
struct FindTexPaintNodeData find_data = {NULL, 0, texpaint_slot};
|
||||
struct FindTexPaintNodeData find_data = {ma->texpaintslot[texpaint_slot].ima, NULL};
|
||||
ntree_foreach_texnode_recursive(ma->nodetree, texpaint_slot_node_find_cb, &find_data);
|
||||
|
||||
return find_data.node;
|
||||
return find_data.r_node;
|
||||
}
|
||||
|
||||
/* r_col = current value, col = new value, (fac == 0) is no change */
|
||||
|
Loading…
Reference in New Issue
Block a user