OpenDroneMap-ODM/scripts/dataset.py

70 wiersze
2.3 KiB
Python
Czysty Zwykły widok Historia

2015-11-26 12:15:02 +00:00
import os
import ecto
from opendm import context
from opendm import io
from opendm import types
from opendm import log
2015-11-27 10:00:43 +00:00
class ODMLoadDatasetCell(ecto.Cell):
def declare_params(self, params):
2015-12-10 12:35:52 +00:00
params.declare("force_focal", 'Override the focal length information for the '
'images', None)
2015-12-10 12:35:52 +00:00
params.declare("force_ccd", 'Override the ccd widht information for the '
'images', None)
2015-11-26 12:15:02 +00:00
def declare_io(self, params, inputs, outputs):
inputs.declare("tree", "Struct with paths", [])
outputs.declare("photos", "list of ODMPhoto's", [])
2015-11-26 12:15:02 +00:00
def process(self, inputs, outputs):
# check if the extension is sopported
def supported_extension(file_name):
(pathfn, ext) = os.path.splitext(file_name)
return ext.lower() in context.supported_extensions
log.ODM_INFO('Running ODM Load Dataset Cell')
# get inputs
tree = self.inputs.tree
# set images directory
images_dir = tree.dataset_resize
2015-12-02 11:16:30 +00:00
2015-12-10 12:35:52 +00:00
if not io.dir_exists(images_dir):
images_dir = tree.dataset_raw
if not io.dir_exists(images_dir):
log.ODM_ERROR("You must put your pictures into an <images> directory")
return ecto.QUIT
2015-11-26 12:15:02 +00:00
log.ODM_DEBUG('Loading dataset from: %s' % images_dir)
# find files in the given directory
files = io.get_files_list(images_dir)
# filter images for its extension type
files = [f for f in files if supported_extension(f)]
if files:
2015-11-26 12:15:02 +00:00
# create ODMPhoto list
2015-12-02 11:16:30 +00:00
photos = []
2015-11-26 12:15:02 +00:00
for f in files:
path_file = io.join_paths(images_dir, f)
2015-12-10 17:17:39 +00:00
photo = types.ODM_Photo(path_file,
self.params.force_focal,
self.params.force_ccd)
2015-12-10 12:35:52 +00:00
photos.append(photo)
2015-11-27 10:00:43 +00:00
log.ODM_INFO('Found %s usable images' % len(photos))
else:
log.ODM_ERROR('Not enough supported images in %s' % images_dir)
return ecto.QUIT
2015-11-26 12:15:02 +00:00
# append photos to cell output
outputs.photos = photos
log.ODM_INFO('Running ODM Load Dataset Cell - Finished')
return ecto.OK