亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? vgg_gui_f.m

?? 實現(xiàn)了幾何多視的功能
?? M
字號:
function fig=vgg_gui_F(i1,i2,F)
%
%	fig=vgg_gui_F(i1,i2,F)
%
%
% Visualizes the fundamental matrix of two views
%
%IN:
%	i1 - Matlab image
%	i2 - Matlab image
%	F - Fundamental matrix (p1'*F*p2=0). Assumes that image coordiantes
%		are 1..width where pixel centers are at integer locations. 
%
%OUT:
%	fig - handle to the figure

% $Id: vgg_gui_F.m,v 1.8 2002/05/20 21:35:42 wexler Exp $
% Yoni, Tue Mar 27 19:31:16 2001


if nargin==3
   action='start';
else
   action=i1;
   ud = get(gcf, 'UserData');
end

if strcmp(action,'start'),
   if nargin ~= 3
      error('Must give 3 arguments... read the docs.\n');
   end

   h0 = figure('Color',[0.8 0.8 0.8], ...
	       'NumberTitle','off', ...
	       'Name','Play With Fundamental Matrix', ...
	       'ButtonDownFcn', 'disp(''Click on images'')',...
	       'WindowButtonUpFcn', 'vgg_gui_F(''none'');',...
	       'WindowButtonMotionFcn', 'vgg_gui_F(''move'')', ...
	       'Pointer', 'crosshair', ...
	       'DoubleBuffer', 'on',...
	       'Units','normalized');
   [pointerShape, pointerHotSpot] = CreatePointer;
   set(h0, 'Pointer', 'custom', ...
	   'PointerShapeCData', pointerShape, ...
	   'PointerShapeHotSpot', pointerHotSpot);
   
   m0=uimenu('Label', '&Color');
   uimenu(m0, 'Label', 'blac&K', 'ForegroundColor', [0 0 0], ...
	  'Accelerator', 'k', 'Callback', 'vgg_gui_F(''ck'');');
   uimenu(m0, 'Label', '&Red', 'ForegroundColor', [1 0 0], ...
	  'Accelerator', 'r', 'Callback', 'vgg_gui_F(''cr'');');
   uimenu(m0, 'Label', '&Green', 'ForegroundColor', [0 1 0], ...
	  'Accelerator', 'g', 'Callback', 'vgg_gui_F(''cg'');');
   uimenu(m0, 'Label', '&Blue', 'ForegroundColor', [0 0 1], ...
	  'Accelerator', 'b', 'Callback', 'vgg_gui_F(''cb'');');
   m1=uimenu('Label', '&Size');
   uimenu(m1, 'Label', '&Increase', 'Callback', 'vgg_gui_F(''s+'');', 'Accelerator', '+');
   uimenu(m1, 'Label', '&Decrease', 'Callback', 'vgg_gui_F(''s-'');', 'Accelerator', '-');
   uimenu(m1, 'Label', '&1', 'Callback', 'vgg_gui_F(''s1'');', 'Accelerator', '1');
   uimenu(m1, 'Label', '&2', 'Callback', 'vgg_gui_F(''s2'');', 'Accelerator', '2');
   uimenu(m1, 'Label', '&3', 'Callback', 'vgg_gui_F(''s3'');', 'Accelerator', '3');
   uimenu(m1, 'Label', '&4', 'Callback', 'vgg_gui_F(''s4'');', 'Accelerator', '4');
   uimenu(m1, 'Label', '&5', 'Callback', 'vgg_gui_F(''s5'');', 'Accelerator', '5');
   uimenu(m1, 'Label', '&6', 'Callback', 'vgg_gui_F(''s6'');', 'Accelerator', '6');
   uimenu(m1, 'Label', '&7', 'Callback', 'vgg_gui_F(''s7'');', 'Accelerator', '7');
   uimenu(m1, 'Label', '&8', 'Callback', 'vgg_gui_F(''s8'');', 'Accelerator', '8');
   uimenu(m1, 'Label', '&9', 'Callback', 'vgg_gui_F(''s9'');', 'Accelerator', '9');
   
   ah1 = axes('Parent', h0, ...
	      'Position',[0 0 .5 1]);
   h1=imshow(i1); hold on; title('Image 1');
   set(h1, 'ButtonDownFcn','vgg_gui_F(''b1'');');

   ah2 = axes('Parent',h0, ...
	      'Position',[.5 0 .5 1], ...
	      'Tag','Axes2');
   h2=imshow(i2); hold on; title('Image 2');
   set(h2, 'ButtonDownFcn','vgg_gui_F(''b2'');');

   point=plot(-1000, -1000,'EraseMode','xor');
   l=plot([-1000, -1001], [-1000 -1000], 'r-','EraseMode','xor');

   s1=size(i1); s2=size(i2);
   t(:,:,1)=F';  t(:,:,2)=F;  F=t;

   ud=struct('h0', h0, 'h',[h1 h2], 'ah', [ah1, ah2], ...
	     'sizes', [s1(1:2); s2(1:2)], ...
	     'current', -1, 'color', 'k', 'size', 1, ...
	     'p', point, 'F', F, 'l', l );

   set(h0,'UserData',ud);

   if nargout > 0, fig = h0; end
elseif strcmp(action, 'move')
   if ud.current<0 return; end;
   pt=get(ud.ah(ud.current),'CurrentPoint');
   pts=get_line_points(ud.F(:,:,ud.current)*pt(1,:)', ...
		       ud.sizes(ud.current,:));

   set(ud.l, 'XData', pts(1,:), 'YData', pts(2,:))
   set(ud.p, 'XData', pt(1,1), 'YData', pt(1,2))

elseif action(1)=='b'
   if action(2)=='1' ud.current=1;
   elseif action(2)=='2' ud.current=2;
   else return;
   end
   pt=get(ud.ah(ud.current),'CurrentPoint');

   pts=get_line_points(ud.F(:,:,ud.current)*pt(1,:)', ud.sizes(1,:));
   delete(ud.p);
   delete(ud.l);
   axes(ud.ah(ud.current));
   ud.p=plot(pt(1,1), pt(1,2), [ud.color '+'], ...
	     'MarkerSize', 8+2*ud.size, 'LineWidth', ud.size,...
	     'EraseMode','xor');
   axes(ud.ah(3-ud.current));
   ud.l=plot(pts(1,:), pts(2,:), [ud.color '-'], ...
	     'LineWidth', ud.size, 'EraseMode','xor');
elseif action(1)=='c'
   ud.color=action(2);
   %get(ud.l)
   set(ud.l, 'Color', ud.color);
   set(ud.p, 'Color', ud.color);
elseif action(1)=='s'
   if action(2)=='+' ud.size=ud.size+1;
   elseif action(2)=='-' ud.size=max(1, ud.size-1);
   else
      ud.size = str2num(action(2));
   end
   set(ud.p, 'LineWidth', ud.size, 'MarkerSize', 8+2*ud.size);
   set(ud.l, 'LineWidth', ud.size, 'MarkerSize', 8+2*ud.size);
elseif strcmp(action, 'none')
   ud.current = -1;
else
   error(['Unknown command: ' action]);
end

set(ud.h0, 'UserData',ud);



function pts=get_line_points(l,sz)
a=l(1); b=l(2);c=l(3);
h=sz(1); w=sz(2);

% This might cause 'divide by zero' warning:
ys=c/-b ;
yf=-(a*w+c)/b;
xs=c/-a;
xf=-(b*h+c)/a;

m1 = [[xs;1] [xf;h] [1;ys] [w;yf]];
w2 = [(xs<=w & xs>=1) (xf<=w & xf>=1) (ys<=h & ys>=1) (yf<=h & yf>=1)];
v = w2>0;
pts = [m1(:,v)];



% Taken from pixval.m:
function [pointerShape, pointerHotSpot] = CreatePointer

pointerHotSpot = [8 8];
pointerShape = [ ...
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
    1   1   1   1   1    1   2  NaN  2   1   1   1   1   1   1   1
    2   2   2   2   2    2  NaN NaN NaN  2   2   2   2   2   2   2
   NaN NaN NaN NaN NaN  NaN NaN NaN NaN NaN NaN NaN NaN NaN NaN NaN
    2   2   2   2   2    2  NaN NaN NaN  2   2   2   2   2   2   2
    1   1   1   1   1    1   2  NaN  2   1   1   1   1   1   1   1
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN   1   2  NaN  2   1 NaN NaN NaN NaN NaN NaN
   NaN NaN NaN NaN NaN NaN NaN  NaN NaN NaN NaN NaN NaN NaN NaN NaN];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级国产精品| 久久久久亚洲蜜桃| 欧美变态tickle挠乳网站| 国产女人18毛片水真多成人如厕 | 午夜久久久影院| 国产毛片精品一区| 欧美日韩一区三区| 国产精品久久久久精k8| 国产呦精品一区二区三区网站| 精品国产一区二区三区忘忧草| 亚洲国产毛片aaaaa无费看| 国产xxx精品视频大全| 日韩精品专区在线影院重磅| 亚洲午夜久久久久中文字幕久| 欧美日韩在线播放| 老司机免费视频一区二区三区| 6080午夜不卡| 五月天欧美精品| 日韩精品一区二区三区四区 | 日韩三级精品电影久久久| 毛片av一区二区| 91精品国产福利| 青青草原综合久久大伊人精品优势| 欧美最猛性xxxxx直播| 亚洲九九爱视频| 91美女蜜桃在线| 中文字幕日韩一区| 99精品久久免费看蜜臀剧情介绍 | 国产精品久久久久久久岛一牛影视 | 久久久www成人免费毛片麻豆| 99精品久久免费看蜜臀剧情介绍| 偷拍一区二区三区四区| 日本一区二区免费在线| 欧美亚洲国产一卡| 午夜日韩在线观看| 欧美激情一区二区在线| 成人精品国产福利| 亚洲欧美在线视频| 欧美一区永久视频免费观看| av电影在线不卡| 亚洲图片有声小说| 中文一区一区三区高中清不卡| 在线观看91av| 国产伦精一区二区三区| 亚洲在线一区二区三区| 在线91免费看| 91一区二区三区在线观看| 精品影视av免费| 中文字幕精品三区| 欧美大肚乱孕交hd孕妇| 在线观看成人小视频| av成人免费在线| 国产精品123| 亚洲女人****多毛耸耸8| 欧美亚洲国产怡红院影院| 成人久久视频在线观看| 亚洲一区二区三区视频在线播放| 国产精品麻豆欧美日韩ww| 欧美亚一区二区| av亚洲精华国产精华精| 国产成人免费视频网站 | 一区二区三区免费观看| 欧美乱妇23p| 在线观看免费视频综合| 99精品视频一区二区三区| 成人av动漫在线| 成人性视频网站| 国产精品综合一区二区| 亚洲卡通动漫在线| 最好看的中文字幕久久| 日韩欧美在线一区二区三区| 欧美日韩高清影院| 成人av网站在线观看| 高清成人免费视频| 成人黄色小视频| 国产成人超碰人人澡人人澡| 风流少妇一区二区| 不卡电影一区二区三区| 成人av一区二区三区| 99国产精品一区| 99久久精品情趣| 色激情天天射综合网| 国内精品国产成人| 丝袜国产日韩另类美女| 国产精品久久久久永久免费观看 | 亚洲欧美经典视频| 亚洲激情五月婷婷| 一二三区精品视频| 亚洲成av人片一区二区梦乃| 国产精品久久久久久久久免费樱桃| 日本一区二区动态图| 国产精品灌醉下药二区| 亚洲色图视频网站| 亚洲二区视频在线| 久久精品国产精品亚洲精品| 国产成人精品在线看| 成人黄色网址在线观看| 91福利国产成人精品照片| 91精品国产一区二区三区| 精品国产凹凸成av人网站| 国产欧美一区二区精品性色| 成人欧美一区二区三区在线播放| 一区二区三区91| 久久97超碰色| 不卡一区中文字幕| 欧美日韩国产精品成人| 久久久精品国产99久久精品芒果| 国产精品第一页第二页第三页| 亚洲国产一区在线观看| 精品制服美女丁香| 成人av网站在线观看| 欧美日韩美女一区二区| 国产婷婷色一区二区三区四区| 精品久久久久久亚洲综合网 | 亚洲最大成人网4388xx| 日本不卡在线视频| 秋霞影院一区二区| 国产一区在线观看麻豆| 91女神在线视频| 91精品国产综合久久福利软件| 国产精品久久久久aaaa| 偷窥国产亚洲免费视频| 本田岬高潮一区二区三区| 欧美人妇做爰xxxⅹ性高电影 | 日本伊人午夜精品| jlzzjlzz欧美大全| 欧美va亚洲va香蕉在线| 一区二区三区在线观看国产| 国产在线观看一区二区| 91国在线观看| 欧美极品少妇xxxxⅹ高跟鞋 | 亚洲午夜精品在线| 国产91对白在线观看九色| 51久久夜色精品国产麻豆| 国产精品久久久久久久午夜片| 蜜桃一区二区三区在线| 在线一区二区三区四区五区| 国产日韩精品一区二区三区| 日韩不卡一区二区三区 | 69av一区二区三区| 综合亚洲深深色噜噜狠狠网站| 国产综合一区二区| 91麻豆精品国产91久久久使用方法 | 波多野结衣中文字幕一区| 91精品国产一区二区| 亚洲国产一区二区三区青草影视 | 成人美女视频在线观看| 欧美成人在线直播| 丝瓜av网站精品一区二区| 欧美性一级生活| 一区二区三区在线免费| 91视频精品在这里| 国产精品人妖ts系列视频| 高清成人免费视频| 国产日韩高清在线| 国产成人av一区二区三区在线| 欧美成人一区二区三区在线观看 | 国产一区二区三区观看| 3751色影院一区二区三区| 亚洲一区二区三区四区在线观看| 91色porny| 亚洲午夜av在线| 欧美日韩一本到| 青青草精品视频| 欧美白人最猛性xxxxx69交| 久久精品国产精品青草| 日韩欧美亚洲另类制服综合在线| 麻豆一区二区99久久久久| 日韩精品一区二区三区在线 | 精品久久久久久久久久久久久久久 | 一本到不卡免费一区二区| 日韩欧美一级二级| 日韩av一二三| 精品久久久久99| 激情五月婷婷综合网| 久久精品亚洲麻豆av一区二区| 国产精一区二区三区| 国产精品国产三级国产aⅴ中文 | 国产一区高清在线| 国产亚洲美州欧州综合国| 成人性视频免费网站| 亚洲图片激情小说| 欧美婷婷六月丁香综合色| 无吗不卡中文字幕| 精品国产第一区二区三区观看体验 | 人人狠狠综合久久亚洲| 欧美变态tickle挠乳网站| 高清不卡在线观看av| 亚洲精品一二三区| 在线播放中文字幕一区| 精品一区二区三区久久| 欧美激情综合五月色丁香| 色94色欧美sute亚洲线路一ni| 香港成人在线视频| 精品日韩av一区二区| 成人性生交大片免费看中文 | 亚洲一区在线看| 欧美一区二区二区| 成人av电影免费在线播放| 亚洲一级二级在线|