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.
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.
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')
Alternately, you can install it from GitHub:
## install.packages('remotes')
remotes::install_github("ucanr-igis/uasimg")
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 13.11
#> [1] "13.11"
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:\windows), rename the executable file from
exiftool(-k).exe to exiftool.exe, and pass use_exiftoolr = FALSE
when you call uas_info()
.
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)
.
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.
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)
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.
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:
library(uasimg)
hast_ft1_info <- uas_info("c:/Drone_Projects/Hastings/Flt01_1443_1446_250ft")
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)
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.
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.
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.
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.
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.
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.