-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgs9.py
executable file
·78 lines (56 loc) · 1.93 KB
/
gs9.py
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
#!/usr/bin/env python
import click
from matplotlib import cm
from glue.config import colormaps
from glue.app.qt.application import GlueApplication
from glue.viewers.image.qt import ImageViewer
from glue.viewers.image.state import ImageLayerState
from glue.core.data_factories import load_data
from glue.main import load_plugins
@click.command()
@click.argument('data', nargs=-1)
@click.option('--vmin', type=float)
@click.option('--vmax', type=float)
@click.option('--percentile', type=float)
@click.option('--stretch')
@click.option('--cmap')
def gs9(data, vmin, vmax, percentile, stretch, cmap):
load_plugins()
if cmap is not None:
for cmap_name, cmap_obj in colormaps.members:
if cmap == cmap_name:
cmap = cmap_obj
break
else:
colormaps.add(cmap, cm.get_cmap(cmap))
cmap = cm.get_cmap(cmap)
ga = GlueApplication()
image = ga.new_data_viewer(ImageViewer)
datasets = []
for filename in data:
datasets.append(load_data(filename))
# Add datasets all in one go to do all linking in one pass
ga.add_datasets(datasets)
for d in ga.data_collection:
image.add_data(d)
for layer_state in image.state.layers:
if vmin is not None:
layer_state.v_min = vmin
if vmax is not None:
layer_state.v_min = vmax
if percentile is not None:
choices = ImageLayerState.percentile.get_choices(layer_state)
for choice in choices:
if percentile == choice:
percentile = choice
break
layer_state.percentile = percentile
if stretch is not None:
layer_state.stretch = stretch
if cmap is not None:
layer_state.cmap = cmap
image.viewer_size = (600, 600)
ga.gather_current_tab()
ga.start(maximized=False, size=(1024, 768))
if __name__ == "__main__":
gs9()