Infusing/ Overlaying two images in reference to their center-to-center distance w.r.t to coordinates
    9 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Abdul Hannan Qureshi
 el 23 de Nov. de 2023
  
    
    
    
    
    Comentada: Abdul Hannan Qureshi
 el 27 de Nov. de 2023
            Hi,
I am working on merging/ infusing/ overlaying images w.r.t coordinate values. I am able to find distance between two coordinate points and using that reference I want to infuse them. Following I have acheived:
% Distance btw image 1 & 2
A = imread('0.JPG');
Picinfo0 = imfinfo('0.JPG');
Xx0=Picinfo0.GPSInfo.GPSLatitude;
X0= dms2degrees(Xx0);
Yy0=Picinfo0.GPSInfo.GPSLongitude;
Y0= dms2degrees(Yy0);
B = imread('1.JPG');
Picinfo1 = imfinfo('1.JPG');
Xx1=Picinfo1.GPSInfo.GPSLatitude;
X1= dms2degrees(Xx1);
Yy1=Picinfo1.GPSInfo.GPSLongitude;
Y1= dms2degrees(Yy1);
wgs84 = wgs84Ellipsoid("m");
D0 = distance(X0,Y0,X1,Y1,wgs84) % D in meters , this D is c/c distance between two images
% Pixel info for Image 1
% Pixel Size=tan(FOV/2)*Distance/pixel width           ;;; Pixel Size Formula
FOV=82.9 % from DJI website
DD0=str2double(Picinfo0.XMPData.drone_dji.RelativeAltitude) % Altitude value is Character array
pixelsize0w=tan(FOV/2)*DD0/Picinfo0.Width % meters
%pixelsize0h=tan(FOV/2)*DD0/Picinfo0.Height % meters
R0 = imref2d(size(A),pixelsize0w,pixelsize0w)
%________________________
%Pixel info for Image 2
DD1=str2double(Picinfo1.XMPData.drone_dji.RelativeAltitude) % Altitude value is Character array
pixelsize1w=tan(FOV/2)*DD1/Picinfo1.Width % meters
%pixelsize1h=tan(FOV/2)*DD1/Picinfo1.Height % meters
R1 = imref2d(size(B),pixelsize1w,pixelsize1w)
%imshow(B,R1);
%____________________________________________________________________
% Referencing Image 1 & 2
% Set referencing object parameters to specify the limits of the coordinates in world coordinates.
R0.XWorldLimits = R1.XWorldLimits
R0.YWorldLimits = R1.YWorldLimits+D0 % D is distance between two coordinates
AB=imfuse(A,R0,B,R1,'blend','Scaling','joint');
figure
imshow(AB);
Here in attained figure AB, the overlap is starting after 'D0' (2.5 meters) from the bottom of 0.JPG as reference. How can I set 'D0' as center to center distance between two images. Kindly assist and advise.
regards
0 comentarios
Respuesta aceptada
  Image Analyst
      
      
 el 23 de Nov. de 2023
        You're going to have to create a canvas larger than either one, like the height is the sum of the two images heights.  Paste one image onto the canvass.  Then compute the shift and paste the second image on.  Or you can average it instead of pasting.  See attached example.
Más respuestas (0)
Ver también
Categorías
				Más información sobre Point Cloud Processing en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

