/* * Copyright (C) 2014 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.camera.one; import java.io.File; import java.text.SimpleDateFormat; import java.util.Date; import java.util.TimeZone; /** * A common abstract {@link OneCamera} implementation that contains some utility * functions and plumbing we don't want every sub-class of {@link OneCamera} to * duplicate. Hence all {@link OneCamera} implementations should sub-class this * class instead. */ public abstract class AbstractOneCamera implements OneCamera { protected FocusStateListener mFocusStateListener; protected ReadyStateChangedListener mReadyStateChangedListener; protected FocusDistanceListener mFocusDistanceListener; /** * Number of characters from the end of the device serial number used to * construct folder names for debugging output. */ static final int DEBUG_FOLDER_SERIAL_LENGTH = 4; @Override public final void setFocusStateListener(FocusStateListener listener) { mFocusStateListener = listener; } @Override public void setFocusDistanceListener(FocusDistanceListener listener) { mFocusDistanceListener = listener; } @Override public void setReadyStateChangedListener(ReadyStateChangedListener listener) { mReadyStateChangedListener = listener; } /** * Create a directory we can use to store debugging information during Gcam * captures. *
* The directory created is [root]/[folderName]/SSSS_YYYYMMDD_HHMMSS_XXX, * where 'SSSS' are the last 'DEBUG_FOLDER_SERIAL_LENGTH' digits of the * devices serial number, and 'XXX' are milliseconds of the timestamp. * * @param root the root into which we put a session-specific sub-directory. * @param folderName the sub-folder within 'root' where the data should be * put. * @return The session-specific directory (absolute path) into which to * store debug information. */ protected static String makeDebugDir(File root, String folderName) { if (root == null) { return null; } if (!root.exists() || !root.isDirectory()) { throw new RuntimeException("Gcam debug directory not valid or doesn't exist: " + root.getAbsolutePath()); } String serialSubstring = ""; String serial = android.os.Build.SERIAL; if (serial != null) { int length = serial.length(); if (length > DEBUG_FOLDER_SERIAL_LENGTH) { serialSubstring = serial.substring(length - DEBUG_FOLDER_SERIAL_LENGTH, length); } else { serialSubstring = serial; } } SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMdd_HHmmss_SSS"); simpleDateFormat.setTimeZone(TimeZone.getDefault()); String currentDateAndTime = simpleDateFormat.format(new Date()); String burstFolderName = String.format("%s_%s", serialSubstring, currentDateAndTime); File destFolder = new File(new File(root, folderName), burstFolderName); if (!destFolder.mkdirs()) { throw new RuntimeException("Could not create Gcam debug data folder."); } String destFolderPath = destFolder.getAbsolutePath(); return destFolderPath; } /** * If set, tells the ready state changed listener the new state. */ protected void broadcastReadyState(boolean readyForCapture) { if (mReadyStateChangedListener != null) { mReadyStateChangedListener.onReadyStateChanged(readyForCapture); } } @Override public float getMaxZoom() { // If not implemented, return 1.0. return 1f; } @Override public void setZoom(float zoom) { // If not implemented, no-op. } }