LSST Applications g180d380827+78227d2bc4,g2079a07aa2+86d27d4dc4,g2305ad1205+bdd7851fe3,g2bbee38e9b+c6a8a0fb72,g337abbeb29+c6a8a0fb72,g33d1c0ed96+c6a8a0fb72,g3a166c0a6a+c6a8a0fb72,g3d1719c13e+260d7c3927,g3ddfee87b4+723a6db5f3,g487adcacf7+29e55ea757,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+9443c4b912,g62aa8f1a4b+7e2ea9cd42,g858d7b2824+260d7c3927,g864b0138d7+8498d97249,g95921f966b+dffe86973d,g991b906543+260d7c3927,g99cad8db69+4809d78dd9,g9c22b2923f+e2510deafe,g9ddcbc5298+9a081db1e4,ga1e77700b3+03d07e1c1f,gb0e22166c9+60f28cb32d,gb23b769143+260d7c3927,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e22341fd87,gbd998247f1+585e252eca,gc120e1dc64+713f94b854,gc28159a63d+c6a8a0fb72,gc3e9b769f7+385ea95214,gcf0d15dbbd+723a6db5f3,gdaeeff99f8+f9a426f77a,ge6526c86ff+fde82a80b9,ge79ae78c31+c6a8a0fb72,gee10cc3b42+585e252eca,w.2024.18
LSST Data Management Base Package
Loading...
Searching...
No Matches
ds9Regions.py
Go to the documentation of this file.
1# This file is part of afw.
2#
3# Developed for the LSST Data Management System.
4# This product includes software developed by the LSST Project
5# (https://www.lsst.org).
6# See the COPYRIGHT file at the top-level directory of this distribution
7# for details of code ownership.
8#
9# This program is free software: you can redistribute it and/or modify
10# it under the terms of the GNU General Public License as published by
11# the Free Software Foundation, either version 3 of the License, or
12# (at your option) any later version.
13#
14# This program is distributed in the hope that it will be useful,
15# but WITHOUT ANY WARRANTY; without even the implied warranty of
16# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17# GNU General Public License for more details.
18#
19# You should have received a copy of the GNU General Public License
20# along with this program. If not, see <https://www.gnu.org/licenses/>.
21
22import math
23import re
24import lsst.afw.geom as afwGeom
25
26
27def dot(symb, c, r, size, ctype=None, fontFamily="helvetica", textAngle=None):
28 """Draw a symbol onto the specified DS9 frame.
29
30 Parameters
31 ----------
32 symb
33 Possible values are:
34
35 ``"+"``
36 Draw a +
37 ``"x"``
38 Draw an x
39 ``"*"``
40 Draw a *
41 ``"o"``
42 Draw a circle
43 ``"@:Mxx,Mxy,Myy"``
44 Draw an ellipse with moments (Mxx, Mxy, Myy) (argument size is ignored)
45 `lsst.afw.geom.ellipses.BaseCore`
46 Draw the ellipse (argument size is ignored). N.b. objects
47 derived from `~lsst.afw.geom.ellipses.BaseCore` include
48 `~lsst.afw.geom.ellipses.Axes` and `~lsst.afw.geom.ellipses.Quadrupole`.
49 Any other value
50 Interpreted as a string to be drawn. Strings obey the ``fontFamily``
51 (which may be extended with other characteristics, e.g. "times
52 bold italic". Text will be drawn rotated by ``textAngle``
53 (textAngle is ignored otherwise).
54 c, r
55 Zero-based coordinates at which to draw the symbol
56 size
57 ctype : `str`
58 the name of the desired color (e.g. 'red', 'orchid')
59 fontFamily
60 textAngle
61 """
62 if ctype is None:
63 color = "" # the default
64 else:
65 color = ' # color=%s' % ctype
66
67 regions = []
68
69 r += 1
70 c += 1 # ds9 uses 1-based coordinates
71 if isinstance(symb, afwGeom.ellipses.Axes):
72 regions.append('ellipse %g %g %gi %gi %g%s' % (c, r, symb.getA(), symb.getB(),
73 math.degrees(symb.getTheta()), color))
74 elif symb == '+':
75 regions.append('line %g %g %g %g%s' % (c, r+size, c, r-size, color))
76 regions.append('line %g %g %g %g%s' % (c-size, r, c+size, r, color))
77 elif symb == 'x':
78 size = size/math.sqrt(2)
79 regions.append('line %g %g %g %g%s' %
80 (c+size, r+size, c-size, r-size, color))
81 regions.append('line %g %g %g %g%s' %
82 (c-size, r+size, c+size, r-size, color))
83 elif symb == '*':
84 size30 = 0.5*size
85 size60 = 0.5*math.sqrt(3)*size
86 regions.append('line %g %g %g %g%s' % (c+size, r, c-size, r, color))
87 regions.append('line %g %g %g %g%s' %
88 (c-size30, r+size60, c+size30, r-size60, color))
89 regions.append('line %g %g %g %g%s' %
90 (c+size30, r+size60, c-size30, r-size60, color))
91 elif symb == 'o':
92 regions.append('circle %g %g %gi%s' % (c, r, size, color))
93 else:
94 color = re.sub("^ # ", "", color) # skip the leading " # "
95
96 angle = ""
97 if textAngle is not None:
98 angle += " textangle=%.1f"%(textAngle)
99
100 font = ""
101 if size != 2 or fontFamily != "helvetica":
102 fontFamily = fontFamily.split()
103 font += ' font="%s %d' % (fontFamily.pop(0),
104 int(10*size/2.0 + 0.5))
105 if not fontFamily:
106 # appears to be needed at least for 7.4b1
107 fontFamily = ["normal"]
108 font += " " + " ".join(fontFamily)
109 font += '"'
110 extra = ""
111 if color or angle or font:
112 extra = " # "
113 extra += color
114 extra += angle
115 extra += font
116
117 regions.append('text %g %g \"%s\"%s' % (c, r, symb, extra))
118
119 return regions
120
121
122def drawLines(points, ctype=None):
123 """Draw a line by connecting the points
124
125 Parameters
126 ----------
127 points : `list` of `tuple` of `float`
128 a list of (col,row)
129 ctype : `str`
130 the name of the desired color (e.g. 'red', 'orchid')
131 """
132
133 if ctype is None: # default
134 color = ""
135 else:
136 color = f"# color={ctype}"
137
138 regions = []
139 if len(points) > 0:
140 c0, r0 = points[0]
141 r0 += 1
142 c0 += 1 # ds9 uses 1-based coordinates
143 for (c, r) in points[1:]:
144 r += 1
145 c += 1 # ds9 uses 1-based coordinates
146 regions.append('line %g %g %g %g %s' % (c0, r0, c, r, color))
147 c0, r0 = c, r
148
149 return regions
dot(symb, c, r, size, ctype=None, fontFamily="helvetica", textAngle=None)
Definition ds9Regions.py:27
drawLines(points, ctype=None)