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
|
/*
A* -------------------------------------------------------------------
B* This file contains source code for the PyMOL computer program
C* copyright (C) by Schrodinger.
D* -------------------------------------------------------------------
E* It is unlawful to modify or remove this copyright notice.
F* -------------------------------------------------------------------
G* Please see the accompanying LICENSE file for further information.
H* -------------------------------------------------------------------
I* Additional authors of this source file include:
-*
-*
-*
Z* -------------------------------------------------------------------
*/
#ifndef _H_ObjectVolume
#define _H_ObjectVolume
#include"CGO.h"
#include"ObjectMap.h"
#include"Word.h"
#include"Symmetry.h"
#include"Util2.h"
#include"Result.h"
struct ObjectVolumeState : public CObjectState {
ObjectNameType MapName;
int MapState;
CCrystal Crystal;
int Active = false;
int Range[6];
float ExtentMin[3], ExtentMax[3];
int ExtentFlag = false;
// TODO difference between Resurface, Recolor, Refresh???
int RefreshFlag;
int ResurfaceFlag = true;
int RecolorFlag = true;
pymol::vla<float> AtomVertex;
float CarveBuffer = 0.0f;
WordType caption{};
float Corner[24];
/* not stored */
pymol::cache_array<std::size_t, 3> textures{}; // 3D volume (map), 1D/2D color table, 3D carvemask
pymol::copyable_ptr<CField> carvemask;
unsigned int dim[3]{};
pymol::copyable_ptr<Isofield> Field;
float min_max_mean_stdev[4];
float ramp_min, ramp_range;
int RampSize() const { return Ramp.size() / 5; };
std::vector<float> Ramp;
int isUpdated = false;
ObjectVolumeState(PyMOLGlobals* G);
~ObjectVolumeState();
};
struct ObjectVolume : public pymol::CObject {
std::vector<ObjectVolumeState> State;
ObjectVolume(PyMOLGlobals* G);
// virtual methods
void update() override;
void render(RenderInfo* info) override;
void invalidate(cRep_t rep, cRepInv_t level, int state) override;
int getNFrame() const override;
pymol::CObject* clone() const override;
};
ObjectVolume *ObjectVolumeFromBox(PyMOLGlobals * G, ObjectVolume * obj, ObjectMap * map,
int map_state,
int state, float *mn, float *mx,
float level, int meshMode,
float carve, float *vert_vla, int quiet);
ObjectVolume *ObjectVolumeFromXtalSym(PyMOLGlobals * G, ObjectVolume * obj, ObjectMap * map,
CSymmetry * sym,
int map_state,
int state, float *mn, float *mx,
float level, int meshMode,
float carve, float *vert_vla,
int quiet);
PyObject *ObjectVolumeAsPyList(ObjectVolume * I);
int ObjectVolumeNewFromPyList(PyMOLGlobals * G, PyObject * list, ObjectVolume ** result);
int ObjectVolumeInvalidateMapName(ObjectVolume * I, const char *name, const char * new_name);
CField * ObjectVolumeGetField(ObjectVolume* I);
PyObject * ObjectVolumeGetRamp(ObjectVolume* I);
pymol::Result<> ObjectVolumeSetRamp(ObjectVolume* I, std::vector<float>&& ramp_list);
ObjectMapState * ObjectVolumeGetMapState(ObjectVolume * I);
#endif
|