Commit 3b9b1b69 authored by Claes Sjofors's avatar Claes Sjofors

Java dynamic ScrollingText and Animation added

parent 422a589c
......@@ -112,7 +112,7 @@ public class GraphCmn implements PlowCmnIfc {
graph.gdh.getObjectRefInfoAll();
*/
graph.cmn.setNodraw();
graph.ctx.traceScan();
graph.traceScan();
graph.cmn.resetNodraw();
}
public void setCanvas(Canvas canvas) {
......
......@@ -467,6 +467,7 @@ public class Dyn {
public static final int eSave_ScrollingText_attribute = 4200;
public static final int eSave_ScrollingText_direction = 4201;
public static final int eSave_ScrollingText_speed = 4202;
public static final int eSave_ScrollingText_bounce = 4203;
public static final int eSave_PopupMenu_ref_object = 5000;
public static final int eSave_SetDig_attribute = 5100;
public static final int eSave_SetDig_instance = 5101;
......@@ -652,6 +653,7 @@ public class Dyn {
public static final int eSave_Script_script_len = 7300;
public static final int eSave_Script_script = 7301;
public static final int eAnimSequence_Inherit = 0;
public static final int eAnimSequence_Cycle = 1;
public static final int eAnimSequence_Dig = 2;
public static final int eAnimSequence_ForwBack = 3;
......@@ -4909,13 +4911,16 @@ public class Dyn {
String attribute;
int direction;
double speed;
int bounce;
PwrtRefId subid;
int a_typeid;
int p;
int database;
boolean inverted;
boolean attrFound = false;
String oldValue;
boolean firstScan = true;
double offset = 0;
double osize;
public DynScrollingText( Dyn dyn) {
super(dyn, Dyn.mDynType2_ScrollingText, 0, 0, 0, Dyn.eDynPrio_ScrollingText);
......@@ -4931,15 +4936,158 @@ public class Dyn {
public int connect(GlowArrayElem o) {
GrowNode object = (GrowNode)o;
DynParsedAttrName pname = dyn.parseAttrName(attribute);
if ( pname == null || pname.name.equals(""))
return 1;
if ( !(pname.type == Pwr.eType_String || pname.type == Pwr.eType_Text))
return 1;
GdhrRefObjectInfo ret = null;
switch( pname.database) {
case GraphIfc.eDatabase_Gdh:
ret = dyn.graph.getGdh().refObjectInfo( pname.tname);
break;
case GraphIfc.eDatabase_Local:
ret = dyn.graph.getLdb().refObjectInfo( graph, pname.name);
break;
default:
ret = null;
}
if ( ret == null || ret.evenSts()) {
System.out.println("Value: " + attribute);
return 1;
}
GlowGeometry geom = object.measure();
switch( direction) {
case Glow.eDirection_Left:
case Glow.eDirection_Right:
osize = geom.ur_x - geom.ll_x;
break;
default:
osize = geom.ur_y - geom.ll_y;
}
p = ret.id;
subid = ret.refid;
a_typeid = pname.type;
database = pname.database;
attrFound = true;
return 1;
}
public void disconnect() {
if ( attrFound && database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(subid);
}
public void scan( GlowArrayElem o) {
GrowNode object = (GrowNode)o;
GlowDimensionD d = object.getAnnotationTextExtent( 1);
if ( d == null)
return;
switch ( direction) {
case Glow.eDirection_Left: {
offset -= speed * dyn.graph.getAnimationScanTime();
if ( bounce != 0) {
if ( d.width < osize) {
if ( offset < 0) {
offset = -offset;
direction = Glow.eDirection_Right;
}
}
else {
if ( offset < osize - d.width) {
offset += (osize - d.width) - offset;
direction = Glow.eDirection_Right;
}
}
}
else {
if ( offset < -d.width)
offset = osize;
}
object.setAnnotationTextOffset( 1, offset, 0);
break;
}
case Glow.eDirection_Right: {
offset += speed * dyn.graph.getAnimationScanTime();
if ( bounce != 0) {
if ( d.width < osize) {
if ( offset > osize - d.width) {
offset -= offset - (osize -d.width);
direction = Glow.eDirection_Left;
}
}
else {
if ( offset > 0) {
offset = -offset;
direction = Glow.eDirection_Left;
}
}
}
else {
if ( offset > osize)
offset = -d.width;
}
object.setAnnotationTextOffset( 1, offset, 0);
break;
}
case Glow.eDirection_Up: {
offset += speed * dyn.graph.getAnimationScanTime();
if ( bounce != 0) {
if ( offset > osize - d.height) {
offset -= offset- (osize - d.height);
direction = Glow.eDirection_Down;
}
}
else {
if ( offset > osize)
offset = -d.height;
}
object.setAnnotationTextOffset( 1, 0, offset);
break;
}
case Glow.eDirection_Down: {
offset -= speed * dyn.graph.getAnimationScanTime();
if ( bounce != 0) {
if ( offset < 0) {
offset = -offset;
direction = Glow.eDirection_Up;
}
}
else {
if ( offset < -d.height)
offset = osize;
}
object.setAnnotationTextOffset( 1, 0, offset);
break;
}
default: ;
}
String value0 = null;
switch ( database) {
case GraphIfc.eDatabase_Gdh:
value0 = dyn.graph.getGdh().getObjectRefInfoString( p, a_typeid);
break;
case GraphIfc.eDatabase_Local:
value0 = dyn.graph.getLdb().getObjectRefInfoString( p, a_typeid);
break;
}
if ( firstScan || !value0.equals( oldValue)) {
object.setAnnotation(1, value0);
dyn.repaintNow = true;
oldValue = value0;
}
if ( firstScan)
firstScan = false;
}
public void open( BufferedReader reader) {
......@@ -4966,6 +5114,9 @@ public class Dyn {
case Dyn.eSave_ScrollingText_speed:
speed = new Double(token.nextToken()).doubleValue();
break;
case Dyn.eSave_ScrollingText_bounce:
bounce = Integer.valueOf(token.nextToken());
break;
case Dyn.eSave_End:
end_found = true;
break;
......@@ -4988,6 +5139,17 @@ public class Dyn {
public class DynAnimation extends DynElem {
String attribute;
int sequence;
PwrtRefId subid;
int p;
int database;
boolean inverted;
boolean attrFound = false;
boolean oldValue;
boolean firstScan = true;
int bitmask;
int a_typeid;
int animation_count;
int animation_direction;
public DynAnimation( Dyn dyn) {
super(dyn, Dyn.mDynType1_Animation, 0, 0, 0, Dyn.eDynPrio_Animation);
......@@ -4999,6 +5161,169 @@ public class Dyn {
sequence = x.sequence;
}
public int connect(GlowArrayElem o) {
GrowNode object = (GrowNode)o;
DynParsedAttrName pname = dyn.parseAttrName(attribute);
if ( pname == null || pname.name.equals(""))
return 1;
GdhrRefObjectInfo 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("Animation: " + attribute);
return 1;
}
p = ret.id;
subid = ret.refid;
inverted = pname.inverted;
a_typeid = pname.type;
bitmask = pname.bitmask;
database = pname.database;
attrFound = true;
System.out.println( "AnimSequence1: " + sequence);
if ( sequence == Dyn.eAnimSequence_Inherit)
sequence = object.get_nodeclass_dyn_attr1();
System.out.println( "AnimSequence2: " + sequence);
return 1;
}
public void disconnect() {
if ( attrFound && database == GraphIfc.eDatabase_Gdh)
dyn.graph.getGdh().unrefObjectInfo(subid);
}
public void scan( GlowArrayElem o) {
GrowNode object = (GrowNode)o;
int max_count;
int sts;
if ( !attrFound)
return;
boolean value = dyn.getDig(p, a_typeid, bitmask, database);
if ( inverted)
value = !value;
if ( firstScan) {
animation_count = 0;
animation_direction = 0;
firstScan = false;
if ( sequence == Dyn.eAnimSequence_Dig) {
if ( value)
object.set_last_nodeclass();
oldValue = value;
}
}
if ( sequence == Dyn.eAnimSequence_Dig) {
if ( oldValue != value) {
// Start animation
if ( value) {
animation_count = 0;
animation_direction = 1;
}
else if ( !value) {
animation_direction = 2;
animation_count = 0;
}
}
if ( animation_direction != 0) {
max_count = object.get_animation_count();
animation_count++;
if ( animation_count >= max_count) {
// Shift nodeclass
if ( animation_direction == 1) {
// Shift forward
sts = object.set_next_nodeclass();
if ( (sts & 1) == 0) {
// End of animation
animation_count = 0;
animation_direction = 0;
}
animation_count = 0;
}
else {
// Shift backward
sts = object.set_previous_nodeclass();
if ( (sts & 1) == 0) {
// End of animation
animation_count = 0;
animation_direction = 0;
}
animation_count = 0;
}
}
}
}
else {
if ( value) {
if ( animation_direction == 0) {
// Animation has been stopped
animation_count = 0;
animation_direction = 1;
}
max_count = object.get_animation_count();
animation_count++;
if ( animation_count >= max_count) {
// Shift nodeclass
if ( animation_direction == 1) {
// Shift forward
sts = object.set_next_nodeclass();
if ((sts & 1) == 0) {
if ( sequence == Dyn.eAnimSequence_Cycle) {
// Start from the beginning again
object.set_nodeclass_by_index( 1);
}
else {
// Change direction
animation_direction = 2;
object.set_previous_nodeclass();
}
}
animation_count = 0;
}
else {
// Shift backward
sts = object.set_previous_nodeclass();
if ( (sts & 1) == 0) {
// Change direction
animation_direction = 1;
sts = object.set_next_nodeclass();
}
animation_count = 0;
}
}
}
else {
if ( animation_direction != 0) {
// Stop and reset animation
animation_direction = 0;
object.set_first_nodeclass();
}
}
}
oldValue = value;
}
public void open( BufferedReader reader) {
String line;
StringTokenizer token;
......
/*
* Proview Open Source Process Control.
* Copyright (C) 2005-2015 SSAB EMEA AB.
*
* This file is part of Proview.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Proview. If not, see <http://www.gnu.org/licenses/>
*
* Linking Proview statically or dynamically with other modules is
* making a combined work based on Proview. Thus, the terms and
* conditions of the GNU General Public License cover the whole
* combination.
*
* In addition, as a special exception, the copyright holders of
* Proview give you permission to, from the build function in the
* Proview Configurator, combine Proview with modules generated by the
* Proview PLC Editor to a PLC program, regardless of the license
* terms of these modules. You may copy and distribute the resulting
* combined work under the terms of your choice, provided that every
* copy of the combined work is accompanied by a complete copy of
* the source code of Proview (the version used to produce the
* combined work), being distributed under the terms of the GNU
* General Public License plus this exception.
*/
package jpwr.jopg;
public class GlowDimensionD {
public double width;
public double height;
}
......@@ -61,7 +61,7 @@ public class GlowNodeClass extends GlowArrayElem {
public int action_type1;
public int action_type2;
public int[] dyn_color = new int[4];
String[] dyn_attr = new String[4];
public int[] dyn_attr = new int[4];
GlowArrayElem next_nc;
GlowArrayElem prev_nc;
int recursive_trace;
......@@ -125,19 +125,19 @@ public class GlowNodeClass extends GlowArrayElem {
break;
case Glow.eSave_NodeClass_dyn_attr1:
if ( token.hasMoreTokens())
dyn_attr[0] = token.nextToken();
dyn_attr[0] = Integer.valueOf(token.nextToken());
break;
case Glow.eSave_NodeClass_dyn_attr2:
if ( token.hasMoreTokens())
dyn_attr[1] = token.nextToken();
dyn_attr[1] = Integer.valueOf(token.nextToken());
break;
case Glow.eSave_NodeClass_dyn_attr3:
if ( token.hasMoreTokens())
dyn_attr[2] = token.nextToken();
dyn_attr[2] = Integer.valueOf(token.nextToken());
break;
case Glow.eSave_NodeClass_dyn_attr4:
if ( token.hasMoreTokens())
dyn_attr[3] = token.nextToken();
dyn_attr[3] = Integer.valueOf(token.nextToken());
break;
case Glow.eSave_NodeClass_java_name:
break;
......@@ -285,4 +285,14 @@ public class GlowNodeClass extends GlowArrayElem {
;
return base;
}
GlowDimensionD getAnnotationTextExtent( GlowTransform t, Object node, int num) {
int i;
for ( i = 0; i < a.size(); i++) {
if ( a.get(i).type() == Glow.eObjectType_GrowAnnot && ((GrowAnnotIfc)a.get(i)).getNumber() == num)
return ((GrowAnnotIfc)a.get(i)).getTextExtent( t, node);
}
return null;
}
}
......@@ -51,6 +51,10 @@ public class Graph implements GraphIfc, GrowApplIfc {
public GraphLocalDb ldb;
public GrowSlider currentSlider;
public double scan_time = 1;
public double fast_scan_time = 1;
public double animation_scan_time = 1;
int slow_scan_cnt = 0;
int fast_scan_cnt = 0;
GrowCmn[] cmnStack = new GrowCmn[10];
int cmnStackCnt = 0;
int clickActive = 0;
......@@ -87,6 +91,7 @@ public class Graph implements GraphIfc, GrowApplIfc {
public void open(BufferedReader reader) {
ctx.open( reader);
animation_scan_time = ctx.cmn.animation_scantime;
ctx.traceConnect();
}
......@@ -144,10 +149,34 @@ public class Graph implements GraphIfc, GrowApplIfc {
public void traceScan(GlowArrayElem object) {
Dyn dyn = (Dyn)object.getUserData();
if ( dyn != null)
if ( dyn == null)
return;
if ( dyn.cycle == Glow.eCycle_Slow && slow_scan_cnt != 0 &&
!((dyn.total_dyn_type1 & Dyn.mDynType1_Animation) != 0 || (dyn.total_dyn_type2 & Dyn.mDynType2_ScrollingText) != 0))
return;
if ( dyn.cycle == Glow.eCycle_Fast && fast_scan_cnt != 0 &&
!((dyn.total_dyn_type1 & Dyn.mDynType1_Animation) != 0 || (dyn.total_dyn_type2 & Dyn.mDynType2_ScrollingText) != 0))
return;
dyn.scan(object);
}
public void traceScan() {
ctx.traceScan();
fast_scan_cnt++;
if ( fast_scan_cnt >=
(int)(fast_scan_time / animation_scan_time + 0.5))
fast_scan_cnt = 0;
slow_scan_cnt++;
if ( slow_scan_cnt >=
(int)(scan_time / animation_scan_time + 0.5))
slow_scan_cnt = 0;
}
int stringToType( String str) {
int idx;
if ( (idx = str.indexOf('#')) != -1)
......@@ -545,6 +574,12 @@ public class Graph implements GraphIfc, GrowApplIfc {
return scan_time;
}
public double getAnimationScanTime() {
if ( scan_time < animation_scan_time)
return scan_time;
return animation_scan_time;
}
public void setOwner( String owner) {
cmn.setOwner( owner);
}
......
......@@ -64,6 +64,7 @@ public interface GraphIfc {
public void setCurrentSlider(GrowSlider currentSlider);
public boolean isAuthorized(int access);
public double getScanTime();
public double getAnimationScanTime();
public String getCommand(String cmd);
public void setClickActive(int active);
}
......@@ -39,7 +39,7 @@ import jpwr.rt.*;
import java.io.*;
import java.util.*;
public class GrowAnnot extends GlowArrayElem {
public class GrowAnnot extends GlowArrayElem implements GrowAnnotIfc {
GrowCmn cmn;
GlowPoint p;
int adjustment;
......@@ -60,6 +60,14 @@ public class GrowAnnot extends GlowArrayElem {
trf = new GlowTransform();
}
public int type() {
return Glow.eObjectType_GrowAnnot;
}
public int getNumber() {
return number;
}
public void open(BufferedReader reader) {
String line;
StringTokenizer token;
......@@ -170,6 +178,8 @@ public class GrowAnnot extends GlowArrayElem {
int color;
int rot;
double offset_x = 0;
double offset_y = 0;
double trf_scale = trf.vertical_scale( t);
int idx = (int)( trf_scale * cmn.mw.zoom_factor_y / cmn.mw.base_zoom_factor * (text_size +4) - 3);
double tsize = trf_scale * cmn.mw.zoom_factor_y / cmn.mw.base_zoom_factor * (8+2*text_size);
......@@ -180,6 +190,11 @@ public class GrowAnnot extends GlowArrayElem {
int lfont;
int ldraw_type;
if ( node != null && ((GrowNode)node).annot_scrollingtext == number) {
offset_x = ((GrowNode)node).annot_offset_x;
offset_y = ((GrowNode)node).annot_offset_y;
}
if ( node != null && ((GrowNode)node).text_font != Glow.eFont_No) {
lfont = ((GrowNode)node).text_font;
ldraw_type = ((GrowNode)node).text_type;
......@@ -190,13 +205,13 @@ public class GrowAnnot extends GlowArrayElem {
}
if ( t == null) {
x1 = (int)( trf.x( p.x, p.y) * cmn.mw.zoom_factor_x) - cmn.mw.offset_x;
y1 = (int)( trf.y( p.x, p.y) * cmn.mw.zoom_factor_y) - cmn.mw.offset_y;
x1 = (int)( (trf.x( p.x, p.y) + offset_x) * cmn.mw.zoom_factor_x) - cmn.mw.offset_x;
y1 = (int)( (trf.y( p.x, p.y) + offset_y) * cmn.mw.zoom_factor_y) - cmn.mw.offset_y;
rot = (int) trf.rot();
}
else {
x1 = (int)( trf.x( t, p.x, p.y) * cmn.mw.zoom_factor_x) - cmn.mw.offset_x;
y1 = (int)( trf.y( t, p.x, p.y) * cmn.mw.zoom_factor_y) - cmn.mw.offset_y;
x1 = (int)( (trf.x( t, p.x, p.y) + offset_x) * cmn.mw.zoom_factor_x) - cmn.mw.offset_x;
y1 = (int)( (trf.y( t, p.x, p.y) + offset_y) * cmn.mw.zoom_factor_y) - cmn.mw.offset_y;
rot = (int) trf.rot( t);
}
rot = rot < 0 ? rot % 360 + 360 : rot % 360;
......@@ -331,4 +346,33 @@ public class GrowAnnot extends GlowArrayElem {
}
}
public GlowDimensionD getTextExtent( GlowTransform t, Object node) {
GlowDimensionD dim = new GlowDimensionD();
if ( ((GrowNode)node).annotv[number] == null || ((GrowNode)node).annotv[number].isEmpty()) {
dim.width = 0;
dim.height = 0;
return dim;
}
int z_width, z_height, descent;
double trf_scale = trf.vertical_scale( t);
int idx = (int)( trf_scale * cmn.mw.zoom_factor_y / cmn.mw.base_zoom_factor *
(text_size +4) - 4);
double tsize = trf_scale * cmn.mw.zoom_factor_y / cmn.mw.base_zoom_factor * (8+2*text_size);
if ( idx < 0) {
dim.width = 0;
dim.height = 0;
return dim;
}
idx = Math.min( idx, Glow.DRAW_TYPE_SIZE-1);
GlowDimension d = cmn.gdraw.getTextExtent( ((GrowNode)node).annotv[number], idx,
font, draw_type);
dim.width = (double)d.width / cmn.mw.zoom_factor_x;
dim.height = (double)d.height / cmn.mw.zoom_factor_y;
return dim;
}
}
/*
* Proview Open Source Process Control.
* Copyright (C) 2005-2015 SSAB EMEA AB.
*
* This file is part of Proview.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation, either version 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Proview. If not, see <http://www.gnu.org/licenses/>
*
* Linking Proview statically or dynamically with other modules is
* making a combined work based on Proview. Thus, the terms and
* conditions of the GNU General Public License cover the whole
* combination.
*
* In addition, as a special exception, the copyright holders of
* Proview give you permission to, from the build function in the
* Proview Configurator, combine Proview with modules generated by the
* Proview PLC Editor to a PLC program, regardless of the license
* terms of these modules. You may copy and distribute the resulting
* combined work under the terms of your choice, provided that every
* copy of the combined work is accompanied by a complete copy of
* the source code of Proview (the version used to produce the
* combined work), being distributed under the terms of the GNU
* General Public License plus this exception.
*/
package jpwr.jopg;
import java.io.*;
public interface GrowAnnotIfc {
public GlowDimensionD getTextExtent( GlowTransform t, Object node);
public int getNumber();
}
......@@ -328,6 +328,9 @@ public class GrowFrame extends JFrame implements GraphApplIfc, ActionListener {
localPanel.addMouseListener(adapter);
localPanel.addMouseMotionListener(adapter);
scanTime = (int) (1000 * graph.getAnimationScanTime());
System.out.println( "scanTime: " + scanTime);
timer = new Timer( scanTime, this);
timer.start();
}
......@@ -344,7 +347,7 @@ public class GrowFrame extends JFrame implements GraphApplIfc, ActionListener {
if ( scanCount == 1)
graph.gdh.getObjectRefInfoAll();
graph.ctx.traceScan();
graph.traceScan();
localPanel.repaint();
}
......
......@@ -97,6 +97,9 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
public int level_fill_drawtype;
public int level_color_tone;
public int level_direction;
public int annot_scrollingtext = -1;
public double annot_offset_x = 0;
public double annot_offset_y = 0;
GrowCmn cmn;
......@@ -415,6 +418,12 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
if ( ((GrowNode)node).invisible != 0 || invisible != 0)
return;
if ( annot_scrollingtext != -1)
cmn.gdraw.set_clip_rectangle( (int)(x_left * cmn.mw.zoom_factor_x - cmn.mw.offset_x),
(int)(y_low * cmn.mw.zoom_factor_y - cmn.mw.offset_y),
(int)(x_right * cmn.mw.zoom_factor_x - cmn.mw.offset_x),
(int)(y_high * cmn.mw.zoom_factor_y - cmn.mw.offset_y));
if ( fill_level == 1) {
if ( t != null) {
GlowTransform trf_tot = t.multiply(trf);
......@@ -563,6 +572,8 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
}
}
if ( annot_scrollingtext != -1)
cmn.gdraw.reset_clip_rectangle();
}
public int getClassTraceColor1() {
......@@ -658,6 +669,18 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
public void setAnnotation(int number, String annot) {
annotv[number] = annot;
}
public void setAnnotationTextOffset( int num, double x, double y) {
if ( annot_scrollingtext == -1)
annot_scrollingtext = num;
if ( num == annot_scrollingtext) {
annot_offset_x = x;
annot_offset_y = y;
}
}
public GlowDimensionD getAnnotationTextExtent( int num) {
return nc.getAnnotationTextExtent( trf, this, num);
}
public void setVisibility( int visibility) {
switch ( visibility) {
case Glow.eVis_Visible:
......@@ -762,6 +785,10 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
return 0;
}
void set_first_nodeclass() {
set_root_nodeclass();
}
void set_last_nodeclass() {
GlowArrayElem next;
for ( next = nc_root;
......@@ -800,6 +827,14 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
set_nodeclass( nc_root);
}
int get_animation_count() {
return nc.animation_count;
}
int get_nodeclass_dyn_attr1() {
return nc.dyn_attr[0];
}
void set_nodeclass( GlowNodeClass new_nc) {
double old_x_left, old_x_right, old_y_low, old_y_high;
......@@ -837,7 +872,7 @@ public class GrowNode extends GlowArrayElem implements GlowColorNode {
double x1, x2, y1, y2;
double rotation;
// Calculate max and min koordinates
// Calculate max and min coordinates
x1 = trf.x( 0, nc.y0);
y1 = trf.y( 0, nc.y0);
......
......@@ -26,6 +26,7 @@ local_java_sources := \
GlowPointX.java,\
GlowPointDX.java,\
GlowDimension.java,\
GlowDimensionD.java,\
GlowSliderInfo.java,\
GlowTableInfo.java,\
GlowMenuInfo.java,\
......@@ -47,6 +48,7 @@ local_java_sources := \
GlowEventTable.java,\
GrowCtxIfc.java,\
GrowCmn.java,\
GrowAnnotIfc.java,\
GlowNodeClass.java,\
GlowNodeGroup.java,\
GlowConClass.java,\
......
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