-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathem_clickAddRemove.m
63 lines (49 loc) · 1.65 KB
/
em_clickAddRemove.m
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
function [x_new, y_new] = em_clickAddRemove(x_old, y_old, im, bool_conjugate)
% Enables mouse input to add or remove coordinates on a image
% x_old, y_old initial x,y point set
% im image to click on
% bool_conjugate add conjugate pair (useful for reciprocal space)
% September 11, 2018 by Suk Hyun Sung @Hovden lab
if nargin == 3
bool_conjugate = false;
end
lft = 1;
figure
imagesc(im)
axis equal off
colormap(parula(65536))
title('Left Click to Add, Right Click to Remove, Hit Return to end' )
hold on
scatter(x_old,y_old,5,'ro')
x_new = x_old;
y_new = y_old;
while lft ~=2
[xm, ym, lft] = ginput(1);
xm_conj = size(im,2)-xm+1;
ym_conj = size(im,2)-ym+1;
if lft == 3
dist = sqrt( (x_new-xm).^2 + (y_new-ym).^2 );
ind_rmv = find( dist == min(dist) );
if bool_conjugate
dist = sqrt( (x_new-xm_conj).^2 + (y_new-ym_conj).^2 );
ind_rmv = [ind_rmv, find( dist == min(dist) )];
end
x_new(ind_rmv) = [];
y_new(ind_rmv) = [];
elseif lft == 1
x_new = [x_new, xm];
y_new = [y_new, ym];
if bool_conjugate
x_new = [x_new, xm_conj];
y_new = [y_new, ym_conj];
end
end
cla
imagesc(im)
axis equal off
colormap(parula(65536))
hold on
scatter(x_new,y_new,5,'ro')
end
end