Skip to content
Snippets Groups Projects
Commit 076d13f3 authored by Christophe Geuzaine's avatar Christophe Geuzaine
Browse files

progress on new post-pro

parent ae8754f8
No related branches found
No related tags found
No related merge requests found
# $Id: Makefile,v 1.135 2007-08-24 08:38:24 remacle Exp $
# $Id: Makefile,v 1.136 2007-08-24 20:14:17 geuzaine Exp $
#
# Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
#
......@@ -65,43 +65,9 @@ Context.o: Context.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
../DataStr/List.h ../DataStr/Tree.h ../DataStr/avl.h ../DataStr/Tools.h \
../DataStr/List.h ../DataStr/Tree.h ../Numeric/Numeric.h Context.h \
DefaultOptions.h GmshDefines.h Options.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Common/SmoothData.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
/sw/include/gsl/gsl_linalg.h /sw/include/gsl/gsl_mode.h \
/sw/include/gsl/gsl_permutation.h /sw/include/gsl/gsl_types.h \
/sw/include/gsl/gsl_errno.h /sw/include/gsl/gsl_check_range.h \
/sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h Trackball.h
../Post/ColorTable.h ../Common/VertexArray.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Common/SmoothData.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h Trackball.h
Octree.o: Octree.cpp Octree.h OctreeInternals.h
OctreeInternals.o: OctreeInternals.cpp Message.h OctreeInternals.h
Options.o: Options.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
......@@ -110,45 +76,12 @@ Options.o: Options.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
../Graphics/Draw.h ../Mesh/Generator.h Context.h Options.h \
../Mesh/BackgroundMesh.h ../Plugin/PluginManager.h ../Plugin/Plugin.h \
../Common/Options.h ../Common/Message.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Common/SmoothData.h \
../Numeric/Numeric.h ../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
/sw/include/gsl/gsl_linalg.h /sw/include/gsl/gsl_mode.h \
/sw/include/gsl/gsl_permutation.h /sw/include/gsl/gsl_types.h \
/sw/include/gsl/gsl_errno.h /sw/include/gsl/gsl_check_range.h \
/sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h ../Fltk/Solvers.h ../Fltk/GUI.h \
../Fltk/Opengl_Window.h ../Fltk/Colorbar_Window.h ../Common/GmshUI.h \
../Fltk/Popup_Button.h ../Fltk/SpherePosition_Widget.h
../Post/ColorTable.h ../Common/VertexArray.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Common/SmoothData.h ../Numeric/Numeric.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h ../Fltk/Solvers.h \
../Fltk/GUI.h ../Fltk/Opengl_Window.h ../Fltk/Colorbar_Window.h \
../Common/GmshUI.h ../Fltk/Popup_Button.h \
../Fltk/SpherePosition_Widget.h
CommandLine.o: CommandLine.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
../DataStr/List.h ../DataStr/Tree.h ../DataStr/avl.h ../DataStr/Tools.h \
../DataStr/List.h ../DataStr/Tree.h GmshUI.h GmshDefines.h \
......@@ -158,54 +91,19 @@ CommandLine.o: CommandLine.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
../Geo/SPoint3.h ../Geo/SBoundingBox3d.h ../Geo/SPoint3.h \
../Geo/SPoint2.h ../Geo/ExtrudeParams.h ../Common/SmoothData.h \
../Post/Views.h ../Post/ColorTable.h ../Common/VertexArray.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
/sw/include/gsl/gsl_linalg.h /sw/include/gsl/gsl_mode.h \
/sw/include/gsl/gsl_permutation.h /sw/include/gsl/gsl_types.h \
/sw/include/gsl/gsl_errno.h /sw/include/gsl/gsl_check_range.h \
/sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h ../Parser/OpenFile.h ../Parser/CreateFile.h \
../Parser/Parser.h ../Geo/GModel.h ../Geo/GVertex.h ../Geo/GEntity.h \
../Geo/Range.h ../Geo/SPoint3.h ../Geo/SBoundingBox3d.h \
../Geo/MVertex.h ../Geo/SPoint3.h ../Geo/GPoint.h ../Geo/SPoint2.h \
../Geo/GEdge.h ../Geo/GEntity.h ../Geo/GVertex.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h \
../Geo/MEdge.h ../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h \
../Geo/MFace.h ../Geo/MVertex.h ../Geo/SVector3.h ../Common/Context.h \
../Geo/ExtrudeParams.h ../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h \
../Geo/GEdgeLoop.h ../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h \
../Geo/SVector3.h ../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h \
../Geo/GEntity.h ../Geo/MElement.h ../Geo/ExtrudeParams.h \
../Geo/SBoundingBox3d.h OS.h
../Post/AdaptiveViews.h ../Common/GmshMatrix.h ../Parser/OpenFile.h \
../Parser/CreateFile.h ../Parser/Parser.h ../Geo/GModel.h \
../Geo/GVertex.h ../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SBoundingBox3d.h ../Geo/MVertex.h ../Geo/SPoint3.h \
../Geo/GPoint.h ../Geo/SPoint2.h ../Geo/GEdge.h ../Geo/GEntity.h \
../Geo/GVertex.h ../Geo/SVector3.h ../Geo/SPoint3.h ../Geo/SPoint2.h \
../Geo/MElement.h ../Geo/MVertex.h ../Geo/MEdge.h ../Geo/MVertex.h \
../Geo/SVector3.h ../Common/Hash.h ../Geo/MFace.h ../Geo/MVertex.h \
../Geo/SVector3.h ../Common/Context.h ../Geo/ExtrudeParams.h \
../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h ../Geo/GEdgeLoop.h \
../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h ../Geo/SVector3.h \
../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h ../Geo/GEntity.h \
../Geo/MElement.h ../Geo/ExtrudeParams.h ../Geo/SBoundingBox3d.h OS.h
OS.o: OS.cpp Message.h
Visibility.o: Visibility.cpp Visibility.h GmshDefines.h ../Geo/GVertex.h \
../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
......@@ -225,8 +123,8 @@ Visibility.o: Visibility.cpp Visibility.h GmshDefines.h ../Geo/GVertex.h \
../Geo/SBoundingBox3d.h ../Parser/Parser.h ../DataStr/Tree.h \
../DataStr/avl.h
Trackball.o: Trackball.cpp Trackball.h
VertexArray.o: VertexArray.cpp VertexArray.h Context.h ../DataStr/List.h \
../Numeric/Numeric.h
VertexArray.o: VertexArray.cpp VertexArray.h ../Geo/SVector3.h \
../Geo/SPoint3.h Context.h ../DataStr/List.h ../Numeric/Numeric.h
SmoothData.o: SmoothData.cpp Gmsh.h Message.h ../DataStr/Malloc.h \
../DataStr/List.h ../DataStr/Tree.h ../DataStr/avl.h ../DataStr/Tools.h \
../DataStr/List.h ../DataStr/Tree.h ../Numeric/Numeric.h SmoothData.h
......
// $Id: VertexArray.cpp,v 1.17 2006-11-27 22:22:08 geuzaine Exp $
// $Id: VertexArray.cpp,v 1.18 2007-08-24 20:14:17 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
......@@ -26,10 +26,10 @@
extern Context_T CTX;
VertexArray::VertexArray(int numNodesPerElement, int numElements)
: fill(0), _type(numNodesPerElement)
VertexArray::VertexArray(int numVerticesPerElement, int numElements)
: fill(0), _numVerticesPerElement(numVerticesPerElement)
{
int nb = (numElements ? numElements : 1) * numNodesPerElement;
int nb = (numElements ? numElements : 1) * numVerticesPerElement;
_vertices.reserve(nb * 3);
_normals.reserve(nb * 3);
_colors.reserve(nb *4);
......@@ -42,8 +42,8 @@ void VertexArray::add(float x, float y, float z, float n0, float n1, float n2,
_vertices.push_back(y);
_vertices.push_back(z);
// Warning: storing the normals as bytes WILL hurt rendering
// performance... but it reduces significantly the memory footprint.
// storing the normals as bytes hurts rendering performance, but it
// significantly reduces the memory footprint
char c0 = float2char(n0);
char c1 = float2char(n1);
char c2 = float2char(n2);
......@@ -81,6 +81,26 @@ void VertexArray::add(float x, float y, float z, unsigned int col, MElement *ele
if(ele && CTX.pick_elements) _elements.push_back(ele);
}
double BarycenterLessThan::tolerance = 0.;
void VertexArray::add(double *x, double *y, double *z, SVector3 *n,
unsigned int *col, MElement *ele, bool unique)
{
int npe = _numVerticesPerElement;
if(unique){
SPoint3 pc(0., 0., 0.);
for(int i = 0; i < npe; i++)
pc += SPoint3(x[i], y[i], z[i]);
pc /= (double)npe;
BarycenterLessThan::tolerance = 1.e-12 * CTX.lc;
if(_barycenters.find(pc) != _barycenters.end()) return;
_barycenters.insert(pc);
}
for(int i = 0; i < npe; i++)
add(x[i], y[i], z[i], n[i].x(), n[i].y(), n[i].z(), col[i], ele);
}
class AlphaElement {
public:
AlphaElement(float *vp, char *np, unsigned char *cp) : v(vp), n(np), c(cp) {}
......@@ -122,25 +142,26 @@ void VertexArray::sort(double eye[3])
// twice. We should think about a more efficient way to sort the
// three arrays in place.
AlphaElementLessThan::numVertices = getType();
AlphaElementLessThan::numVertices = getNumVerticesPerElement();
AlphaElementLessThan::eye[0] = eye[0];
AlphaElementLessThan::eye[1] = eye[1];
AlphaElementLessThan::eye[2] = eye[2];
int n = getNumVertices() / getType();
int npe = getNumVerticesPerElement();
int n = getNumVertices() / npe;
std::vector<AlphaElement> elements;
elements.reserve(n);
if(_normals.size())
for(int i = 0; i < n; i++)
elements.push_back(AlphaElement(&_vertices[3 * getType() * i],
&_normals[3 * getType() * i],
&_colors[4 * getType() * i]));
elements.push_back(AlphaElement(&_vertices[3 * npe * i],
&_normals[3 * npe * i],
&_colors[4 * npe * i]));
else
for(int i = 0; i < n; i++)
elements.push_back(AlphaElement(&_vertices[3 * getType() * i],
elements.push_back(AlphaElement(&_vertices[3 * npe * i],
0,
&_colors[4 * getType() * i]));
&_colors[4 * npe * i]));
std::sort(elements.begin(), elements.end(), AlphaElementLessThan());
......@@ -152,7 +173,7 @@ void VertexArray::sort(double eye[3])
sortedColors.reserve(_colors.size());
for(int i = 0; i < n; i++){
for(int j = 0; j < getType(); j++){
for(int j = 0; j < getNumVerticesPerElement(); j++){
for(int k = 0; k < 3; k++){
sortedVertices.push_back(elements[i].v[3 * j + k]);
if(elements[i].v)
......
......@@ -21,25 +21,42 @@
// Please report all bugs and problems to <gmsh@geuz.org>.
#include <vector>
#include <set>
#include "SVector3.h"
class MElement;
class BarycenterLessThan{
public:
static double tolerance;
bool operator()(const SPoint3 &p1, const SPoint3 &p2) const
{
if(p1.x() - p2.x() > tolerance) return true;
if(p1.x() - p2.x() < -tolerance) return false;
if(p1.y() - p2.y() > tolerance) return true;
if(p1.y() - p2.y() < -tolerance) return false;
if(p1.z() - p2.z() > tolerance) return true;
return false;
}
};
class VertexArray{
public:
int fill; // this must/will be removed
private:
int _type;
int _numVerticesPerElement;
std::vector<float> _vertices;
std::vector<char> _normals;
std::vector<unsigned char> _colors;
std::vector<MElement*> _elements;
std::set<SPoint3, BarycenterLessThan> _barycenters;
public:
VertexArray(int numNodesPerElement, int numElements);
VertexArray(int numVerticesPerElement, int numElements);
~VertexArray(){}
// returns the number of nodes in the array
// returns the number of vertices in the array
int getNumVertices() { return _vertices.size() / 3; }
// returns the type of the array
int getType() { return _type; }
// returns the number of vertices per element
int getNumVerticesPerElement() { return _numVerticesPerElement; }
// returns the number of element pointers
int getNumElementPointers() { return _elements.size(); }
// returns a pointer to the raw vertex array
......@@ -54,6 +71,11 @@ class VertexArray{
void add(float x, float y, float z, float n0, float n1, float n2,
unsigned int col, MElement *ele=0);
void add(float x, float y, float z, unsigned int col, MElement *ele=0);
// add a complete element in the arrays (if unique is set, only add
// the element if another one with the same barycenter is not
// already present)
void add(double *x, double *y, double *z, SVector3 *n, unsigned int *col,
MElement *ele=0, bool unique=true);
// sorts the elements back to front wrt the eye position
void sort(double eye[3]);
};
......
# $Id: Makefile,v 1.142 2007-08-24 08:38:24 remacle Exp $
# $Id: Makefile,v 1.143 2007-08-24 20:14:18 geuzaine Exp $
#
# Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
#
......@@ -78,41 +78,7 @@ Main.o: Main.cpp GUI.h Opengl_Window.h Colorbar_Window.h \
../Parser/OpenFile.h ../Common/CommandLine.h Solvers.h \
../Plugin/PluginManager.h ../Plugin/Plugin.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h /sw/include/gsl/gsl_linalg.h \
/sw/include/gsl/gsl_mode.h /sw/include/gsl/gsl_permutation.h \
/sw/include/gsl/gsl_types.h /sw/include/gsl/gsl_errno.h \
/sw/include/gsl/gsl_check_range.h /sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h ../Geo/GModel.h ../Geo/GVertex.h \
../Common/GmshMatrix.h ../Geo/GModel.h ../Geo/GVertex.h \
../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SBoundingBox3d.h ../Geo/MVertex.h ../Geo/SPoint3.h \
../Geo/GPoint.h ../Geo/SPoint2.h ../Geo/GEdge.h ../Geo/GEntity.h \
......@@ -124,10 +90,9 @@ Main.o: Main.cpp GUI.h Opengl_Window.h Colorbar_Window.h \
../Geo/SPoint2.h ../Geo/SVector3.h ../Geo/Pair.h ../Geo/ExtrudeParams.h \
../Geo/GRegion.h ../Geo/GEntity.h ../Geo/MElement.h \
../Geo/ExtrudeParams.h ../Geo/SBoundingBox3d.h ../Mesh/Field.h \
../contrib/ANN/include/ANN/ANN.h ../Post/OctreePost.h \
../Common/Octree.h ../Common/OctreeInternals.h ../Mesh/BackgroundMesh.h \
../Post/PView.h ../Post/AdaptiveViews.h ../Post/PViewData.h \
../Post/PViewOptions.h ../Post/ColorTable.h
../Post/OctreePost.h ../Common/Octree.h ../Common/OctreeInternals.h \
../Mesh/BackgroundMesh.h ../Post/PView.h ../Post/AdaptiveViews.h \
../Post/PViewData.h ../Post/PViewOptions.h ../Post/ColorTable.h
Message.o: Message.cpp ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/List.h ../DataStr/Tree.h \
../DataStr/avl.h ../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
......@@ -143,43 +108,9 @@ GUI.o: GUI.cpp ../Common/Gmsh.h ../Common/Message.h ../DataStr/Malloc.h \
SpherePosition_Widget.h Callbacks.h Win32Icon.h ../Parser/OpenFile.h \
../Common/CommandLine.h ../Mesh/Generator.h Solvers.h \
../Plugin/PluginManager.h ../Plugin/Plugin.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Common/SmoothData.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
/sw/include/gsl/gsl_linalg.h /sw/include/gsl/gsl_mode.h \
/sw/include/gsl/gsl_permutation.h /sw/include/gsl/gsl_types.h \
/sw/include/gsl/gsl_errno.h /sw/include/gsl/gsl_check_range.h \
/sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h Shortcut_Window.h
../Post/ColorTable.h ../Common/VertexArray.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Common/SmoothData.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h Shortcut_Window.h
GUI_Extras.o: GUI_Extras.cpp ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/List.h ../DataStr/Tree.h \
../DataStr/avl.h ../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
......@@ -233,47 +164,12 @@ Callbacks.o: Callbacks.cpp ../Common/Gmsh.h ../Common/Message.h \
../Geo/MElement.h ../Geo/ExtrudeParams.h ../Geo/SBoundingBox3d.h \
../Graphics/Draw.h ../Graphics/SelectBuffer.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h /sw/include/gsl/gsl_linalg.h \
/sw/include/gsl/gsl_mode.h /sw/include/gsl/gsl_permutation.h \
/sw/include/gsl/gsl_types.h /sw/include/gsl/gsl_errno.h \
/sw/include/gsl/gsl_check_range.h /sw/include/gsl/gsl_vector.h \
/sw/include/gsl/gsl_vector_complex_long_double.h \
/sw/include/gsl/gsl_complex.h /sw/include/gsl/gsl_vector_long_double.h \
/sw/include/gsl/gsl_block_long_double.h \
/sw/include/gsl/gsl_vector_complex.h \
/sw/include/gsl/gsl_block_complex_long_double.h \
/sw/include/gsl/gsl_vector_complex_double.h \
/sw/include/gsl/gsl_vector_double.h /sw/include/gsl/gsl_block_double.h \
/sw/include/gsl/gsl_block_complex_double.h \
/sw/include/gsl/gsl_vector_complex_float.h \
/sw/include/gsl/gsl_vector_float.h /sw/include/gsl/gsl_block_float.h \
/sw/include/gsl/gsl_block_complex_float.h \
/sw/include/gsl/gsl_vector_ulong.h /sw/include/gsl/gsl_block_ulong.h \
/sw/include/gsl/gsl_vector_long.h /sw/include/gsl/gsl_block_long.h \
/sw/include/gsl/gsl_vector_uint.h /sw/include/gsl/gsl_block_uint.h \
/sw/include/gsl/gsl_vector_int.h /sw/include/gsl/gsl_block_int.h \
/sw/include/gsl/gsl_vector_ushort.h /sw/include/gsl/gsl_block_ushort.h \
/sw/include/gsl/gsl_vector_short.h /sw/include/gsl/gsl_block_short.h \
/sw/include/gsl/gsl_vector_uchar.h /sw/include/gsl/gsl_block_uchar.h \
/sw/include/gsl/gsl_vector_char.h /sw/include/gsl/gsl_block_char.h \
/sw/include/gsl/gsl_matrix.h \
/sw/include/gsl/gsl_matrix_complex_long_double.h \
/sw/include/gsl/gsl_matrix_complex_double.h \
/sw/include/gsl/gsl_matrix_complex_float.h \
/sw/include/gsl/gsl_matrix_long_double.h \
/sw/include/gsl/gsl_matrix_double.h /sw/include/gsl/gsl_matrix_float.h \
/sw/include/gsl/gsl_matrix_ulong.h /sw/include/gsl/gsl_matrix_long.h \
/sw/include/gsl/gsl_matrix_uint.h /sw/include/gsl/gsl_matrix_int.h \
/sw/include/gsl/gsl_matrix_ushort.h /sw/include/gsl/gsl_matrix_short.h \
/sw/include/gsl/gsl_matrix_uchar.h /sw/include/gsl/gsl_matrix_char.h \
/sw/include/gsl/gsl_blas.h /sw/include/gsl/gsl_blas_types.h \
/sw/include/gsl/gsl_cblas.h ../Parser/CreateFile.h ../Parser/OpenFile.h \
../Common/GmshMatrix.h ../Parser/CreateFile.h ../Parser/OpenFile.h \
../Common/CommandLine.h ../Common/Options.h GUI.h Opengl_Window.h \
Colorbar_Window.h Popup_Button.h SpherePosition_Widget.h GUI_Extras.h \
Callbacks.h ../Plugin/Plugin.h ../Plugin/PluginManager.h \
../Plugin/Plugin.h ../Common/Visibility.h ../Common/GmshDefines.h \
Solvers.h ../Common/OS.h ../Mesh/Field.h \
../contrib/ANN/include/ANN/ANN.h ../Post/OctreePost.h \
Solvers.h ../Common/OS.h ../Mesh/Field.h ../Post/OctreePost.h \
../Common/Octree.h ../Common/OctreeInternals.h ../Mesh/BackgroundMesh.h
Opengl.o: Opengl.cpp ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/List.h ../DataStr/Tree.h \
......
# $Id: Makefile,v 1.157 2007-08-21 19:05:39 geuzaine Exp $
# $Id: Makefile,v 1.158 2007-08-24 20:14:18 geuzaine Exp $
#
# Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
#
......@@ -75,7 +75,8 @@ GEntity.o: GEntity.cpp GEntity.h Range.h SPoint3.h SBoundingBox3d.h \
SPoint2.h SVector3.h MElement.h MEdge.h ../Common/Hash.h MFace.h \
../Numeric/Numeric.h ../Common/Context.h ../DataStr/List.h \
ExtrudeParams.h ../Common/SmoothData.h GFace.h GEdgeLoop.h Pair.h \
GRegion.h ../Common/VertexArray.h ../Common/Message.h ../Common/OS.h
GRegion.h ../Common/VertexArray.h ../Geo/SVector3.h ../Common/Message.h \
../Common/OS.h
GVertex.o: GVertex.cpp GVertex.h GEntity.h Range.h SPoint3.h \
SBoundingBox3d.h ../Common/GmshDefines.h MVertex.h GPoint.h SPoint2.h \
GFace.h GEdgeLoop.h GEdge.h SVector3.h MElement.h MEdge.h \
......@@ -186,12 +187,12 @@ GModel.o: GModel.cpp GModel.h GVertex.h GEntity.h Range.h SPoint3.h \
../Numeric/Numeric.h ../Common/Context.h ../DataStr/List.h \
ExtrudeParams.h ../Common/SmoothData.h GFace.h GEdgeLoop.h Pair.h \
GRegion.h gmshSurface.h ../Mesh/Field.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h ../Geo/Geo.h ../Geo/gmshSurface.h \
../DataStr/Tree.h ../DataStr/avl.h ../Geo/SPoint2.h \
../Geo/ExtrudeParams.h ../Geo/GEdge.h ../Post/OctreePost.h \
../Common/Octree.h ../Common/OctreeInternals.h MRep.h \
../Common/Message.h ../Common/OS.h ../Mesh/BackgroundMesh.h
../Post/ColorTable.h ../Common/VertexArray.h ../Geo/SVector3.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h ../Geo/Geo.h \
../Geo/gmshSurface.h ../DataStr/Tree.h ../DataStr/avl.h \
../Geo/SPoint2.h ../Geo/ExtrudeParams.h ../Geo/GEdge.h \
../Post/OctreePost.h ../Common/Octree.h ../Common/OctreeInternals.h \
MRep.h ../Common/Message.h ../Common/OS.h ../Mesh/BackgroundMesh.h
GModelIO_Geo.o: GModelIO_Geo.cpp GModel.h GVertex.h GEntity.h Range.h \
SPoint3.h SBoundingBox3d.h ../Common/GmshDefines.h MVertex.h GPoint.h \
SPoint2.h GEdge.h SVector3.h MElement.h MEdge.h ../Common/Hash.h \
......
......@@ -44,6 +44,7 @@ class SPoint3 {
void operator+=(const SPoint3 &p);
void operator-=(const SPoint3 &p);
void operator*=(double mult);
void operator/=(double mult);
SPoint3 operator*(double mult);
operator double *() { return P; }
};
......@@ -84,6 +85,9 @@ inline void SPoint3::operator-=(const SPoint3 &p)
inline void SPoint3::operator*=(double mult)
{ P[0] *= mult; P[1] *= mult; P[2] *= mult; }
inline void SPoint3::operator/=(double div)
{ P[0] /= div; P[1] /= div; P[2] /= div; }
inline SPoint3 SPoint3::operator*(double mult)
{ return SPoint3(P[0] * mult, P[1] * mult, P[2] * mult); }
......
// $Id: Draw.cpp,v 1.110 2007-08-21 19:05:39 geuzaine Exp $
// $Id: Draw.cpp,v 1.111 2007-08-24 20:14:18 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
......@@ -77,8 +77,8 @@ void Draw3d(void)
InitPosition();
Draw_Geom();
Draw_Mesh();
Draw_Post_Old();
Draw_Post();
Draw_Post_New();
}
void Draw2d(void)
......
......@@ -55,8 +55,8 @@ void Draw_String_Center(char *s);
void Draw_String_Right(char *s);
void Draw_Geom(void);
void Draw_Mesh(void);
void Draw_Post(void);
void Draw_Post_New();
void Draw_Post_Old(void);
void Draw_Post();
void Draw_Graph2D(void);
void Draw_Text2D(void);
void Draw_Text2D3D(int dim, int timestep, int nb, List_T *td, List_T *tc);
......
This diff is collapsed.
// $Id: Mesh.cpp,v 1.200 2007-08-21 19:05:39 geuzaine Exp $
// $Id: Mesh.cpp,v 1.201 2007-08-24 20:14:18 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
......@@ -474,11 +474,11 @@ static void drawArrays(GEntity *e, VertexArray *va, GLint type, bool useNormalAr
// draw each one separately
if(CTX.render_mode == GMSH_SELECT && CTX.pick_elements) {
if(va->getNumElementPointers() == va->getNumVertices()){
for(int i = 0; i < va->getNumVertices(); i += va->getType()){
glPushName(va->getType());
for(int i = 0; i < va->getNumVertices(); i += va->getNumVerticesPerElement()){
glPushName(va->getNumVerticesPerElement());
glPushName(i);
glBegin(type);
for(int j = 0; j < va->getType(); j++)
for(int j = 0; j < va->getNumVerticesPerElement(); j++)
glVertex3fv(va->getVertexArray(3 * (i + j)));
glEnd();
glPopName();
......@@ -518,7 +518,7 @@ static void drawArrays(GEntity *e, VertexArray *va, GLint type, bool useNormalAr
glColor4ubv((GLubyte *) & color);
}
if(va->getType() > 2 && !drawOutline && CTX.polygon_offset)
if(va->getNumVerticesPerElement() > 2 && !drawOutline && CTX.polygon_offset)
glEnable(GL_POLYGON_OFFSET_FILL);
if(drawOutline)
......
This diff is collapsed.
// $Id: Post_New.cpp,v 1.1 2007-08-21 19:05:39 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
// 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 this program; if not, write to the Free Software
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
// USA.
//
// Please report all bugs and problems to <gmsh@geuz.org>.
#include "Gmsh.h"
#include "GmshUI.h"
#include "Numeric.h"
#include "Draw.h"
#include "PView.h"
#include "Context.h"
#include "gl2ps.h"
void addElementsInArrays(PView *p)
{
}
void drawArrays(PView *p)
{
/*
double x[20], y[20], z[20];
for(int i = 0; i < data->getNumElements(); i++){
int n = data->getNumNodes(i);
for(int j = 0; j < n; j++)
data->getNode(i, j, x[j], y[j], z[j]);
if(n == 3){
glColor3d(1, 0, 0);
glBegin(GL_TRIANGLES);
glVertex3d(x[0], y[0], z[0]);
glVertex3d(x[1], y[1], z[1]);
glVertex3d(x[2], y[2], z[2]);
glEnd();
}
}
*/
}
// We try to estimate how many primitives will end up in the vertex
// arrays, since reallocating the arrays takes a HUGE amount of time
// on Windows/Cygwin. A better way would be to slightly redesign the
// drawing routines so we can have different pre-processing steps
// (like the one we have for smooth normals right now), in order to
// count how many primitives we will have.
static int estimateNumTriangles(PView *p)
{
PViewData *dat = p->getData();
int tris = dat->getNumTriangles();
int quads = dat->getNumQuadrangles();
int tets = dat->getNumTetrahedra();
int prisms = dat->getNumPrisms();
int pyrs = dat->getNumPyramids();
int hexas = dat->getNumHexahedra();
PViewOptions *opt = p->getOptions();
int heuristic = 0;
if(opt->IntervalsType == PViewOptions::Iso)
heuristic = (tets + prisms + pyrs + hexas) / 10;
else if(opt->IntervalsType == PViewOptions::Continuous)
heuristic = (tris + 2 * quads + 6 * tets +
8 * prisms + 6 * pyrs + 12 * hexas);
else if(opt->IntervalsType == PViewOptions::Discrete)
heuristic = (tris + 2 * quads + 6 * tets +
8 * prisms + 6 * pyrs + 12 * hexas) * 2;
return heuristic + 10000;
}
static int estimateNumLines(PView *p)
{
return 10000;
}
class initPView {
public :
void operator () (PView *p)
{
PViewData *data = p->getData();
PViewOptions *opt = p->getOptions();
if(!p->getChanged() || p->getDirty() || !opt->Visible) return;
if(p->va_lines) delete p->va_lines;
p->va_lines = new VertexArray(2, estimateNumLines(p));
if(p->va_triangles) delete p->va_triangles;
p->va_lines = new VertexArray(3, estimateNumTriangles(p));
addElementsInArrays(p);
p->setChanged(false);
}
};
class drawPView {
public :
void operator () (PView *p)
{
PViewData *data = p->getData();
PViewOptions *opt = p->getOptions();
if(!opt->Visible) return;
glPointSize(opt->PointSize);
gl2psPointSize(opt->PointSize * CTX.print.eps_point_size_factor);
glLineWidth(opt->LineWidth);
gl2psLineWidth(opt->LineWidth * CTX.print.eps_line_width_factor);
if(opt->LightTwoSide)
glLightModelf(GL_LIGHT_MODEL_TWO_SIDE, GL_TRUE);
else
glLightModelf(GL_LIGHT_MODEL_TWO_SIDE, GL_FALSE);
for(int i = 0; i < 6; i++)
if(CTX.clip[i] & (1 << (2 + p->getIndex())))
glEnable((GLenum)(GL_CLIP_PLANE0 + i));
else
glDisable((GLenum)(GL_CLIP_PLANE0 + i));
drawArrays(p);
}
};
class drawPViewBoundingBox {
public :
void operator () (PView *p)
{
PViewData *data = p->getData();
PViewOptions *opt = p->getOptions();
if(!opt->Visible || opt->Type != PViewOptions::Plot3D) return;
glColor4ubv((GLubyte *) & CTX.color.fg);
glLineWidth(CTX.line_width);
gl2psLineWidth(CTX.line_width * CTX.print.eps_line_width_factor);
SBoundingBox3d bb = data->getBoundingBox();
Draw_Box(bb.min().x(), bb.min().y(), bb.min().z(),
bb.max().x(), bb.max().y(), bb.max().z());
glColor3d(1., 0., 0.);
for(int i = 0; i < 6; i++)
if(CTX.clip[i] & (1 << (2 + p->getIndex())))
Draw_PlaneInBoundingBox(bb.min().x(), bb.min().y(), bb.min().z(),
bb.max().x(), bb.max().y(), bb.max().z(),
CTX.clip_plane[i][0], CTX.clip_plane[i][1],
CTX.clip_plane[i][2], CTX.clip_plane[i][3]);
}
};
void Draw_Post_New()
{
// draw any plugin-specific stuff
if(CTX.post.plugin_draw_function)
(*CTX.post.plugin_draw_function)();
if(PView::list.empty()) return;
if(CTX.draw_bbox || !CTX.post.draw)
std::for_each(PView::list.begin(), PView::list.end(), drawPViewBoundingBox());
if(!CTX.post.draw) return;
if(!CTX.threads_lock){
CTX.threads_lock = 1;
// recompute graphics data if we need to
std::for_each(PView::list.begin(), PView::list.end(), initPView());
std::for_each(PView::list.begin(), PView::list.end(), drawPView());
CTX.threads_lock = 0;
}
}
This diff is collapsed.
# $Id: Makefile,v 1.178 2007-07-31 22:09:11 geuzaine Exp $
# $Id: Makefile,v 1.179 2007-08-24 20:14:18 geuzaine Exp $
#
# Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
#
......@@ -80,22 +80,22 @@ Generator.o: Generator.cpp ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/List.h ../DataStr/Tree.h \
../DataStr/avl.h ../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
../Numeric/Numeric.h ../Common/Context.h ../Post/Views.h \
../Post/ColorTable.h ../Common/VertexArray.h ../Common/SmoothData.h \
../Post/AdaptiveViews.h ../Common/GmshMatrix.h ../Common/OS.h \
../Geo/GModel.h ../Geo/GVertex.h ../Geo/GEntity.h ../Geo/Range.h \
../Geo/SPoint3.h ../Geo/SBoundingBox3d.h ../Geo/SPoint3.h \
../Common/GmshDefines.h ../Geo/MVertex.h ../Geo/SPoint3.h \
../Geo/GPoint.h ../Geo/SPoint2.h ../Geo/GEdge.h ../Geo/GEntity.h \
../Geo/GVertex.h ../Geo/SVector3.h ../Geo/SPoint3.h ../Geo/SPoint3.h \
../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h ../Geo/MEdge.h \
../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h ../Geo/MFace.h \
../Geo/MVertex.h ../Geo/SVector3.h ../Geo/ExtrudeParams.h \
../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h ../Geo/GEdgeLoop.h \
../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h ../Geo/SVector3.h \
../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h ../Geo/GEntity.h \
../Geo/MElement.h ../Geo/ExtrudeParams.h ../Geo/SBoundingBox3d.h \
meshGEdge.h meshGFace.h meshGRegion.h BackgroundMesh.h BoundaryLayer.h \
HighOrder.h
../Post/ColorTable.h ../Common/VertexArray.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Common/SmoothData.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h ../Common/OS.h ../Geo/GModel.h ../Geo/GVertex.h \
../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SBoundingBox3d.h ../Geo/SPoint3.h ../Common/GmshDefines.h \
../Geo/MVertex.h ../Geo/SPoint3.h ../Geo/GPoint.h ../Geo/SPoint2.h \
../Geo/GEdge.h ../Geo/GEntity.h ../Geo/GVertex.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h \
../Geo/MEdge.h ../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h \
../Geo/MFace.h ../Geo/MVertex.h ../Geo/SVector3.h \
../Geo/ExtrudeParams.h ../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h \
../Geo/GEdgeLoop.h ../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h \
../Geo/SVector3.h ../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h \
../Geo/GEntity.h ../Geo/MElement.h ../Geo/ExtrudeParams.h \
../Geo/SBoundingBox3d.h meshGEdge.h meshGFace.h meshGRegion.h \
BackgroundMesh.h BoundaryLayer.h HighOrder.h
Field.o: Field.cpp ../Mesh/BDS.h ../Geo/GFace.h ../Geo/GPoint.h \
../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SBoundingBox3d.h ../Geo/SPoint3.h ../Common/GmshDefines.h \
......@@ -305,16 +305,17 @@ BackgroundMesh.o: BackgroundMesh.cpp ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/List.h ../DataStr/Tree.h \
../DataStr/avl.h ../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
../Post/Views.h ../Post/ColorTable.h ../Common/VertexArray.h \
../Common/SmoothData.h ../Numeric/Numeric.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h BackgroundMesh.h ../Common/Context.h \
../Post/OctreePost.h ../Common/Octree.h ../Common/OctreeInternals.h \
../Geo/GVertex.h ../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SVector3.h ../Geo/SPoint3.h ../Common/SmoothData.h \
../Numeric/Numeric.h ../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
BackgroundMesh.h ../Common/Context.h ../Post/OctreePost.h \
../Common/Octree.h ../Common/OctreeInternals.h ../Geo/GVertex.h \
../Geo/GEntity.h ../Geo/Range.h ../Geo/SPoint3.h \
../Geo/SBoundingBox3d.h ../Geo/SPoint3.h ../Common/GmshDefines.h \
../Geo/MVertex.h ../Geo/SPoint3.h ../Geo/GPoint.h ../Geo/SPoint2.h \
../Geo/GEdge.h ../Geo/GEntity.h ../Geo/GVertex.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Geo/SPoint3.h ../Geo/SPoint2.h ../Geo/MElement.h \
../Geo/MVertex.h ../Geo/MEdge.h ../Geo/MVertex.h ../Geo/SVector3.h \
../Common/Hash.h ../Geo/MFace.h ../Geo/MVertex.h ../Geo/SVector3.h \
../Geo/SPoint3.h ../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h \
../Geo/MEdge.h ../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h \
../Geo/MFace.h ../Geo/MVertex.h ../Geo/SVector3.h \
../Geo/ExtrudeParams.h ../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h \
../Geo/GEdgeLoop.h ../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h \
../Geo/SVector3.h ../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GModel.h \
......
# $Id: Makefile,v 1.123 2007-08-21 19:05:43 geuzaine Exp $
# $Id: Makefile,v 1.124 2007-08-24 20:14:18 geuzaine Exp $
#
# Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
#
......@@ -79,24 +79,25 @@ depend:
Gmsh.tab.o: Gmsh.tab.cpp ../Plugin/PluginManager.h ../Plugin/Plugin.h \
../Common/Options.h ../Common/Message.h ../Post/Views.h \
../Post/ColorTable.h ../DataStr/List.h ../Common/VertexArray.h \
../Common/SmoothData.h ../Numeric/Numeric.h ../Post/AdaptiveViews.h \
../Common/GmshMatrix.h ../Parallel/ParUtil.h ../Common/Gmsh.h \
../Common/Message.h ../DataStr/Malloc.h ../DataStr/Tree.h \
../DataStr/avl.h ../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
../Geo/SVector3.h ../Geo/SPoint3.h ../Common/SmoothData.h \
../Numeric/Numeric.h ../Post/AdaptiveViews.h ../Common/GmshMatrix.h \
../Parallel/ParUtil.h ../Common/Gmsh.h ../Common/Message.h \
../DataStr/Malloc.h ../DataStr/Tree.h ../DataStr/avl.h \
../DataStr/Tools.h ../DataStr/List.h ../DataStr/Tree.h \
../Common/Context.h ../Geo/GModel.h ../Geo/GVertex.h ../Geo/GEntity.h \
../Geo/Range.h ../Geo/SPoint3.h ../Geo/SBoundingBox3d.h \
../Geo/SPoint3.h ../Common/GmshDefines.h ../Geo/MVertex.h \
../Geo/SPoint3.h ../Geo/GPoint.h ../Geo/SPoint2.h ../Geo/GEdge.h \
../Geo/GEntity.h ../Geo/GVertex.h ../Geo/SVector3.h ../Geo/SPoint3.h \
../Geo/SPoint3.h ../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h \
../Geo/MEdge.h ../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h \
../Geo/MFace.h ../Geo/MVertex.h ../Geo/SVector3.h \
../Geo/ExtrudeParams.h ../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h \
../Geo/GEdgeLoop.h ../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h \
../Geo/SVector3.h ../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h \
../Geo/GEntity.h ../Geo/MElement.h ../Geo/ExtrudeParams.h \
../Geo/SBoundingBox3d.h ../Geo/Geo.h ../Geo/gmshSurface.h ../Geo/Pair.h \
../Geo/Range.h ../Geo/SPoint2.h ../Geo/SPoint3.h ../Geo/SVector3.h \
../Geo/SPoint2.h ../Geo/MElement.h ../Geo/MVertex.h ../Geo/MEdge.h \
../Geo/MVertex.h ../Geo/SVector3.h ../Common/Hash.h ../Geo/MFace.h \
../Geo/MVertex.h ../Geo/SVector3.h ../Geo/ExtrudeParams.h \
../Geo/GFace.h ../Geo/GPoint.h ../Geo/GEntity.h ../Geo/GEdgeLoop.h \
../Geo/GEdge.h ../Geo/MElement.h ../Geo/SPoint2.h ../Geo/SVector3.h \
../Geo/Pair.h ../Geo/ExtrudeParams.h ../Geo/GRegion.h ../Geo/GEntity.h \
../Geo/MElement.h ../Geo/ExtrudeParams.h ../Geo/SBoundingBox3d.h \
../Geo/Geo.h ../Geo/gmshSurface.h ../Geo/Pair.h ../Geo/Range.h \
../Geo/SPoint2.h ../Geo/SPoint3.h ../Geo/SVector3.h \
../Geo/SBoundingBox3d.h ../Geo/SPoint2.h ../Geo/ExtrudeParams.h \
../Geo/GeoInterpolation.h ../Geo/Geo.h ../Mesh/Generator.h \
../Graphics/Draw.h ../Common/Colors.h ../Common/Options.h Parser.h \
......
// $Id: OpenFile.cpp,v 1.151 2007-08-21 19:05:43 geuzaine Exp $
// $Id: OpenFile.cpp,v 1.152 2007-08-24 20:14:18 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
......@@ -389,9 +389,8 @@ int MergeFile(char *name, int warn_if_missing)
}
else if(!strncmp(header, "$PostFormat", 11) ||
!strncmp(header, "$View", 5)) {
#if 0 // FIXME: test new post-pro
#if 0 // test new post-pro
PView *p = new PView(false);
PView::list.push_back(p);
status = p->getData()->read(name);
#else
status = ReadView(name);
......
This diff is collapsed.
This diff is collapsed.
......@@ -41,9 +41,6 @@ class PView{
int _aliasOf;
// flag to mark that some other views link to this one
bool _links;
// flag to mark that this view is 'dirty' and should not be
// displayed
bool _dirty;
// name of the view
std::string _name;
// name of the file the view was loaded from
......@@ -54,17 +51,21 @@ class PView{
PViewData *_data;
public:
PView(bool allocate=true) :
_num(0), _index(0), _changed(false), _aliasOf(-1), _links(false),
_dirty(true), _name(""), _filename(""), _options(0), _data(0),
va_lines(0), va_triangles(0), normals(0), adaptive(0)
_num(0), _index(0), _changed(true), _aliasOf(-1), _links(false),
_name(""), _filename(""), _options(0), _data(0),
va_points(0), va_lines(0), va_triangles(0), normals(0), adaptive(0)
{
_data = new PViewDataList(allocate);
_options = new PViewOptions;
list.push_back(this);
// reset indices
for(unsigned int i = 0; i < list.size(); i++) list[i]->setIndex(i);
}
~PView()
{
if(_options) delete _options;
if(_data) delete _data;
if(va_points) delete va_points;
if(va_lines) delete va_lines;
if(va_triangles) delete va_triangles;
if(normals) delete normals;
......@@ -80,8 +81,6 @@ class PView{
void setIndex(int val){ _index = val; }
bool getChanged(){ return _changed; }
void setChanged(bool val){ _changed = val; }
bool getDirty(){ return _dirty; }
void setDirty(bool val){ _dirty = val; }
void setGlobalResolutionLevel(int level)
{
//if(adaptive) adaptive->setGlobalResolutionLevel(this, level);
......@@ -92,7 +91,7 @@ class PView{
}
// vertex arrays to draw triangles and lines efficiently
VertexArray *va_lines, *va_triangles;
VertexArray *va_points, *va_lines, *va_triangles;
// smoothed normals
smooth_normals *normals;
// adaptative rendering for high-order datasets
......
// $Id: PViewData.cpp,v 1.1 2007-08-21 19:05:43 geuzaine Exp $
// $Id: PViewData.cpp,v 1.2 2007-08-24 20:14:19 geuzaine Exp $
//
// Copyright (C) 1997-2007 C. Geuzaine, J.-F. Remacle
//
......@@ -114,6 +114,20 @@ void PViewDataList::finalize()
List_Add(Time, &d);
}
}
setDirty(false);
}
double PViewDataList::getMin(int step)
{
if(step < 0) return Min;
return TimeStepMin[step];
}
double PViewDataList::getMax(int step)
{
if(step < 0) return Max;
return TimeStepMax[step];
}
void PViewDataList::_stat(List_T *D, List_T *C, int nb)
......@@ -306,7 +320,7 @@ int PViewDataList::getNumComponents(int ele)
return _lastNumComponents;
}
void PViewDataList::getValue(int ele, int nod, int step, int comp, double &val)
void PViewDataList::getValue(int ele, int nod, int comp, int step, double &val)
{
if(ele != _lastElement) _setLast(ele);
val = _lastVal[step * _lastNumNodes * _lastNumComponents +
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment