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 package com.android.camera.panorama; 18 19 /** 20 * The Java interface to JNI calls regarding mosaic preview rendering. 21 * 22 */ 23 public class MosaicRenderer 24 { 25 static 26 { 27 System.loadLibrary("jni_mosaic"); 28 } 29 30 /** 31 * Function to be called in onSurfaceCreated() to initialize 32 * the GL context, load and link the shaders and create the 33 * program. Returns a texture ID to be used for SurfaceTexture. 34 * 35 * @return textureID the texture ID of the newly generated texture to 36 * be assigned to the SurfaceTexture object. 37 */ 38 public static native int init(); 39 40 /** 41 * Pass the drawing surface's width and height to initialize the 42 * renderer viewports and FBO dimensions. 43 * 44 * @param width width of the drawing surface in pixels. 45 * @param height height of the drawing surface in pixels. 46 */ 47 public static native void reset(int width, int height); 48 49 /** 50 * Calling this function will render the SurfaceTexture to a new 2D texture 51 * using the provided STMatrix. 52 * 53 * @param stMatrix texture coordinate transform matrix obtained from the 54 * Surface texture 55 */ 56 public static native void preprocess(float[] stMatrix); 57 58 /** 59 * This function calls glReadPixels to transfer both the low-res and high-res 60 * data from the GPU memory to the CPU memory for further processing by the 61 * mosaicing library. 62 */ 63 public static native void transferGPUtoCPU(); 64 65 /** 66 * Function to be called in onDrawFrame() to update the screen with 67 * the new frame data. 68 */ 69 public static native void step(); 70 71 /** 72 * Call this function when a new low-res frame has been processed by 73 * the mosaicing library. This will tell the renderer library to 74 * update its texture and warping transformation. Any calls to step() 75 * after this call will use the new image frame and transformation data. 76 */ 77 public static native void ready(); 78 79 /** 80 * This function allows toggling between showing the input image data 81 * (without applying any warp) and the warped image data. For running 82 * the renderer as a viewfinder, we set the flag to false. To see the 83 * preview mosaic, we set the flag to true. 84 * 85 * @param flag boolean flag to set the warping to true or false. 86 */ 87 public static native void setWarping(boolean flag); 88 } 89