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
|
/*
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"ObjectMap.h"
#include"Word.h"
#include"Symmetry.h"
typedef struct {
CObjectState State;
ObjectNameType MapName;
int MapState;
CCrystal Crystal;
int Active;
int Range[6];
float ExtentMin[3], ExtentMax[3];
int ExtentFlag;
// TODO difference between Resurface, Recolor, Refresh???
int RefreshFlag;
int ResurfaceFlag;
int RecolorFlag;
float *AtomVertex;
float CarveBuffer;
CGO *UnitCellCGO;
WordType caption;
float Corner[24];
/* not stored */
int textures[3];
CField *carvemask;
unsigned int dim[3];
Isofield *Field;
float min_max_mean_stdev[4];
float ramp_min, ramp_range;
int RampSize;
float *Ramp;
int isUpdated;
} ObjectVolumeState;
typedef struct ObjectVolume {
CObject Obj;
ObjectVolumeState *State;
int NState;
} ObjectVolume;
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, float alt_level, 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,
float alt_level, int quiet);
PyObject *ObjectVolumeAsPyList(ObjectVolume * I);
int ObjectVolumeNewFromPyList(PyMOLGlobals * G, PyObject * list, ObjectVolume ** result);
int ObjectVolumeInvalidateMapName(ObjectVolume * I, char *name);
int ObjectVolumeColor(ObjectVolume * I, float * colors, int ncolors);
CField * ObjectVolumeGetField(ObjectVolume* I);
PyObject * ObjectVolumeGetRamp(ObjectVolume* I);
int ObjectVolumeSetRamp(ObjectVolume* I, float *ramp_list, int list_size);
ObjectMapState * ObjectVolumeGetMapState(ObjectVolume * I);
#endif
|