[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [57414] trunk/blender/source/blender: Track Position node now could output absolute position of track at a given frame
Sergey Sharybin
sergey.vfx at gmail.com
Wed Jun 12 16:28:37 CEST 2013
Revision: 57414
http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=57414
Author: nazgul
Date: 2013-06-12 14:28:36 +0000 (Wed, 12 Jun 2013)
Log Message:
-----------
Track Position node now could output absolute position of track at a given frame
Modified Paths:
--------------
trunk/blender/source/blender/blenkernel/BKE_node.h
trunk/blender/source/blender/compositor/nodes/COM_TrackPositionNode.cpp
trunk/blender/source/blender/editors/space_node/drawnode.c
trunk/blender/source/blender/makesrna/intern/rna_nodetree.c
Modified: trunk/blender/source/blender/blenkernel/BKE_node.h
===================================================================
--- trunk/blender/source/blender/blenkernel/BKE_node.h 2013-06-12 12:55:44 UTC (rev 57413)
+++ trunk/blender/source/blender/blenkernel/BKE_node.h 2013-06-12 14:28:36 UTC (rev 57414)
@@ -921,6 +921,7 @@
#define CMP_TRACKPOS_ABSOLUTE 0
#define CMP_TRACKPOS_RELATIVE_START 1
#define CMP_TRACKPOS_RELATIVE_FRAME 2
+#define CMP_TRACKPOS_ABSOLUTE_FRAME 3
/* API */
struct CompBuf;
Modified: trunk/blender/source/blender/compositor/nodes/COM_TrackPositionNode.cpp
===================================================================
--- trunk/blender/source/blender/compositor/nodes/COM_TrackPositionNode.cpp 2013-06-12 12:55:44 UTC (rev 57413)
+++ trunk/blender/source/blender/compositor/nodes/COM_TrackPositionNode.cpp 2013-06-12 14:28:36 UTC (rev 57414)
@@ -27,6 +27,8 @@
extern "C" {
#include "DNA_movieclip_types.h"
+
+ #include "BKE_node.h"
}
TrackPositionNode::TrackPositionNode(bNode *editorNode) : Node(editorNode)
@@ -44,13 +46,21 @@
NodeTrackPosData *trackpos_data = (NodeTrackPosData *) editorNode->storage;
+ int frame_number;
+ if (editorNode->custom1 == CMP_TRACKPOS_ABSOLUTE_FRAME) {
+ frame_number = editorNode->custom2;
+ }
+ else {
+ frame_number = context->getFramenumber();
+ }
+
TrackPositionOperation *operationX = new TrackPositionOperation();
TrackPositionOperation *operationY = new TrackPositionOperation();
operationX->setMovieClip(clip);
operationX->setTrackingObject(trackpos_data->tracking_object);
operationX->setTrackName(trackpos_data->track_name);
- operationX->setFramenumber(context->getFramenumber());
+ operationX->setFramenumber(frame_number);
operationX->setAxis(0);
operationX->setPosition(editorNode->custom1);
operationX->setRelativeFrame(editorNode->custom2);
@@ -58,7 +68,7 @@
operationY->setMovieClip(clip);
operationY->setTrackingObject(trackpos_data->tracking_object);
operationY->setTrackName(trackpos_data->track_name);
- operationY->setFramenumber(context->getFramenumber());
+ operationY->setFramenumber(frame_number);
operationY->setAxis(1);
operationY->setPosition(editorNode->custom1);
operationY->setRelativeFrame(editorNode->custom2);
Modified: trunk/blender/source/blender/editors/space_node/drawnode.c
===================================================================
--- trunk/blender/source/blender/editors/space_node/drawnode.c 2013-06-12 12:55:44 UTC (rev 57413)
+++ trunk/blender/source/blender/editors/space_node/drawnode.c 2013-06-12 14:28:36 UTC (rev 57414)
@@ -2216,7 +2216,7 @@
uiItemR(layout, ptr, "position", 0, NULL, ICON_NONE);
- if (node->custom1 == 2) {
+ if (ELEM(node->custom1, CMP_TRACKPOS_RELATIVE_FRAME, CMP_TRACKPOS_ABSOLUTE_FRAME)) {
uiItemR(layout, ptr, "frame_relative", 0, NULL, ICON_NONE);
}
}
Modified: trunk/blender/source/blender/makesrna/intern/rna_nodetree.c
===================================================================
--- trunk/blender/source/blender/makesrna/intern/rna_nodetree.c 2013-06-12 12:55:44 UTC (rev 57413)
+++ trunk/blender/source/blender/makesrna/intern/rna_nodetree.c 2013-06-12 14:28:36 UTC (rev 57414)
@@ -5720,6 +5720,8 @@
"Relative Start", "Output position of a marker relative to first marker of a track"},
{CMP_TRACKPOS_RELATIVE_FRAME, "RELATIVE_FRAME", 0,
"Relative Frame", "Output position of a marker relative to marker at given frame number"},
+ {CMP_TRACKPOS_ABSOLUTE_FRAME, "ABSOLUTE_FRAME", 0,
+ "Absolute Frame", "Output absolute position of a marker at given frame number"},
{0, NULL, 0, NULL, NULL}
};
More information about the Bf-blender-cvs
mailing list