1 /* 2 * Copyright (C) 2011 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 /////////////////////////////////////////////////// 18 // Mosaic.h 19 // S.O. # : 20 // Author(s): zkira 21 // $Id: Mosaic.h,v 1.16 2011/06/24 04:22:14 mbansal Exp $ 22 23 #ifndef MOSAIC_H 24 #define MOSAIC_H 25 26 #include "ImageUtils.h" 27 #include "AlignFeatures.h" 28 #include "Blend.h" 29 #include "MosaicTypes.h" 30 31 /*! \mainpage Mosaic 32 33 \section intro Introduction 34 The class Mosaic provides a simple interface to the panoramic mosaicing algorithm. The class allows passing in individual image frames to be stitched together, computes the alignment transformation between them, and then stitches and blends them together into a single panoramic output which can then be accessed as a single image. \ 35 36 \section usage Usage 37 The class methods need to be called as outlined in the sample application which is created from the mosaic_main.cpp file in the directory src/mosaic/. A brief snapshot of the flow is given below: 38 39 \code 40 Mosaic mosaic; 41 // Define blending types to use, and the frame dimensions 42 int blendingType = Blend::BLEND_TYPE_CYLPAN; 43 int stripType = Blend::STRIP_TYPE_THIN; 44 int width = 640; 45 int height = 480; 46 47 while (<image frames are available>) 48 { 49 // Check for initialization and if not, initialize 50 if (!mosaic.isInitialized()) 51 { 52 // Initialize mosaic processing 53 mosaic.initialize(blendingType, stripType, width, height, -1, false, 5.0f); 54 } 55 56 // Add to list of frames 57 mosaic.addFrameRGB(imageRGB); 58 59 // Free image 60 ImageUtils::freeImage(imageRGB); 61 } 62 63 // Create the mosaic 64 ret = mosaic.createMosaic(); 65 66 // Get back the result 67 resultYVU = mosaic.getMosaic(mosaicWidth, mosaicHeight); 68 69 printf("Got mosaic of size %d,%d\n", mosaicWidth, mosaicHeight); 70 71 \endcode 72 */ 73 74 /*! 75 * Main class that creates a mosaic by creating an aligner and blender. 76 */ 77 class Mosaic 78 { 79 80 public: 81 82 Mosaic(); 83 ~Mosaic(); 84 85 /*! 86 * Creates the aligner and blender and initializes state. 87 * \param blendingType Type of blending to perform 88 * \param stripType Type of strip to use. 0: thin, 1: wide. stripType 89 * is effective only when blendingType is CylPan or 90 * Horz. Otherwise, it is set to thin irrespective of the input. 91 * \param width Width of input images (note: all images must be same size) 92 * \param height Height of input images (note: all images must be same size) 93 * \param nframes Number of frames to pre-allocate; default value -1 will allocate each frame as it comes 94 * \param quarter_res Whether to compute alignment at quarter the input resolution (default = false) 95 * \param thresh_still Minimum number of pixels of translation detected between the new frame and the last frame before this frame is added to be mosaiced. For the low-res processing at 320x180 resolution input, we set this to 5 pixels. To reject no frames, set this to 0.0 (default value). 96 * \return Return code signifying success or failure. 97 */ 98 int initialize(int blendingType, int stripType, int width, int height, int nframes = -1, bool quarter_res = false, float thresh_still = 0.0); 99 100 /*! 101 * Adds a YVU frame to the mosaic. 102 * \param imageYVU Pointer to a YVU image. 103 * \return Return code signifying success or failure. 104 */ 105 int addFrame(ImageType imageYVU); 106 107 /*! 108 * Adds a RGB frame to the mosaic. 109 * \param imageRGB Pointer to a RGB image. 110 * \return Return code signifying success or failure. 111 */ 112 int addFrameRGB(ImageType imageRGB); 113 114 /*! 115 * After adding all frames, call this function to perform the final blending. 116 * \param progress Variable to set the current progress in. 117 * \return Return code signifying success or failure. 118 */ 119 int createMosaic(float &progress, bool &cancelComputation); 120 121 /*! 122 * Obtains the resulting mosaic and its dimensions. 123 * \param width Width of the resulting mosaic (returned) 124 * \param height Height of the resulting mosaic (returned) 125 * \return Pointer to image. 126 */ 127 ImageType getMosaic(int &width, int &height); 128 129 /*! 130 * Provides access to the internal alignment object pointer. 131 * \return Pointer to the aligner object. 132 */ 133 Align* getAligner() { return aligner; } 134 135 /*! 136 * Obtain initialization state. 137 * 138 * return Returns true if initialized, false otherwise. 139 */ 140 bool isInitialized() { return initialized; } 141 142 143 /*! 144 * Return codes for mosaic. 145 */ 146 static const int MOSAIC_RET_OK = 1; 147 static const int MOSAIC_RET_ERROR = -1; 148 static const int MOSAIC_RET_CANCELLED = -2; 149 static const int MOSAIC_RET_LOW_TEXTURE = -3; 150 static const int MOSAIC_RET_FEW_INLIERS = 2; 151 152 protected: 153 154 /** 155 * Size of image frames making up mosaic 156 */ 157 int width, height; 158 159 /** 160 * Size of actual mosaic 161 */ 162 int mosaicWidth, mosaicHeight; 163 164 /** 165 * Bounding box to crop the mosaic when the gray border is not desired. 166 */ 167 MosaicRect mosaicCroppingRect; 168 169 ImageType imageMosaicYVU; 170 171 /** 172 * Collection of frames that will make up mosaic. 173 */ 174 MosaicFrame **frames; 175 176 /** 177 * Subset of frames that are considered as relevant. 178 */ 179 MosaicFrame **rframes; 180 181 int frames_size; 182 int max_frames; 183 184 /** 185 * Implicitly created frames, should be freed by Mosaic. 186 */ 187 ImageType *owned_frames; 188 int owned_size; 189 190 /** 191 * Initialization state. 192 */ 193 bool initialized; 194 195 /** 196 * Type of blending to perform. 197 */ 198 int blendingType; 199 200 /** 201 * Type of strip to use. 0: thin (default), 1: wide 202 */ 203 int stripType; 204 205 /** 206 * Pointer to aligner. 207 */ 208 Align *aligner; 209 210 /** 211 * Pointer to blender. 212 */ 213 Blend *blender; 214 215 /** 216 * Modifies TRS matrices so that rotations are balanced 217 * about center of mosaic 218 * 219 * Side effect: TRS matrices of all mosaic frames 220 * are modified 221 */ 222 int balanceRotations(); 223 224 }; 225 226 #endif 227