Commit 923fdb05 authored by Claes Sjofors's avatar Claes Sjofors

Java, move dynamics added to jopg

parent fbd5ac39
...@@ -1341,6 +1341,8 @@ public class Dyn { ...@@ -1341,6 +1341,8 @@ public class Dyn {
} }
public DynParsedAttrName parseAttrName(String name) { public DynParsedAttrName parseAttrName(String name) {
if ( name == null)
return null;
if ( (total_dyn_type1 & Dyn.mDynType1_HostObject) != 0) { if ( (total_dyn_type1 & Dyn.mDynType1_HostObject) != 0) {
int idx = name.indexOf("$hostobject"); int idx = name.indexOf("$hostobject");
if ( idx != -1) { if ( idx != -1) {
...@@ -3661,7 +3663,32 @@ public class Dyn { ...@@ -3661,7 +3663,32 @@ public class Dyn {
double scale_x_factor; double scale_x_factor;
double scale_y_factor; double scale_y_factor;
int scale_type; int scale_type;
int move_x_p = -1;
int move_x_database;
int move_x_typeid;
PwrtRefId move_x_subid;
int move_y_p = -1;
int move_y_database;
int move_y_typeid;
PwrtRefId move_y_subid;
int scale_x_p = -1;
int scale_x_database;
int scale_x_typeid;
PwrtRefId scale_x_subid;
int scale_y_p = -1;
int scale_y_database;
int scale_y_typeid;
PwrtRefId scale_y_subid;
float move_x_old_value = 0;
float move_y_old_value = 0;
float scale_x_old_value = 0;
float scale_y_old_value = 0;
boolean firstScan = true;
double x_orig;
double y_orig;
double width_orig;
double height_orig;
public DynMove( Dyn dyn) { public DynMove( Dyn dyn) {
super(dyn, Dyn.mDynType1_Move, 0, 0, 0, Dyn.eDynPrio_Move); super(dyn, Dyn.mDynType1_Move, 0, 0, 0, Dyn.eDynPrio_Move);
} }
...@@ -3679,6 +3706,359 @@ public class Dyn { ...@@ -3679,6 +3706,359 @@ public class Dyn {
scale_y_attribute = x.scale_y_attribute; scale_y_attribute = x.scale_y_attribute;
} }
public int connect(GlowArrayElem o) {
GrowNode object = (GrowNode)o;
GdhrRefObjectInfo ret = null;
DynParsedAttrName pname = dyn.parseAttrName(move_x_attribute);
if ( !(pname == null || pname.name.equals(""))) {
switch ( pname.type) {
case Pwr.eType_Float32:
case Pwr.eType_Float64:
case Pwr.eType_Int32:
case Pwr.eType_UInt32:
break;
default:
System.out.println("Move: " + move_x_attribute);
return 1;
}
ret = null;
switch( pname.database) {
case GraphIfc.eDatabase_Gdh:
ret = dyn.graph.getGdh().refObjectInfo( pname.tname);
break;
default:
ret = null;
}
if ( ret == null || ret.evenSts()) {
System.out.println("Move: " + move_x_attribute);
return 1;
}
move_x_p = ret.id;
move_x_subid = ret.refid;
move_x_typeid = pname.type;
}
pname = dyn.parseAttrName(move_y_attribute);
if ( pname != null && !pname.name.equals("")) {
ret = null;
switch ( pname.type) {
case Pwr.eType_Float32:
case Pwr.eType_Float64:
case Pwr.eType_Int32:
case Pwr.eType_UInt32:
break;
default:
System.out.println("Move: " + move_y_attribute);
return 1;
}
switch( pname.database) {
case GraphIfc.eDatabase_Gdh:
ret = dyn.graph.getGdh().refObjectInfo( pname.tname);
break;
default:
ret = null;
}
if ( ret == null || ret.evenSts()) {
System.out.println("Move: " + move_y_attribute);
return 1;
}
move_y_p = ret.id;
move_y_subid = ret.refid;
move_y_typeid = pname.type;
}
pname = dyn.parseAttrName(scale_x_attribute);
if ( pname != null && !pname.name.equals("")) {
ret = null;
switch ( pname.type) {
case Pwr.eType_Float32:
case Pwr.eType_Float64:
case Pwr.eType_Int32:
case Pwr.eType_UInt32:
break;
default:
System.out.println("Move: " + scale_x_attribute);
return 1;
}
switch( pname.database) {
case GraphIfc.eDatabase_Gdh:
ret = dyn.graph.getGdh().refObjectInfo( pname.tname);
break;
default:
ret = null;
}
if ( ret == null || ret.evenSts()) {
System.out.println("Move: " + scale_x_attribute);
return 1;
}
scale_x_p = ret.id;
scale_x_subid = ret.refid;
scale_x_typeid = pname.type;
}
pname = dyn.parseAttrName(scale_y_attribute);
if ( pname != null && !pname.name.equals("")) {
ret = null;
switch ( pname.type) {
case Pwr.eType_Float32:
case Pwr.eType_Float64:
case Pwr.eType_Int32:
case Pwr.eType_UInt32:
break;
default:
System.out.println("Move: " + scale_y_attribute);
return 1;
}
switch( pname.database) {
case GraphIfc.eDatabase_Gdh:
ret = dyn.graph.getGdh().refObjectInfo( pname.tname);
break;
default:
ret = null;
}
if ( ret == null || ret.evenSts()) {
System.out.println("Move: " + scale_y_attribute);
return 1;
}
scale_y_p = ret.id;
scale_y_subid = ret.refid;
scale_y_typeid = pname.type;
}
if ( !object.transform_is_stored()) {
object.store_transform();
GlowGeometry geom = object.measure();
x_orig = geom.ll_x;
y_orig = geom.ll_y;
width_orig = geom.ur_x - x_orig;
height_orig = geom.ur_y - y_orig;
}
return 1;
}
public void disconnect() {
if ( move_x_p != -1 && move_x_database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(move_x_subid);
if ( move_y_p != -1 && move_y_database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(move_y_subid);
if ( scale_x_p != -1 && scale_x_database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(scale_x_subid);
if ( scale_y_p != -1 && scale_y_database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(scale_y_subid);
}
public void scan( GlowArrayElem o) {
GrowNode object = (GrowNode)o;
boolean update = false;
float move_x_value = 0;
float move_y_value = 0;
float scale_x_value = 0;
float scale_y_value = 0;
if ( move_x_p != -1) {
switch ( move_x_typeid) {
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
move_x_value = dyn.graph.getGdh().getObjectRefInfoFloat( move_x_p);
break;
}
case Pwr.eType_Int32:
case Pwr.eType_UInt32: {
move_x_value = (float)dyn.graph.getGdh().getObjectRefInfoInt( move_x_p);
break;
}
default: ;
}
}
if ( move_y_p != -1) {
switch ( move_x_typeid) {
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
move_y_value = dyn.graph.getGdh().getObjectRefInfoFloat( move_y_p);
break;
}
case Pwr.eType_Int32:
case Pwr.eType_UInt32: {
move_y_value = (float)dyn.graph.getGdh().getObjectRefInfoInt( move_y_p);
break;
}
default: ;
}
}
if ( scale_x_p != -1) {
switch ( scale_x_typeid) {
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
scale_x_value = dyn.graph.getGdh().getObjectRefInfoFloat( scale_x_p);
break;
}
case Pwr.eType_Int32:
case Pwr.eType_UInt32: {
scale_x_value = (float)dyn.graph.getGdh().getObjectRefInfoInt( scale_x_p);
break;
}
default: ;
}
}
if ( scale_y_p != -1) {
switch ( scale_x_typeid) {
case Pwr.eType_Float32:
case Pwr.eType_Float64: {
scale_y_value = dyn.graph.getGdh().getObjectRefInfoFloat( scale_y_p);
break;
}
case Pwr.eType_Int32:
case Pwr.eType_UInt32: {
scale_y_value = (float)dyn.graph.getGdh().getObjectRefInfoInt( scale_y_p);
break;
}
default: ;
}
}
update = false;
if ( !firstScan) {
if ( move_x_p != -1 && move_x_value != move_x_old_value)
update = true;
else if ( move_y_p != -1 && move_y_value != move_y_old_value)
update = true;
else if ( scale_x_p != -1 && scale_x_value != scale_x_old_value)
update = true;
else if ( scale_y_p != -1 && scale_y_value != scale_y_old_value)
update = true;
if ( !update)
return;
}
else
firstScan = false;
double move_x = 0;
double move_y = 0;
double scale_x = 1;
double scale_y = 1;
if ( scale_x_p != -1 || scale_y_p != -1) {
if ( scale_x_p != -1)
scale_x = scale_x_value * scale_x_factor;
else
scale_x = 1;
if ( scale_y_p != -1)
scale_y = scale_y_value * scale_y_factor;
}
else
scale_y = 1;
if ( !(move_x_p != -1 || move_y_p != -1))
object.set_scale( scale_x, scale_y, 0, 0,
scale_type);
if ( scale_x_p != -1)
scale_x_old_value = scale_x_value;
if ( scale_y_p != -1)
scale_y_old_value = scale_y_value;
if ( move_x_p != -1 || move_y_p != -1) {
if ( move_x_p != -1) {
double scale_offs = 0;
// Adjust position for different scaletypes
switch ( scale_type) {
case Glow.eScaleType_LowerRight:
case Glow.eScaleType_UpperRight:
scale_offs = width_orig * ( 1 - scale_x);
break;
case Glow.eScaleType_Center:
scale_offs = width_orig * ( 1 - scale_x) / 2;
break;
default: ;
}
move_x = x_orig + scale_offs + (move_x_value - x_offset) * x_factor;
}
else
move_x = x_orig;
if ( move_y_p != -1) {
double scale_offs = 0;
// Adjust position for different scaletypes
switch ( scale_type) {
case Glow.eScaleType_UpperRight:
case Glow.eScaleType_UpperLeft:
scale_offs = height_orig * ( 1 - scale_y);
break;
case Glow.eScaleType_Center:
scale_offs = height_orig * ( 1 - scale_y) / 2;
break;
default: ;
}
move_y = y_orig + scale_offs + (move_y_value - y_offset) * y_factor;
}
else
move_y = y_orig;
if ( Math.abs(scale_x) < Double.MIN_VALUE)
scale_x = 10e-5;
if ( Math.abs(scale_y) < Double.MIN_VALUE)
scale_y = 10e-5;
object.set_scale_pos( move_x, move_y,
scale_x, scale_y, 0, 0,
scale_type);
if ( move_x_p != -1)
move_x_old_value = move_x_value;
if ( move_y_p != -1)
move_y_old_value = move_y_value;
}
else {
if ( move_x_p != -1)
move_x = (move_x_value - x_offset) * x_factor;
else
move_x = 0;
if ( move_y_p != -1) {
move_y = (move_y_value - y_offset) * y_factor;
}
else
move_y = 0;
object.set_position( move_x, move_y);
if ( move_x_p != -1)
move_x_old_value = move_x_value;
if ( move_y_p != -1)
move_y_old_value = move_y_value;
}
}
public void open( BufferedReader reader) { public void open( BufferedReader reader) {
String line; String line;
StringTokenizer token; StringTokenizer token;
......
...@@ -915,6 +915,110 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode { ...@@ -915,6 +915,110 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
y_high * cmn.mw.zoom_factor_y - cmn.mw.offset_y + Glow.DRAW_MP); y_high * cmn.mw.zoom_factor_y - cmn.mw.offset_y + Glow.DRAW_MP);
} }
public void set_scale_pos( double x, double y,
double scale_x, double scale_y,
double x0, double y0, int type) {
double old_x_left, old_x_right, old_y_low, old_y_high;
old_x_left = x_left;
old_x_right = x_right;
old_y_low = y_low;
old_y_high = y_high;
cmn.setNodraw();
set_scale( scale_x, scale_y, x0, y0, type);
cmn.resetNodraw();
trf.move( x - x_left, y - y_low);
get_node_borders();
/*
ctx->set_defered_redraw();
ctx->draw( &ctx->mw, old_x_left * ctx->mw.zoom_factor_x - ctx->mw.offset_x - DRAW_MP,
old_y_low * ctx->mw.zoom_factor_y - ctx->mw.offset_y - DRAW_MP,
old_x_right * ctx->mw.zoom_factor_x - ctx->mw.offset_x + DRAW_MP,
old_y_high * ctx->mw.zoom_factor_y - ctx->mw.offset_y + DRAW_MP);
ctx->draw( &ctx->mw, x_left * ctx->mw.zoom_factor_x - ctx->mw.offset_x - DRAW_MP,
y_low * ctx->mw.zoom_factor_y - ctx->mw.offset_y - DRAW_MP,
x_right * ctx->mw.zoom_factor_x - ctx->mw.offset_x + DRAW_MP,
y_high * ctx->mw.zoom_factor_y - ctx->mw.offset_y + DRAW_MP);
ctx->draw( &ctx->navw, old_x_left * ctx->navw.zoom_factor_x - ctx->navw.offset_x - 1,
old_y_low * ctx->navw.zoom_factor_y - ctx->navw.offset_y - 1,
old_x_right * ctx->navw.zoom_factor_x - ctx->navw.offset_x + 1,
old_y_high * ctx->navw.zoom_factor_y - ctx->navw.offset_y + 1);
ctx->draw( &ctx->navw, x_left * ctx->navw.zoom_factor_x - ctx->navw.offset_x - 1,
y_low * ctx->navw.zoom_factor_y - ctx->navw.offset_y - 1,
x_right * ctx->navw.zoom_factor_x - ctx->navw.offset_x + 1,
y_high * ctx->navw.zoom_factor_y - ctx->navw.offset_y + 1);
ctx->redraw_defered();
*/
}
public void set_scale( double scale_x, double scale_y,
double x0, double y0, int type) {
double old_x_left, old_x_right, old_y_low, old_y_high;
if ( !((scale_x == -1 && scale_y == 1) || (scale_x == 1 && scale_y == -1))) {
if ( scale_x < 0)
scale_x = 0;
if ( scale_y < 0)
scale_y = 0;
}
if ( trf.s_a11 != 0 && trf.s_a22 != 0 &&
Math.abs( scale_x - trf.a11 / trf.s_a11) < Float.MIN_VALUE &&
Math.abs( scale_y - trf.a22 / trf.s_a22) < Float.MIN_VALUE)
return;
switch( type) {
case Glow.eScaleType_LowerLeft:
x0 = x_left;
y0 = y_low;
break;
case Glow.eScaleType_LowerRight:
x0 = x_right;
y0 = y_low;
break;
case Glow.eScaleType_UpperRight:
x0 = x_right;
y0 = y_high;
break;
case Glow.eScaleType_UpperLeft:
x0 = x_left;
y0 = y_high;
break;
case Glow.eScaleType_FixPoint:
break;
case Glow.eScaleType_Center:
x0 = (x_left + x_right) / 2;
y0 = (y_low + y_high) /2;
break;
default:
;
}
old_x_left = x_left;
old_x_right = x_right;
old_y_low = y_low;
old_y_high = y_high;
trf.scale_from_stored( scale_x, scale_y, x0, y0);
get_node_borders();
/*
ctx->draw( &ctx->mw, old_x_left * ctx->mw.zoom_factor_x - ctx->mw.offset_x - DRAW_MP,
old_y_low * ctx->mw.zoom_factor_y - ctx->mw.offset_y - DRAW_MP,
old_x_right * ctx->mw.zoom_factor_x - ctx->mw.offset_x + DRAW_MP,
old_y_high * ctx->mw.zoom_factor_y - ctx->mw.offset_y + DRAW_MP);
ctx->draw( &ctx->mw, x_left * ctx->mw.zoom_factor_x - ctx->mw.offset_x - DRAW_MP,
y_low * ctx->mw.zoom_factor_y - ctx->mw.offset_y - DRAW_MP,
x_right * ctx->mw.zoom_factor_x - ctx->mw.offset_x + DRAW_MP,
y_high * ctx->mw.zoom_factor_y - ctx->mw.offset_y + DRAW_MP);
ctx->draw( &ctx->navw, x_left * ctx->navw.zoom_factor_x - ctx->navw.offset_x - 1,
y_low * ctx->navw.zoom_factor_y - ctx->navw.offset_y - 1,
x_right * ctx->navw.zoom_factor_x - ctx->navw.offset_x + 1,
y_high * ctx->navw.zoom_factor_y - ctx->navw.offset_y + 1);
*/
}
public int get_background_object_limits(GlowTransform t, int type, double x, double y, Object bo) { public int get_background_object_limits(GlowTransform t, int type, double x, double y, Object bo) {
int dyn_type; int dyn_type;
GlowBackgroundObject b = (GlowBackgroundObject)bo; GlowBackgroundObject b = (GlowBackgroundObject)bo;
...@@ -1022,4 +1126,10 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode { ...@@ -1022,4 +1126,10 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
public String getName() { public String getName() {
return n_name; return n_name;
} }
public void store_transform() {
trf.store();
}
public boolean transform_is_stored() {
return trf.is_stored();
}
} }
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