📄 plotmatches.m
字号:
function h=plotmatches(I1,I2,P1,P2,matches,varargin)% PLOTMATCHES Plot keypoint matches% PLOTMATCHES(I1,I2,P1,P2,MATCHES) plots the two images I1 and I2% and lines connecting the frames (keypoints) P1 and P2 as specified% by MATCHES.%% P1 and P2 specify two sets of frames, one per column. The first% two elements of each column specify the X,Y coordinates of the% corresponding frame. Any other element is ignored.%% MATCHES specifies a set of matches, one per column. The two% elementes of each column are two indexes in the sets P1 and P2% respectively.%% The images I1 and I2 might be either both grayscale or both color% and must have DOUBLE storage class. If they are color the range% must be normalized in [0,1].%% The function accepts the following option-value pairs:%% 'Stacking' ['h']% Stacking of images: horizontal ['h'], vertical ['v'], diagonal% ['h'], overlap ['o']%% 'Interactive' [0]% If set to 1, starts the interactive session. In this mode the% program lets the user browse the matches by moving the mouse:% Click to select and highlight a match; press any key to end.% If set to a value greater than 1, the feature matches are not% drawn at all (useful for cluttered scenes).%% See also PLOTSIFTDESCRIPTOR(), PLOTSIFTFRAME(), PLOTSS().% AUTORIGHTS% Copyright (c) 2006 The Regents of the University of California.% All Rights Reserved.% % Created by Andrea Vedaldi% UCLA Vision Lab - Department of Computer Science% % Permission to use, copy, modify, and distribute this software and its% documentation for educational, research and non-profit purposes,% without fee, and without a written agreement is hereby granted,% provided that the above copyright notice, this paragraph and the% following three paragraphs appear in all copies.% % This software program and documentation are copyrighted by The Regents% of the University of California. The software program and% documentation are supplied "as is", without any accompanying services% from The Regents. The Regents does not warrant that the operation of% the program will be uninterrupted or error-free. The end-user% understands that the program was developed for research purposes and% is advised not to rely exclusively on the program for any reason.% % This software embodies a method for which the following patent has% been issued: "Method and apparatus for identifying scale invariant% features in an image and use of same for locating an object in an% image," David G. Lowe, US Patent 6,711,293 (March 23,% 2004). Provisional application filed March 8, 1999. Asignee: The% University of British Columbia.% % IN NO EVENT SHALL THE UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY% FOR DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES,% INCLUDING LOST PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND% ITS DOCUMENTATION, EVEN IF THE UNIVERSITY OF CALIFORNIA HAS BEEN% ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. THE UNIVERSITY OF% CALIFORNIA SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT% LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR% A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS"% BASIS, AND THE UNIVERSITY OF CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE% MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.% --------------------------------------------------------------------% Check the arguments% --------------------------------------------------------------------stack='h' ;interactive=0 ;only_interactive=0 ;for k=1:2:length(varargin) switch lower(varargin{k}) case 'stacking' stack=varargin{k+1} ; case 'interactive' interactive=varargin{k+1}; otherwise error(['[Unknown option ''', varargin{k}, '''.']) ; endend % --------------------------------------------------------------------% Do the job% --------------------------------------------------------------------[M1,N1,K1]=size(I1) ;[M2,N2,K2]=size(I2) ;switch stack case 'h' N3=N1+N2 ; M3=max(M1,M2) ; oj=N1 ; oi=0 ; case 'v' M3=M1+M2 ; N3=max(N1,N2) ; oj=0 ; oi=M1 ; case 'd' M3=M1+M2 ; N3=N1+N2 ; oj=N1 ; oi=M1 ; case 'o' M3=max(M1,M2) ; N3=max(N1,N2) ; oj=0; oi=0; otherwise error(['Unkown stacking type '''], stack, ['''.']) ;end% Combine the two images. In most cases just place one image next to% the other. If the stacking is 'o', however, combine the two images% linearly.I=zeros(M3,N3,K1) ;if stack ~= 'o' I(1:M1,1:N1,:) = I1 ; I(oi+(1:M2),oj+(1:N2),:) = I2 ;else I(oi+(1:M2),oj+(1:N2),:) = I2 ; I(1:M1,1:N1,:) = I(1:M1,1:N1,:) + I1 ; I(1:min(M1,M2),1:min(N1,N2),:) = 0.5 * I(1:min(M1,M2),1:min(N1,N2),:) ;endaxes('Position', [0 0 1 1]) ;imagesc(I) ; colormap gray ; hold on ; axis image ; axis off ;K = size(matches, 2) ;nans = NaN * ones(1,K) ;x = [ P1(1,matches(1,:)) ; P2(1,matches(2,:))+oj ; nans ] ;y = [ P1(2,matches(1,:)) ; P2(2,matches(2,:))+oi ; nans ] ;% if interactive > 1 we do not drive lines, but just points.if(interactive > 1) h = plot(x(:),y(:),'g.') ;else h = line(x(:)', y(:)') ;endset(h,'Marker','.','Color','g') ;% --------------------------------------------------------------------% Interactive% --------------------------------------------------------------------if(~interactive), return ; endsel1 = unique(matches(1,:)) ;sel2 = unique(matches(2,:)) ;K1 = length(sel1) ; %size(P1,2) ;K2 = length(sel2) ; %size(P2,2) ;X = [ P1(1,sel1) P2(1,sel2)+oj ; P1(2,sel1) P2(2,sel2)+oi ; ] ;fig = gcf ;is_hold = ishold ;hold on ;% save the handlers for later to restoredhandler = get(fig,'WindowButtonDownFcn') ;uhandler = get(fig,'WindowButtonUpFcn') ;mhandler = get(fig,'WindowButtonMotionFcn') ;khandler = get(fig,'KeyPressFcn') ;pointer = get(fig,'Pointer') ;set(fig,'KeyPressFcn', @key_handler) ;set(fig,'WindowButtonDownFcn',@click_down_handler) ;set(fig,'WindowButtonUpFcn', @click_up_handler) ;set(fig,'Pointer','crosshair') ;data.exit = 0 ; % signal exit to the interactive modedata.selected = [] ; % currently selected featuredata.X = X ; % feature anchorshighlighted = [] ; % currently highlighted featurehh = [] ; % hook of the highlight plotguidata(fig,data) ;while ~ data.exit uiwait(fig) ; data = guidata(fig) ; if(any(size(highlighted) ~= size(data.selected)) || ... any(highlighted ~= data.selected) ) highlighted = data.selected ; % delete previous highlight if( ~isempty(hh) ) delete(hh) ; end hh=[] ; % each selected feature uses its own color c=1 ; colors=[1.0 0.0 0.0 ; 0.0 1.0 0.0 ; 0.0 0.0 1.0 ; 1.0 1.0 0.0 ; 0.0 1.0 1.0 ; 1.0 0.0 1.0 ] ; % more than one feature might be seleted at one time... for this=highlighted % find matches if( this <= K1 ) sel=find(matches(1,:)== sel1(this)) ; else sel=find(matches(2,:)== sel2(this-K1)) ; end K=length(sel) ; % plot matches x = [ P1(1,matches(1,sel)) ; P2(1,matches(2,sel))+oj ; nan*ones(1,K) ] ; y = [ P1(2,matches(1,sel)) ; P2(2,matches(2,sel))+oi ; nan*ones(1,K) ] ; hh = [hh line(x(:)', y(:)',... 'Marker','*',... 'Color',colors(c,:),... 'LineWidth',3)]; if( size(P1,1) == 4 ) f1 = unique(P1(:,matches(1,sel))','rows')' ; hp=plotsiftframe(f1); set(hp,'Color',colors(c,:)) ; hh=[hh hp] ; end if( size(P2,1) == 4 ) f2 = unique(P2(:,matches(2,sel))','rows')' ; f2(1,:)=f2(1,:)+oj ; f2(2,:)=f2(2,:)+oi ; hp=plotsiftframe(f2); set(hp,'Color',colors(c,:)) ; hh=[hh hp] ; end c=c+1 ; end drawnow ; endendif( ~isempty(hh) ) delete(hh) ;endif ~is_hold hold off ; endset(fig,'WindowButtonDownFcn', dhandler) ;set(fig,'WindowButtonUpFcn', uhandler) ;set(fig,'WindowButtonMotionFcn',mhandler) ;set(fig,'KeyPressFcn', khandler) ;set(fig,'Pointer', pointer ) ;% ====================================================================function data=selection_helper(data)% --------------------------------------------------------------------P = get(gca, 'CurrentPoint') ;P = [P(1,1); P(1,2)] ;d = (data.X(1,:) - P(1)).^2 + (data.X(2,:) - P(2)).^2 ;dmin=min(d) ;idx=find(d==dmin) ;data.selected = idx ;% ====================================================================function click_down_handler(obj,event)% --------------------------------------------------------------------% select a feature and change motion handler for dragging[obj,fig]=gcbo ;data = guidata(fig) ;data.mhandler = get(fig,'WindowButtonMotionFcn') ;set(fig,'WindowButtonMotionFcn',@motion_handler) ;data = selection_helper(data) ;guidata(fig,data) ;uiresume(obj) ;% ====================================================================function click_up_handler(obj,event)% --------------------------------------------------------------------% stop dragging[obj,fig]=gcbo ;data = guidata(fig) ;set(fig,'WindowButtonMotionFcn',data.mhandler) ;guidata(fig,data) ;uiresume(obj) ;% ====================================================================function motion_handler(obj,event)% --------------------------------------------------------------------% select features while draggingdata = guidata(obj) ;data = selection_helper(data); guidata(obj,data) ;uiresume(obj) ;% ====================================================================function key_handler(obj,event)% --------------------------------------------------------------------% use keypress to exitdata = guidata(gcbo) ;data.exit = 1 ;guidata(obj,data) ;uiresume(gcbo) ;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -