uasimg
helps manage images taken from an unoccupied aerial vehicle (UAV, or drone) that have been collected with the intent to stitch them into 2D and 3D products with photogrammetry software. The package does not stitch images, but helps you create catalogs of your image data, examine their locations and properties, export image centroids and estimated footprints as GIS files, and prepare images for visualization and analysis in GIS and remote sensing applications.
Motivation
uasimg
was developed to help with the following common data management tasks:
Doing a quick check in the field of photos after a flight, assessing their locations and estimated image overlap. This can help a pilot determine if a flight was successful, or needs to be redone.
Organizing images into structured folder trees based on the project, location, platform, etc.
Subsetting images for further processing with photogrammetry (stitching) software like Pix4Dmapper or OpenDroneMap. For example omitting images with an extreme amount of overlap can actually improve photogrammetry results and reduce processing time.
Creating individual Flight Summary pages in HTML, as the backbone of an image catalog, and higher level ‘Table of Contents’ pages for groups of related flights (e.g., from the same site).
Converting images from one format to another (e.g., DNG to JPG), while preserving all the image metadata needed for photogrammetry.
-
Creating world files for individual drone images, using the image EXIF data to model the ground footprint and rotation, so they can be imported in GIS software and appear in their approximate location.
Note: image locations and footprints are based on the metadata saved in the image files (e.g., relative altitude above the launch point, camera compass direction), and are estimates only.
Exporting individual images as pseudo-georeferenced GeoTIFFs, so that you can do pixel operations with remote sensing tools such as pixel classification, spatial overlays, object detection, zonal stats, etc.
Installation
Install from R-Universe
uasimg
is not on CRAN (yet), but you can install it from R-Universe (recommended):
options(repos = c(ajlyons = 'https://ajlyons.r-universe.dev',
CRAN = 'https://cloud.r-project.org'))
install.packages('uasimg')
Install from GitHub
Alternately, you can install it from GitHub:
## install.packages('remotes')
remotes::install_github("ucanr-igis/uasimg")
Dependencies
exiftool
To read the EXIF data from the image files, uasimg
requires an external command line tool called exiftool
. exiftool
is not bundled with uasimg
, but you can install it by running:
exiftoolr::install_exiftool()
To verify it worked:
exiftoolr::exif_version()
#> Using ExifTool version 12.50
#> [1] "12.50"
Alternately, you can install exiftool manually by downloading it from http://www.sno.phy.queensu.ca/~phil/exiftool/. Be sure to unzip it to a folder on the path (e.g, c:), rename the executable file from exiftool(-k).exe to exiftool.exe, and pass use_exiftoolr = FALSE
when you call uas_info()
.
Dependent Packages
uasimg
requires several dependent packages, including sf, dplyr, tidyr, leaflet, htmltools, and several suggested packages for specific features (see the DESCRIPTION file for a complete list). Normally missing packages are installed at the same time, but if you get an error message about a missing package(s), install the dependent packages separately (i.e., from the ‘Packages’ pane in RStudio) then run remotes::install_github("ucanr-igis/uasimg", dependencies=FALSE)
.
Supported Cameras
To see a list of known cameras (sensors), run uas_cameras()
with no arguments. If your camera is not listed, you may submit an issue on GitHub to have it added, or pass the camera parameters in as a csv file. For details see the help page (?uas_cameras
) or contact the package author.
Data Requirements
Virtually all of the functions in uasimg
use location data saved in the EXIF data (header) of image files themselves. This assumes the camera saves the location in the images using a GPS coordinate from the drone or the camera itself. To compute footprints, the package also needs to know the above-ground height at which images were taken. Some drones (including many DJI drones) record the relative flight altitude (above the launch point) in the image file, but others don’t (notably many multispectral cameras). Flight height can also be entered manually as an argument when you run uas_info()
.
Requirements for uasimg
therefore include:
- images must have GPS coordinates saved in them
- image files should be grouped in folders (typically one flight per folder)
- the camera must be one of the ones known by the
uasimg
package (see below)
Additional requirements to generate estimated footprints:
- the height above ground level must be saved in the image files, or passed as an argument. If passed as an argument, the assumption is that all images were taken from the same height.
- it is presumed that images were taken at nadir (camera pointing straight down)
Usage Overview
You always start with uas_info()
, feeding it one or more folders of drone images. This function extracts image information, computes footprints, and reads supplemental flight metadata (see also the article on Flight Metadata).
The object returned by uas_info()
is not very useful by itself. The results are generally saved to a variable then fed into other functions that do useful things, such as:
uas_report()
creates ‘Flight Summaries’ as standalone HTML pages, with options to create image thumbnails (sample). Flight summaries also be grouped usinguas_toc()
, which generates a Table of Contents page for several Flight Summaries, with options to copy all the catalog files to a single folder so the catalog is in one place (sample).uas_exp_shp()
anduas_exp_kml()
exports flight geometries (image centroids, image footprints, and/or flight area) as Shapefiles or KML files. KML files can be imported into most flight planning software to refly the same area and/or plan a flight for an adjacent area.uas_worldfile()
creates small external XML files that allow images to be imported into GIS software and appear in their approximate footprint.uas_convert()
converts image files from one format to another.uas_move()
moves images into a standardized directory tree based on metadata
For more info, see the Managing Drone Images with uasimg Vignette and function help pages.
Example
The general usage is to first create a flight info object for one or more directories of images using the uas_info() function. Save the result to a variable:
If you want to record additional metadata about the flight as a whole, you can create a metadata.txt file in the image folder with uas_metadata_make()
. Edit the metadata.txt file in Notepad (or another text editor), save it, then run uas_info()
again.
uas_metadata_make(hast_ft1_info, open = TRUE)
Once a flight info object has been created, you can start to generate outputs.
## Generate a flight summary
uas_report(hast_ft1_info)
## Export image centroid, footprints, and minimum convex polygon as Shapefiles
uas_exp_shp(hast_ft1_info)
## Generate estimated world files so the images can be imported into ArcGIS or QGIS
uas_worldfile(hast_ft1_info)
Utilities for Individual Images
The following utilities can help visualize and analyze individual images. These functions are based on the modeled image footprints, which as described above require the camera to record the relative altitude above ground.
World Files
Drone images typically save the coordinates of the camera, but do not include the width, length, or compass angle. A “world file” is a small external text file (also known as a sidecar file) that contains these additional parameters. These files allow GIS programs like ArcGIS Pro or QGIS to display the image in its approximate footprint on the ground.
You can create world files, readable by ArcGIS and QGIS, with uas_worldfile()
. uas_worldfile()
can create three types of world files, including aux.xml
, jpw
and tfw
, and prj
files. aux.xml
is the most recognized format and hence the default. See the uas_worldfile()
help page for details.
Cropping the Center of Images
Sometimes images will simply not stitch, forcing you to do your analysis and visualization with individual images. uas_cropctr()
crops out the center part of each image (which normally has the least amount of distortion if the image was taken at nadir). The function will also produce a world file for the cropped center, so they can be visualized together in a GIS software as a kind of crude mosaic. uas_cropctr()
provides arguments to specify how tall and wide to make the crop, which you can set to the average forward distance between images and the average side distance between flight lines. The resulting mosaic will not be orthorectified, but may be good enough for visualization and/or object detection particularly if the area is flat.
Exporting Images as Psuedo-Georefrenced TIFFs
Many remote sensing tools can not read WorldFiles. In these cases, you can export individual images in their modeled footprint as GeoTIFFs. This may allow you for example to do traditional remote sensing analyses including spatial joins and queries (e.g., with field data), pixel classification, zonal statistics, using Deep Learning / CNN methods to detect objects, etc. See uas_exp_geotiff()
for details.
Get Involved!
Bugs, Questions, and Feature Requests
To report a bug, add your camera to the package, or suggest a new feature, please create an issue on GitHub, or contact the package author.
Code of Conduct
Please note that the uasimg project is released with a Contributor Code of Conduct. By contributing to this project, you agree to abide by its terms.