Frame inverse and sensitive area adjusted

parent a3f601f2
...@@ -63,10 +63,10 @@ void FlowFrame::draw( void *pos, int highlight, int hot, void *node) ...@@ -63,10 +63,10 @@ void FlowFrame::draw( void *pos, int highlight, int hot, void *node)
idx = MAX( 0, idx); idx = MAX( 0, idx);
idx = MIN( idx, DRAW_TYPE_SIZE-1); idx = MIN( idx, DRAW_TYPE_SIZE-1);
ctx->fdraw->rect( ctx, ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x, ctx->fdraw->rect( ctx, ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x,
ll.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y, ll.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y,
int( ur_x * ctx->zoom_factor - ll.z_x - ((FlowPoint *)pos)->z_x - 1), int( ur_x * ctx->zoom_factor - ll.z_x - ((FlowPoint *)pos)->z_x - 1),
int( ur_y * ctx->zoom_factor - ll.z_y - ((FlowPoint *)pos)->z_y - 1), int( ur_y * ctx->zoom_factor - ll.z_y - ((FlowPoint *)pos)->z_y - 1),
draw_type, idx, highlight); draw_type, idx, highlight);
} }
void FlowFrame::erase( void *pos, int hot, void *node) void FlowFrame::erase( void *pos, int hot, void *node)
...@@ -94,10 +94,10 @@ void FlowFrame::erase( void *pos, int hot, void *node) ...@@ -94,10 +94,10 @@ void FlowFrame::erase( void *pos, int hot, void *node)
idx = MIN( idx, DRAW_TYPE_SIZE-1); idx = MIN( idx, DRAW_TYPE_SIZE-1);
ctx->fdraw->rect_erase( ctx, ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x, ll.z_y + ctx->fdraw->rect_erase( ctx, ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x, ll.z_y +
((FlowPoint *)pos)->z_y - ctx->offset_y, ((FlowPoint *)pos)->z_y - ctx->offset_y,
int( ur_x * ctx->zoom_factor - ll.z_x - ((FlowPoint *)pos)->z_x - 1), int( ur_x * ctx->zoom_factor - ll.z_x - ((FlowPoint *)pos)->z_x - 1),
int( ur_y * ctx->zoom_factor - ll.z_y - ((FlowPoint *)pos)->z_y - 1), int( ur_y * ctx->zoom_factor - ll.z_y - ((FlowPoint *)pos)->z_y - 1),
idx); idx);
} }
void FlowFrame::get_borders( double pos_x, double pos_y, double *x_right, void FlowFrame::get_borders( double pos_x, double pos_y, double *x_right,
...@@ -113,3 +113,29 @@ void FlowFrame::get_borders( double pos_x, double pos_y, double *x_right, ...@@ -113,3 +113,29 @@ void FlowFrame::get_borders( double pos_x, double pos_y, double *x_right,
*y_high = pos_y + ur.y; *y_high = pos_y + ur.y;
} }
int FlowFrame::event_handler( void *pos, flow_eEvent event, int x, int y,
void *node)
{
FlowPoint *p;
p = (FlowPoint *) pos;
if ( ctx->type() == flow_eCtxType_Brow) {
if ( ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x <= x &&
ll.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y <= y &&
y <= ur.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y)
return 1;
else
return 0;
}
else {
if ( ll.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x <= x &&
x <= ur.z_x + ((FlowPoint *)pos)->z_x - ctx->offset_x &&
ll.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y <= y &&
y <= ur.z_y + ((FlowPoint *)pos)->z_y - ctx->offset_y)
// cout << "Event handler: Hit in rect" << endl;
return 1;
else
return 0;
}
}
...@@ -41,6 +41,8 @@ class FlowFrame : public FlowRect { ...@@ -41,6 +41,8 @@ class FlowFrame : public FlowRect {
void get_borders( double pos_x, double pos_y, double *x_right, void get_borders( double pos_x, double pos_y, double *x_right,
double *x_left, double *y_high, double *y_low, void *node); double *x_left, double *y_high, double *y_low, void *node);
flow_eObjectType type() { return flow_eObjectType_Frame;}; flow_eObjectType type() { return flow_eObjectType_Frame;};
int event_handler( void *pos, flow_eEvent event, int x, int y,
void *node);
}; };
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment