|
JavaView® v2.00.008 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Object
|
+--jv.object.PsObject
|
+--jv.project.PgGeometry
|
+--jv.geom.PgVectorField
Vector field along an associated curves or surfaces. Each vector has a point on the associated geometry as base point. The base points must be implicitly reconstructed from the associated geometry and the flag 'basedOn'.
Note, usually the vector field is also registered in the geometry.
PgPointSet, Serialized Form| Field Summary | |
static int |
ELEMENT_BASED
VectorField is given at element centers. |
protected int |
m_basedOn
Switch vertex based / element based (standard=VERTEX_BASED). |
protected PgPointSet |
m_basePoints
Associated point set containing the base points of the vectors. |
protected boolean |
m_bShowVectorArrow
Flag whether tip of vector is shown as arrow. |
protected boolean |
m_bShowVectorColors
Flag if global color of vectors used in display, applied if no individual vector coloring available. |
protected int |
m_dimOfVectors
Uniform number of components of all vectors. |
protected PdColor |
m_globalVectorColor
Global color of all vector fields used in display. |
protected PuDouble |
m_globalVectorLength
Scaling factor of all vector fields used in display. |
protected PuDouble |
m_globalVectorSize
Thickness in pixels of each vector used in display. |
protected int |
m_maxNumVectors
Number of allocated vectors in vector array. |
protected int |
m_numVectors
Number of used vectors in vector array. |
protected PgElementSet |
m_surface
Associated element set (if any). |
protected PdVector[] |
m_vector
Array of m_dim - dimensional vectors. |
protected java.awt.Color[] |
m_vectorColor
Color of each vector, usually empty array. |
static int |
VERTEX_BASED
VectorField is given at vertices. |
| Fields inherited from class jv.project.PgGeometry |
m_ambientProj, m_ambientSpace, m_authorInfo, m_bShowBndBox, m_bShowCenter, m_bShowing, m_bShowTitle, m_center, m_dim, m_dimOfSimplex, m_displayList, m_geometryInfo, m_labelAttribute, m_methodMenu, m_modelMatrix, m_title, m_version, m_versionType |
| Fields inherited from class jv.object.PsObject |
HAS_CONFIG_PANEL, HAS_INFO_PANEL, HAS_MATERIAL_PANEL, INSPECTOR_INFO, INSPECTOR_INFO_EXT, IS_DELETED, IS_FIXED, IS_SELECTED, IS_USED, m_infoPanel, m_name, m_panelList, m_parent, m_tag, m_updateList, NUM_TAGS |
| Constructor Summary | |
PgVectorField(int aVectorDim)
Constructor of an empty vector field which is VERTEX_BASED on default. |
|
PgVectorField(int aVectorDim,
int basedOn)
Constructor of an empty vector field which is VERTEX_BASED on default. |
|
| Method Summary | |
void |
assureVectorColors()
Ensure that array of colors for each vector exists and its size is equal to number of vectors. |
boolean |
blend(double s,
PgVectorField a,
double t,
PgVectorField b)
Blend between two vector fields this = s*a + t*b, e.g. used in interpolation. |
void |
clearTagVector(int anIndex,
int aTag)
|
java.lang.Object |
clone()
Duplicate geometry by recursively cloning all instance variables except inspector panels and lists of registered listeners. |
boolean |
computeGradient(PgElementSet domain,
PgPointSet image)
Compute vector field as gradient of a map from domain triangulation to R. |
void |
copy(PgGeometry aGeom)
Copy instance variables by duplication, not by copying a reference. |
int |
getBasedOn()
Get flag whether vector field is vertex or element based. |
int |
getDimOfVectors()
|
java.awt.Color |
getGlobalVectorColor()
Get global vector color which is used if no local colors are available. |
double |
getGlobalVectorLength()
Get length factor of vectors when drawn in display. |
double |
getGlobalVectorSize()
Get thickness in pixels of vectors when drawn in display. |
protected int |
getMaxNumVectors()
|
int |
getNumVectors()
|
PdVector |
getVector(int anIndex)
|
java.awt.Color[] |
getVectorColors()
|
PdVector[] |
getVectors()
Get vertex array for read and write access, but do not modify the size of any vector. |
PdVector[] |
getVertices()
|
void |
init()
Initializes and resets geometry. |
void |
makeTangent()
|
boolean |
merge(PgGeometryIf aField)
Merge vector field with current object and store union of both objects in 'this'. |
void |
paint(PvGeometryIf dc)
Major rendering method fills an internal container class supplied by the display. |
protected void |
project(int elemInd)
Projects given vector onto element plane. |
boolean |
removeVector(int anIndex)
|
void |
setBasedOn(int basedOn)
|
void |
setGeometry(PgElementSet aElementSet)
|
void |
setGeometry(PgPointSet aVertexSet)
|
void |
setGlobalVectorColor(java.awt.Color color)
Set global vector color to be used if no local colors are available. |
void |
setGlobalVectorLength(double length)
Get length factor of vectors when drawn in display. |
void |
setGlobalVectorSize(double size)
Get thickness in pixels of vectors when drawn in display. |
protected void |
setMaxNumVectors(int aNumVectors)
All vector allocation should be done in 'setMaxNumVectors' method should not be called directly, only subclass#setMaxNumVectors() may call it. |
void |
setNumVectors(int aNumVectors)
|
void |
setTagVector(int anIndex,
int aTag)
|
void |
setVector(int anIndex,
double x,
double y)
|
void |
setVector(int anIndex,
double x,
double y,
double z)
|
boolean |
setVector(int anIndex,
PdVector aVector)
|
boolean |
setVectors(PdVector[] aVectorList)
Copy all vectors of vector list to an existing array of vectors. |
java.lang.String |
toString()
Create a multi-line string representation with detailed information about all instance variables. |
boolean |
update(java.lang.Object event)
Update the class whenever a child has changed. |
| Methods inherited from class jv.object.PsObject |
addInspector, addUpdateListener, clearTag, clone, clone, copy, getFather, getInfoPanel, getInspector, getName, getNumObjects, hasInspector, hasTag, hasUpdateListener, instanceOf, instanceOf, removeInspector, removeUpdateListener, setName, setParent, setTag, updatePanels |
| Methods inherited from class java.lang.Object |
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| Methods inherited from interface jv.project.PgGeometryIf |
getInfoPanel, getName, setName |
| Methods inherited from interface jv.object.PsUpdateIf |
getFather, setParent |
| Field Detail |
protected PgPointSet m_basePoints
protected PgElementSet m_surface
public static final int VERTEX_BASED
public static final int ELEMENT_BASED
protected int m_basedOn
protected int m_dimOfVectors
protected int m_numVectors
protected int m_maxNumVectors
protected PdVector[] m_vector
getVectors() to obtain vector array.PgPointSet.getDimOfVectors(),
getVectors()protected java.awt.Color[] m_vectorColor
m_bShowVectorColorsprotected boolean m_bShowVectorArrow
protected PdColor m_globalVectorColor
protected PuDouble m_globalVectorLength
protected PuDouble m_globalVectorSize
protected boolean m_bShowVectorColors
| Constructor Detail |
public PgVectorField(int aVectorDim)
aVectorDim - uniform number of components of all vectorsPgVectorField(int, int)
public PgVectorField(int aVectorDim,
int basedOn)
The parameter 'basedOn' must be VERTEX_BASED or ELEMENT_BASED. Specifies the number of vectors this instance can hold and alters the interpretation by the viewer (VERTEX_BASED vectors are shown at the vertices, ELEMENT_BASED vectors are shown at the element centers) and possibly other classes.
aVectorDim - uniform number of components of all vectorsbasedOn - flag determining how to compute the vector base point from geometry| Method Detail |
public void init()
PgGeometryinit in class PgGeometrypublic java.lang.String toString()
toString in class PgGeometrypublic java.lang.Object clone()
null.
Tags of this object are not copied but maybe copied of subclasses.
Link to associated point set and element set is set to null.
clone in class PgGeometrycopy(PgGeometry)public void copy(PgGeometry aGeom)
copy in class PgGeometrypublic boolean update(java.lang.Object event)
update in class PgGeometryjv.object.PsUpdateIfevent - carries a lot of informationPsObject,
PsUpdateIf.getFather(),
PsUpdateIf.setParent(PsUpdateIf)public int getNumVectors()
protected int getMaxNumVectors()
public void setGeometry(PgPointSet aVertexSet)
public void setGeometry(PgElementSet aElementSet)
public int getBasedOn()
public void setBasedOn(int basedOn)
basedOn - has to be VERTEX_BASED or ELEMENT_BASED. Specifies the
number of vectors this instance can hold and alters the interpretation by the
viewer (VERTEX_BASED vectors are shown at the vertices,
ELEMENT_BASED vectors are shown at the element centers) and possibly
other classes.public double getGlobalVectorLength()
public double getGlobalVectorSize()
public java.awt.Color getGlobalVectorColor()
public void setGlobalVectorLength(double length)
public void setGlobalVectorSize(double size)
public void setGlobalVectorColor(java.awt.Color color)
public PdVector[] getVectors()
public boolean setVectors(PdVector[] aVectorList)
PgPointSet.getDimOfVectors()
of the geometry.aVectorList - array with new vectorspublic java.awt.Color[] getVectorColors()
public PdVector[] getVertices()
protected void setMaxNumVectors(int aNumVectors)
public void setNumVectors(int aNumVectors)
public void assureVectorColors()
public void paint(PvGeometryIf dc)
PgGeometryjv.project.PgGeometryIf for detailed information.paint in class PgGeometryjv.project.PgGeometryPgGeometryIf
public void clearTagVector(int anIndex,
int aTag)
public void setTagVector(int anIndex,
int aTag)
public PdVector getVector(int anIndex)
public boolean removeVector(int anIndex)
public boolean setVector(int anIndex,
PdVector aVector)
public void setVector(int anIndex,
double x,
double y)
public void setVector(int anIndex,
double x,
double y,
double z)
public boolean merge(PgGeometryIf aField)
merge in class PgGeometryaField - Vector field to be merged into 'this'true if method was successfull
public boolean blend(double s,
PgVectorField a,
double t,
PgVectorField b)
this = s*a + t*b, e.g. used in interpolation.double - s, t weights of vectors of each elementSetPgPointSet - a, b two pointSets used for blending
public boolean computeGradient(PgElementSet domain,
PgPointSet image)
As a result the current vector field is the element based gradient of the map, tangential to triangles in the domain.
PgElementSet - domain domain triangulation, may be a curved surfacePgPointSet - image vertices of point set are the image values of mappublic void makeTangent()
protected void project(int elemInd)
public int getDimOfVectors()
|
JavaView® v2.00.008 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||