/usr/include/tulip/GlEdge.h is in libtulip-dev 4.6.0dfsg-2+b5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 | /*
*
* This file is part of Tulip (www.tulip-software.org)
*
* Authors: David Auber and the Tulip development Team
* from LaBRI, University of Bordeaux
*
* Tulip is free software; you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3
* of the License, or (at your option) any later version.
*
* Tulip 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.
*
*/
///@cond DOXYGEN_HIDDEN
#ifndef Tulip_GLEDGE_H
#define Tulip_GLEDGE_H
#ifndef DOXYGEN_NOTFOR_DEVEL
#include <tulip/PropertyTypes.h>
#include <tulip/Size.h>
#include <tulip/GlComplexeEntity.h>
#include <tulip/Matrix.h>
namespace tlp {
struct OcclusionTest;
class TextRenderer;
class GlLabel;
class EdgeExtremityGlyph;
/**
* Class to represent an edge of a graph
*/
class TLP_GL_SCOPE GlEdge : public GlComplexeEntity {
public:
/**
* Build an edge with the id : id
* id must be the id of the edge in graph
*/
GlEdge(unsigned int id);
/**
* Virtual function to accept GlSceneVisitor on this class
*/
virtual void acceptVisitor(GlSceneVisitor *visitor);
/**
* Return the edge bounding box
*/
virtual BoundingBox getBoundingBox(const GlGraphInputData* data);
/**
* Draw the edge with level of detail : lod and Camera : camera
*/
virtual void draw(float lod,const GlGraphInputData *data,Camera* camera);
/**
* Draw the label of the edge if drawEdgesLabel is true and if label selection is equal to drawSelect
* Use TextRenderer : renderer to draw the label
*/
void drawLabel(bool drawSelect,OcclusionTest* test,const GlGraphInputData* data, float lod);
/**
* Draw the label of the edge if drawEdgesLabel is true
* Use TextRenderer : renderer to draw the label
*/
void drawLabel(OcclusionTest* test,const GlGraphInputData* data);
/**
* Draw the label of the edge if drawEdgesLabel is true
* Use TextRenderer : renderer to draw the label
*/
void drawLabel(OcclusionTest* test,const GlGraphInputData* data, float lod, Camera *camera=NULL);
/**
* This function is used by the engine to get line coordinates of the edge
*/
void getVertices(const GlGraphInputData *data,std::vector<Coord> &linesCoordsArray);
/**
* This function is used by the engine to get line colors of the edge
*/
void getColors(const GlGraphInputData *data,const Coord *vertices,unsigned int numberOfVertices,std::vector<Color> &linesColorsArray);
/**
* This function is used by the engine to get line colors of the edge
*/
void getColors(const GlGraphInputData *data,const std::vector<Coord> &vertices,std::vector<Color> &linesColorsArray);
/**
* Compute the edge size
*/
void getEdgeSize(const GlGraphInputData *data,edge e,const Size &srcSize, const Size &tgtSize,const float maxSrcSize,const float maxTgtSize,Size &edgeSize);
/**
* Compute edge anchor
*/
void getEdgeAnchor(const GlGraphInputData *data,const node &source,const node &target,const LineType::RealType &bends,const Coord &srcCoord,const Coord &tgtCoord,const Size &srcSize,const Size &tgtSize, Coord &srcAnchor, Coord &tgtAnchor);
unsigned int id;
private :
static GlLabel *label;
/**
* Draw the Edge : this function is used by draw function
*/
void drawEdge(const Coord &srcNodePos, const Coord &tgtNodePos,
const Coord &startPoint, const Coord &endPoint, const LineType::RealType &bends,
const Color &startColor, const Color &endColor, const Coord &lookDir, bool colorInterpolate, const Color &borderColor,
const Size &size, int shape, bool edge3D, float lod,const std::string &textureName, const float outlineWidth);
/**
* Function used to compute bounding box for edge extremity.
*/
BoundingBox eeGlyphBoundingBox(const Coord& anchor, const Coord& tgt, float glyphNrm,
const Matrix<float, 4>& transformation, const Matrix<float, 4>& size);
/**
* Compute the edge colors and store these colors in srcCol and tgtCol
* \param data : input data used to compute edge colors
*/
void getEdgeColor(const GlGraphInputData *data,const edge &e,const node &source,const node &target, bool selected,Color &srcCol, Color &tgtCol);
/**
* Compute width lod of edge
* This lod is used to know if the edge is render in polygon mode or line mode
*/
float getEdgeWidthLod(const Coord &edgeCoord,const Size &edgeSize,Camera *camera);
/**
* Thgis function is used to render edge arrows
*/
void displayArrowAndAdjustAnchor(const GlGraphInputData *data,const edge &e,const node &source,const Size &sizeRatio,float edgeSize,const Color &color,float maxSize,bool selected,float selectionOutlineSize,
int tgtEdgeGlyph,size_t numberOfBends,const Coord &anchor,const Coord &tgtCoord,
const Coord &srcAnchor,const Coord &tgtAnchor,Coord &lineAnchor, EdgeExtremityGlyph* srcEdgeGlyph = NULL, Camera *camera = NULL);
};
}
#endif // DOXYGEN_NOTFOR_DEVEL
#endif // Tulip_GLEDGE_H
///@endcond
|