Blame view

gui/visu_double/visu_double.py 4.71 KB
6a9e1893   Alain Klotz   Work before holli...
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
# -*- coding: utf-8 -*-
"""
Created on Thu Mar 11 15:39:17 2021

@author: alain
"""

import os
import sys
import yaml

import tkinter as tk

path = os.path.abspath("../../src")
if path not in sys.path:
        sys.path.insert(0,path)
import guitastro

# #####################################################################
# #####################################################################
# #####################################################################
# Main
# #####################################################################
# #####################################################################
# #####################################################################

if __name__ == "__main__":

    # --- Get path_images for examples
    ima = guitastro.Ima()
    path_products = ima.copy_data2products()
    fconfig = os.path.join(path_products,"visu_double.yml")
    if not os.path.exists(fconfig):
        config = {}
        conf = {}
        conf["fits_path"] = path_products
        config["visu1"] = conf
        conf = {}
        conf["fits_path"] = path_products
        config["visu2"] = conf
    else:
        with open(fconfig, 'r') as stream:
            try:
                config = yaml.safe_load(stream)
            except yaml.YAMLError as exc:
                print(exc)

    def save_config():
        global fconfig
        with open(fconfig, 'w') as yaml_file:
            yaml.dump(config, yaml_file, default_flow_style=False)

    def ima1_load():
        global widgets
        path_cur = config["visu1"]["fits_path"]
72560278   Alain Klotz   Update of Ima cla...
56
        ima1.rootdir = path_cur
6a9e1893   Alain Klotz   Work before holli...
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
        fullfile = ima1.load()
        if fullfile != "":
            path_new = os.path.dirname(fullfile)
            if path_cur != path_new and path_new != "":
                config["visu1"]["fits_path"] = path_new
                save_config()
        visu1.autocuts()
        visu1.disp()
        widgets["button_saveima_1"].configure(state= tk.NORMAL)

    def ima1_save():
        ima1.save()

    def ima2_load():
        global widgets
        path_cur = config["visu2"]["fits_path"]
72560278   Alain Klotz   Update of Ima cla...
73
        ima2.rootdir = path_cur
6a9e1893   Alain Klotz   Work before holli...
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
        fullfile = ima2.load()
        if fullfile != "":
            path_new = os.path.dirname(fullfile)
            if path_cur != path_new and path_new != "":
                config["visu2"]["fits_path"] = path_new
                save_config()
        visu2.autocuts()
        visu2.disp()
        widgets["button_saveima_2"].configure(state= tk.NORMAL)

    def ima2_save():
        ima2.save()

    # --- load an image from a FITS file
    ima1 = guitastro.Ima()
    ima1.extension = ".fit"
    ima2 = guitastro.Ima()
    ima2.extension = ".fit"

    # --- Create a simple Tk interface
    tkroot = tk.Tk()
    tkroot.geometry("1000x500+120+80")
    tkroot.title("Guitastro double visu tool")
    # ---
    frame1 = tk.Frame(tkroot)
    frame1.pack(side = tk.LEFT, fill=tk.BOTH, expand=tk.YES)
    frame2 = tk.Frame(tkroot)
    frame2.pack(side = tk.LEFT, fill=tk.BOTH, expand=tk.YES)
    # ---
    widgets = {}
    # ---
    frame1m = tk.Frame(frame1)
    widgets["button_loadima_1"] = tk.Button(frame1m, text="Load FITS", command=ima1_load)
    widgets["button_loadima_1"].pack(side=tk.LEFT, padx = 2)
    widgets["button_saveima_1"] = tk.Button(frame1m, text="Save FITS", command=ima1_save, state= tk.DISABLED)
    widgets["button_saveima_1"].pack(side=tk.LEFT, padx = 2)
    frame1m.pack(fill=tk.BOTH, expand=tk.NO)
    # ---
    frame2m = tk.Frame(frame2)
    widgets["button_loadima_2"] = tk.Button(frame2m, text="Load FITS", command=ima2_load)
    widgets["button_loadima_2"].pack(side=tk.LEFT, padx = 2)
    widgets["button_saveima_2"] = tk.Button(frame2m, text="Save FITS", command=ima2_save, state= tk.DISABLED)
    widgets["button_saveima_2"].pack(side=tk.LEFT, padx = 2)
    frame2m.pack(fill=tk.BOTH, expand=tk.NO)
    # ---
    tkroot.pack_propagate(0)
    tkroot.update()

    # --- Create and use a visu
    try:
        frame1i = tk.Frame(frame1)
        frame1i.pack(side = tk.TOP, fill=tk.BOTH, expand=tk.YES)
        visu1 = guitastro.Visu(frame1i)
        visu1.ima(ima1)
        #visu1.autocuts()
        #visu1.disp()

    except:
        msg = "{}".format(sys.exc_info())
        print(msg)

    # --- Create and use a visu
    try:
        frame2i = tk.Frame(frame2)
        frame2i.pack(side = tk.TOP, fill=tk.BOTH, expand=tk.YES)
        visu2 = guitastro.Visu(frame2i)
        visu2.ima(ima2)
        #visu2.autocuts()
        #visu2.disp()

    except:
        msg = "{}".format(sys.exc_info())
        print(msg)

    # --- Launch the event loop of the user interface
    tkroot.update()
    tkroot.mainloop()