Parameters.cpp revision c36fbcdf37ec02314e7b8134bb0de5f624fa70fd
1/* 2 * Copyright (C) 2012 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#define LOG_TAG "Camera2-Parameters" 18#define ATRACE_TAG ATRACE_TAG_CAMERA 19// #define LOG_NDEBUG 0 20 21#include <utils/Log.h> 22#include <utils/Trace.h> 23#include <utils/Vector.h> 24#include <utils/SortedVector.h> 25 26#include <math.h> 27#include <stdlib.h> 28#include <cutils/properties.h> 29 30#include "Parameters.h" 31#include "system/camera.h" 32 33namespace android { 34namespace camera2 { 35 36Parameters::Parameters(int cameraId, 37 int cameraFacing) : 38 cameraId(cameraId), 39 cameraFacing(cameraFacing), 40 info(NULL) { 41} 42 43Parameters::~Parameters() { 44} 45 46status_t Parameters::initialize(const CameraMetadata *info) { 47 status_t res; 48 49 if (info->entryCount() == 0) { 50 ALOGE("%s: No static information provided!", __FUNCTION__); 51 return BAD_VALUE; 52 } 53 Parameters::info = info; 54 55 res = buildFastInfo(); 56 if (res != OK) return res; 57 58 res = buildQuirks(); 59 if (res != OK) return res; 60 61 const Size MAX_PREVIEW_SIZE = { MAX_PREVIEW_WIDTH, MAX_PREVIEW_HEIGHT }; 62 res = getFilteredPreviewSizes(MAX_PREVIEW_SIZE, &availablePreviewSizes); 63 if (res != OK) return res; 64 65 // TODO: Pick more intelligently 66 previewWidth = availablePreviewSizes[0].width; 67 previewHeight = availablePreviewSizes[0].height; 68 videoWidth = previewWidth; 69 videoHeight = previewHeight; 70 71 params.setPreviewSize(previewWidth, previewHeight); 72 params.setVideoSize(videoWidth, videoHeight); 73 params.set(CameraParameters::KEY_PREFERRED_PREVIEW_SIZE_FOR_VIDEO, 74 String8::format("%dx%d", 75 previewWidth, previewHeight)); 76 { 77 String8 supportedPreviewSizes; 78 for (size_t i = 0; i < availablePreviewSizes.size(); i++) { 79 if (i != 0) supportedPreviewSizes += ","; 80 supportedPreviewSizes += String8::format("%dx%d", 81 availablePreviewSizes[i].width, 82 availablePreviewSizes[i].height); 83 } 84 ALOGV("Supported preview sizes are: %s", supportedPreviewSizes.string()); 85 params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_SIZES, 86 supportedPreviewSizes); 87 params.set(CameraParameters::KEY_SUPPORTED_VIDEO_SIZES, 88 supportedPreviewSizes); 89 } 90 91 camera_metadata_ro_entry_t availableFpsRanges = 92 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES, 2); 93 if (!availableFpsRanges.count) return NO_INIT; 94 95 previewFormat = HAL_PIXEL_FORMAT_YCrCb_420_SP; 96 params.set(CameraParameters::KEY_PREVIEW_FORMAT, 97 formatEnumToString(previewFormat)); // NV21 98 99 previewTransform = degToTransform(0, 100 cameraFacing == CAMERA_FACING_FRONT); 101 102 camera_metadata_ro_entry_t availableFormats = 103 staticInfo(ANDROID_SCALER_AVAILABLE_FORMATS); 104 105 { 106 String8 supportedPreviewFormats; 107 bool addComma = false; 108 for (size_t i=0; i < availableFormats.count; i++) { 109 if (addComma) supportedPreviewFormats += ","; 110 addComma = true; 111 switch (availableFormats.data.i32[i]) { 112 case HAL_PIXEL_FORMAT_YCbCr_422_SP: 113 supportedPreviewFormats += 114 CameraParameters::PIXEL_FORMAT_YUV422SP; 115 break; 116 case HAL_PIXEL_FORMAT_YCrCb_420_SP: 117 supportedPreviewFormats += 118 CameraParameters::PIXEL_FORMAT_YUV420SP; 119 break; 120 case HAL_PIXEL_FORMAT_YCbCr_422_I: 121 supportedPreviewFormats += 122 CameraParameters::PIXEL_FORMAT_YUV422I; 123 break; 124 case HAL_PIXEL_FORMAT_YV12: 125 supportedPreviewFormats += 126 CameraParameters::PIXEL_FORMAT_YUV420P; 127 break; 128 case HAL_PIXEL_FORMAT_RGB_565: 129 supportedPreviewFormats += 130 CameraParameters::PIXEL_FORMAT_RGB565; 131 break; 132 case HAL_PIXEL_FORMAT_RGBA_8888: 133 supportedPreviewFormats += 134 CameraParameters::PIXEL_FORMAT_RGBA8888; 135 break; 136 case HAL_PIXEL_FORMAT_YCbCr_420_888: 137 // Flexible YUV allows both YV12 and NV21 138 supportedPreviewFormats += 139 CameraParameters::PIXEL_FORMAT_YUV420P; 140 supportedPreviewFormats += ","; 141 supportedPreviewFormats += 142 CameraParameters::PIXEL_FORMAT_YUV420SP; 143 break; 144 // Not advertizing JPEG, RAW_SENSOR, etc, for preview formats 145 case HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED: 146 case HAL_PIXEL_FORMAT_RAW_SENSOR: 147 case HAL_PIXEL_FORMAT_BLOB: 148 addComma = false; 149 break; 150 151 default: 152 ALOGW("%s: Camera %d: Unknown preview format: %x", 153 __FUNCTION__, cameraId, availableFormats.data.i32[i]); 154 addComma = false; 155 break; 156 } 157 } 158 params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FORMATS, 159 supportedPreviewFormats); 160 } 161 162 previewFpsRange[0] = availableFpsRanges.data.i32[0]; 163 previewFpsRange[1] = availableFpsRanges.data.i32[1]; 164 165 // PREVIEW_FRAME_RATE / SUPPORTED_PREVIEW_FRAME_RATES are deprecated, but 166 // still have to do something sane for them 167 168 // NOTE: Not scaled like FPS range values are. 169 int previewFps = fpsFromRange(previewFpsRange[0], previewFpsRange[1]); 170 params.set(CameraParameters::KEY_PREVIEW_FRAME_RATE, 171 previewFps); 172 173 // PREVIEW_FPS_RANGE 174 // -- Order matters. Set range after single value to so that a roundtrip 175 // of setParameters(getParameters()) would keep the FPS range in higher 176 // order. 177 params.set(CameraParameters::KEY_PREVIEW_FPS_RANGE, 178 String8::format("%d,%d", 179 previewFpsRange[0] * kFpsToApiScale, 180 previewFpsRange[1] * kFpsToApiScale)); 181 182 { 183 String8 supportedPreviewFpsRange; 184 for (size_t i=0; i < availableFpsRanges.count; i += 2) { 185 if (i != 0) supportedPreviewFpsRange += ","; 186 supportedPreviewFpsRange += String8::format("(%d,%d)", 187 availableFpsRanges.data.i32[i] * kFpsToApiScale, 188 availableFpsRanges.data.i32[i+1] * kFpsToApiScale); 189 } 190 params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FPS_RANGE, 191 supportedPreviewFpsRange); 192 } 193 194 { 195 SortedVector<int32_t> sortedPreviewFrameRates; 196 197 String8 supportedPreviewFrameRates; 198 for (size_t i=0; i < availableFpsRanges.count; i += 2) { 199 // from the [min, max] fps range use the max value 200 int fps = fpsFromRange(availableFpsRanges.data.i32[i], 201 availableFpsRanges.data.i32[i+1]); 202 203 // de-dupe frame rates 204 if (sortedPreviewFrameRates.indexOf(fps) == NAME_NOT_FOUND) { 205 sortedPreviewFrameRates.add(fps); 206 } 207 else { 208 continue; 209 } 210 211 if (sortedPreviewFrameRates.size() > 1) { 212 supportedPreviewFrameRates += ","; 213 } 214 215 supportedPreviewFrameRates += String8::format("%d", 216 fps); 217 218 ALOGV("%s: Supported preview frame rates: %s", 219 __FUNCTION__, supportedPreviewFrameRates.string()); 220 } 221 params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FRAME_RATES, 222 supportedPreviewFrameRates); 223 } 224 225 camera_metadata_ro_entry_t availableJpegSizes = 226 staticInfo(ANDROID_SCALER_AVAILABLE_JPEG_SIZES, 2); 227 if (!availableJpegSizes.count) return NO_INIT; 228 229 // TODO: Pick maximum 230 pictureWidth = availableJpegSizes.data.i32[0]; 231 pictureHeight = availableJpegSizes.data.i32[1]; 232 233 params.setPictureSize(pictureWidth, 234 pictureHeight); 235 236 { 237 String8 supportedPictureSizes; 238 for (size_t i=0; i < availableJpegSizes.count; i += 2) { 239 if (i != 0) supportedPictureSizes += ","; 240 supportedPictureSizes += String8::format("%dx%d", 241 availableJpegSizes.data.i32[i], 242 availableJpegSizes.data.i32[i+1]); 243 } 244 params.set(CameraParameters::KEY_SUPPORTED_PICTURE_SIZES, 245 supportedPictureSizes); 246 } 247 248 params.setPictureFormat(CameraParameters::PIXEL_FORMAT_JPEG); 249 params.set(CameraParameters::KEY_SUPPORTED_PICTURE_FORMATS, 250 CameraParameters::PIXEL_FORMAT_JPEG); 251 252 camera_metadata_ro_entry_t availableJpegThumbnailSizes = 253 staticInfo(ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES, 4); 254 if (!availableJpegThumbnailSizes.count) return NO_INIT; 255 256 // Pick the largest thumbnail size that matches still image aspect ratio. 257 ALOG_ASSERT(pictureWidth > 0 && pictureHeight > 0, 258 "Invalid picture size, %d x %d", pictureWidth, pictureHeight); 259 float picAspectRatio = static_cast<float>(pictureWidth) / pictureHeight; 260 Size thumbnailSize = 261 getMaxSizeForRatio( 262 picAspectRatio, 263 &availableJpegThumbnailSizes.data.i32[0], 264 availableJpegThumbnailSizes.count); 265 jpegThumbSize[0] = thumbnailSize.width; 266 jpegThumbSize[1] = thumbnailSize.height; 267 268 params.set(CameraParameters::KEY_JPEG_THUMBNAIL_WIDTH, 269 jpegThumbSize[0]); 270 params.set(CameraParameters::KEY_JPEG_THUMBNAIL_HEIGHT, 271 jpegThumbSize[1]); 272 273 { 274 String8 supportedJpegThumbSizes; 275 for (size_t i=0; i < availableJpegThumbnailSizes.count; i += 2) { 276 if (i != 0) supportedJpegThumbSizes += ","; 277 supportedJpegThumbSizes += String8::format("%dx%d", 278 availableJpegThumbnailSizes.data.i32[i], 279 availableJpegThumbnailSizes.data.i32[i+1]); 280 } 281 params.set(CameraParameters::KEY_SUPPORTED_JPEG_THUMBNAIL_SIZES, 282 supportedJpegThumbSizes); 283 } 284 285 jpegThumbQuality = 90; 286 params.set(CameraParameters::KEY_JPEG_THUMBNAIL_QUALITY, 287 jpegThumbQuality); 288 jpegQuality = 90; 289 params.set(CameraParameters::KEY_JPEG_QUALITY, 290 jpegQuality); 291 jpegRotation = 0; 292 params.set(CameraParameters::KEY_ROTATION, 293 jpegRotation); 294 295 gpsEnabled = false; 296 gpsCoordinates[0] = 0.0; 297 gpsCoordinates[1] = 0.0; 298 gpsCoordinates[2] = 0.0; 299 gpsTimestamp = 0; 300 gpsProcessingMethod = "unknown"; 301 // GPS fields in CameraParameters are not set by implementation 302 303 wbMode = ANDROID_CONTROL_AWB_MODE_AUTO; 304 params.set(CameraParameters::KEY_WHITE_BALANCE, 305 CameraParameters::WHITE_BALANCE_AUTO); 306 307 camera_metadata_ro_entry_t availableWhiteBalanceModes = 308 staticInfo(ANDROID_CONTROL_AWB_AVAILABLE_MODES, 0, 0, false); 309 if (!availableWhiteBalanceModes.count) { 310 params.set(CameraParameters::KEY_SUPPORTED_WHITE_BALANCE, 311 CameraParameters::WHITE_BALANCE_AUTO); 312 } else { 313 String8 supportedWhiteBalance; 314 bool addComma = false; 315 for (size_t i=0; i < availableWhiteBalanceModes.count; i++) { 316 if (addComma) supportedWhiteBalance += ","; 317 addComma = true; 318 switch (availableWhiteBalanceModes.data.u8[i]) { 319 case ANDROID_CONTROL_AWB_MODE_AUTO: 320 supportedWhiteBalance += 321 CameraParameters::WHITE_BALANCE_AUTO; 322 break; 323 case ANDROID_CONTROL_AWB_MODE_INCANDESCENT: 324 supportedWhiteBalance += 325 CameraParameters::WHITE_BALANCE_INCANDESCENT; 326 break; 327 case ANDROID_CONTROL_AWB_MODE_FLUORESCENT: 328 supportedWhiteBalance += 329 CameraParameters::WHITE_BALANCE_FLUORESCENT; 330 break; 331 case ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT: 332 supportedWhiteBalance += 333 CameraParameters::WHITE_BALANCE_WARM_FLUORESCENT; 334 break; 335 case ANDROID_CONTROL_AWB_MODE_DAYLIGHT: 336 supportedWhiteBalance += 337 CameraParameters::WHITE_BALANCE_DAYLIGHT; 338 break; 339 case ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT: 340 supportedWhiteBalance += 341 CameraParameters::WHITE_BALANCE_CLOUDY_DAYLIGHT; 342 break; 343 case ANDROID_CONTROL_AWB_MODE_TWILIGHT: 344 supportedWhiteBalance += 345 CameraParameters::WHITE_BALANCE_TWILIGHT; 346 break; 347 case ANDROID_CONTROL_AWB_MODE_SHADE: 348 supportedWhiteBalance += 349 CameraParameters::WHITE_BALANCE_SHADE; 350 break; 351 // Skipping values not mappable to v1 API 352 case ANDROID_CONTROL_AWB_MODE_OFF: 353 addComma = false; 354 break; 355 default: 356 ALOGW("%s: Camera %d: Unknown white balance value: %d", 357 __FUNCTION__, cameraId, 358 availableWhiteBalanceModes.data.u8[i]); 359 addComma = false; 360 break; 361 } 362 } 363 params.set(CameraParameters::KEY_SUPPORTED_WHITE_BALANCE, 364 supportedWhiteBalance); 365 } 366 367 effectMode = ANDROID_CONTROL_EFFECT_MODE_OFF; 368 params.set(CameraParameters::KEY_EFFECT, 369 CameraParameters::EFFECT_NONE); 370 371 camera_metadata_ro_entry_t availableEffects = 372 staticInfo(ANDROID_CONTROL_AVAILABLE_EFFECTS, 0, 0, false); 373 if (!availableEffects.count) { 374 params.set(CameraParameters::KEY_SUPPORTED_EFFECTS, 375 CameraParameters::EFFECT_NONE); 376 } else { 377 String8 supportedEffects; 378 bool addComma = false; 379 for (size_t i=0; i < availableEffects.count; i++) { 380 if (addComma) supportedEffects += ","; 381 addComma = true; 382 switch (availableEffects.data.u8[i]) { 383 case ANDROID_CONTROL_EFFECT_MODE_OFF: 384 supportedEffects += 385 CameraParameters::EFFECT_NONE; 386 break; 387 case ANDROID_CONTROL_EFFECT_MODE_MONO: 388 supportedEffects += 389 CameraParameters::EFFECT_MONO; 390 break; 391 case ANDROID_CONTROL_EFFECT_MODE_NEGATIVE: 392 supportedEffects += 393 CameraParameters::EFFECT_NEGATIVE; 394 break; 395 case ANDROID_CONTROL_EFFECT_MODE_SOLARIZE: 396 supportedEffects += 397 CameraParameters::EFFECT_SOLARIZE; 398 break; 399 case ANDROID_CONTROL_EFFECT_MODE_SEPIA: 400 supportedEffects += 401 CameraParameters::EFFECT_SEPIA; 402 break; 403 case ANDROID_CONTROL_EFFECT_MODE_POSTERIZE: 404 supportedEffects += 405 CameraParameters::EFFECT_POSTERIZE; 406 break; 407 case ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD: 408 supportedEffects += 409 CameraParameters::EFFECT_WHITEBOARD; 410 break; 411 case ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD: 412 supportedEffects += 413 CameraParameters::EFFECT_BLACKBOARD; 414 break; 415 case ANDROID_CONTROL_EFFECT_MODE_AQUA: 416 supportedEffects += 417 CameraParameters::EFFECT_AQUA; 418 break; 419 default: 420 ALOGW("%s: Camera %d: Unknown effect value: %d", 421 __FUNCTION__, cameraId, availableEffects.data.u8[i]); 422 addComma = false; 423 break; 424 } 425 } 426 params.set(CameraParameters::KEY_SUPPORTED_EFFECTS, supportedEffects); 427 } 428 429 antibandingMode = ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO; 430 params.set(CameraParameters::KEY_ANTIBANDING, 431 CameraParameters::ANTIBANDING_AUTO); 432 433 camera_metadata_ro_entry_t availableAntibandingModes = 434 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES, 0, 0, false); 435 if (!availableAntibandingModes.count) { 436 params.set(CameraParameters::KEY_SUPPORTED_ANTIBANDING, 437 CameraParameters::ANTIBANDING_OFF); 438 } else { 439 String8 supportedAntibanding; 440 bool addComma = false; 441 for (size_t i=0; i < availableAntibandingModes.count; i++) { 442 if (addComma) supportedAntibanding += ","; 443 addComma = true; 444 switch (availableAntibandingModes.data.u8[i]) { 445 case ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF: 446 supportedAntibanding += 447 CameraParameters::ANTIBANDING_OFF; 448 break; 449 case ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ: 450 supportedAntibanding += 451 CameraParameters::ANTIBANDING_50HZ; 452 break; 453 case ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ: 454 supportedAntibanding += 455 CameraParameters::ANTIBANDING_60HZ; 456 break; 457 case ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO: 458 supportedAntibanding += 459 CameraParameters::ANTIBANDING_AUTO; 460 break; 461 default: 462 ALOGW("%s: Camera %d: Unknown antibanding value: %d", 463 __FUNCTION__, cameraId, 464 availableAntibandingModes.data.u8[i]); 465 addComma = false; 466 break; 467 } 468 } 469 params.set(CameraParameters::KEY_SUPPORTED_ANTIBANDING, 470 supportedAntibanding); 471 } 472 473 sceneMode = ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED; 474 params.set(CameraParameters::KEY_SCENE_MODE, 475 CameraParameters::SCENE_MODE_AUTO); 476 477 camera_metadata_ro_entry_t availableSceneModes = 478 staticInfo(ANDROID_CONTROL_AVAILABLE_SCENE_MODES, 0, 0, false); 479 if (!availableSceneModes.count) { 480 params.remove(CameraParameters::KEY_SCENE_MODE); 481 } else { 482 String8 supportedSceneModes(CameraParameters::SCENE_MODE_AUTO); 483 bool addComma = true; 484 bool noSceneModes = false; 485 for (size_t i=0; i < availableSceneModes.count; i++) { 486 if (addComma) supportedSceneModes += ","; 487 addComma = true; 488 switch (availableSceneModes.data.u8[i]) { 489 case ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED: 490 noSceneModes = true; 491 break; 492 case ANDROID_CONTROL_SCENE_MODE_FACE_PRIORITY: 493 // Not in old API 494 addComma = false; 495 break; 496 case ANDROID_CONTROL_SCENE_MODE_ACTION: 497 supportedSceneModes += 498 CameraParameters::SCENE_MODE_ACTION; 499 break; 500 case ANDROID_CONTROL_SCENE_MODE_PORTRAIT: 501 supportedSceneModes += 502 CameraParameters::SCENE_MODE_PORTRAIT; 503 break; 504 case ANDROID_CONTROL_SCENE_MODE_LANDSCAPE: 505 supportedSceneModes += 506 CameraParameters::SCENE_MODE_LANDSCAPE; 507 break; 508 case ANDROID_CONTROL_SCENE_MODE_NIGHT: 509 supportedSceneModes += 510 CameraParameters::SCENE_MODE_NIGHT; 511 break; 512 case ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT: 513 supportedSceneModes += 514 CameraParameters::SCENE_MODE_NIGHT_PORTRAIT; 515 break; 516 case ANDROID_CONTROL_SCENE_MODE_THEATRE: 517 supportedSceneModes += 518 CameraParameters::SCENE_MODE_THEATRE; 519 break; 520 case ANDROID_CONTROL_SCENE_MODE_BEACH: 521 supportedSceneModes += 522 CameraParameters::SCENE_MODE_BEACH; 523 break; 524 case ANDROID_CONTROL_SCENE_MODE_SNOW: 525 supportedSceneModes += 526 CameraParameters::SCENE_MODE_SNOW; 527 break; 528 case ANDROID_CONTROL_SCENE_MODE_SUNSET: 529 supportedSceneModes += 530 CameraParameters::SCENE_MODE_SUNSET; 531 break; 532 case ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO: 533 supportedSceneModes += 534 CameraParameters::SCENE_MODE_STEADYPHOTO; 535 break; 536 case ANDROID_CONTROL_SCENE_MODE_FIREWORKS: 537 supportedSceneModes += 538 CameraParameters::SCENE_MODE_FIREWORKS; 539 break; 540 case ANDROID_CONTROL_SCENE_MODE_SPORTS: 541 supportedSceneModes += 542 CameraParameters::SCENE_MODE_SPORTS; 543 break; 544 case ANDROID_CONTROL_SCENE_MODE_PARTY: 545 supportedSceneModes += 546 CameraParameters::SCENE_MODE_PARTY; 547 break; 548 case ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT: 549 supportedSceneModes += 550 CameraParameters::SCENE_MODE_CANDLELIGHT; 551 break; 552 case ANDROID_CONTROL_SCENE_MODE_BARCODE: 553 supportedSceneModes += 554 CameraParameters::SCENE_MODE_BARCODE; 555 break; 556 default: 557 ALOGW("%s: Camera %d: Unknown scene mode value: %d", 558 __FUNCTION__, cameraId, 559 availableSceneModes.data.u8[i]); 560 addComma = false; 561 break; 562 } 563 } 564 if (!noSceneModes) { 565 params.set(CameraParameters::KEY_SUPPORTED_SCENE_MODES, 566 supportedSceneModes); 567 } else { 568 params.remove(CameraParameters::KEY_SCENE_MODE); 569 } 570 } 571 572 bool isFlashAvailable = false; 573 camera_metadata_ro_entry_t flashAvailable = 574 staticInfo(ANDROID_FLASH_INFO_AVAILABLE, 0, 1, false); 575 if (flashAvailable.count) { 576 isFlashAvailable = flashAvailable.data.u8[0]; 577 } 578 579 camera_metadata_ro_entry_t availableAeModes = 580 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_MODES, 0, 0, false); 581 582 if (isFlashAvailable) { 583 flashMode = Parameters::FLASH_MODE_OFF; 584 params.set(CameraParameters::KEY_FLASH_MODE, 585 CameraParameters::FLASH_MODE_OFF); 586 587 String8 supportedFlashModes(CameraParameters::FLASH_MODE_OFF); 588 supportedFlashModes = supportedFlashModes + 589 "," + CameraParameters::FLASH_MODE_AUTO + 590 "," + CameraParameters::FLASH_MODE_ON + 591 "," + CameraParameters::FLASH_MODE_TORCH; 592 for (size_t i=0; i < availableAeModes.count; i++) { 593 if (availableAeModes.data.u8[i] == 594 ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH_REDEYE) { 595 supportedFlashModes = supportedFlashModes + "," + 596 CameraParameters::FLASH_MODE_RED_EYE; 597 break; 598 } 599 } 600 params.set(CameraParameters::KEY_SUPPORTED_FLASH_MODES, 601 supportedFlashModes); 602 } else { 603 flashMode = Parameters::FLASH_MODE_OFF; 604 params.set(CameraParameters::KEY_FLASH_MODE, 605 CameraParameters::FLASH_MODE_OFF); 606 params.set(CameraParameters::KEY_SUPPORTED_FLASH_MODES, 607 CameraParameters::FLASH_MODE_OFF); 608 } 609 610 camera_metadata_ro_entry_t minFocusDistance = 611 staticInfo(ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE, 0, 1, false); 612 613 camera_metadata_ro_entry_t availableAfModes = 614 staticInfo(ANDROID_CONTROL_AF_AVAILABLE_MODES, 0, 0, false); 615 616 if (!minFocusDistance.count || minFocusDistance.data.f[0] == 0) { 617 // Fixed-focus lens 618 focusMode = Parameters::FOCUS_MODE_FIXED; 619 params.set(CameraParameters::KEY_FOCUS_MODE, 620 CameraParameters::FOCUS_MODE_FIXED); 621 params.set(CameraParameters::KEY_SUPPORTED_FOCUS_MODES, 622 CameraParameters::FOCUS_MODE_FIXED); 623 } else { 624 focusMode = Parameters::FOCUS_MODE_AUTO; 625 params.set(CameraParameters::KEY_FOCUS_MODE, 626 CameraParameters::FOCUS_MODE_AUTO); 627 String8 supportedFocusModes(CameraParameters::FOCUS_MODE_INFINITY); 628 bool addComma = true; 629 630 for (size_t i=0; i < availableAfModes.count; i++) { 631 if (addComma) supportedFocusModes += ","; 632 addComma = true; 633 switch (availableAfModes.data.u8[i]) { 634 case ANDROID_CONTROL_AF_MODE_AUTO: 635 supportedFocusModes += 636 CameraParameters::FOCUS_MODE_AUTO; 637 break; 638 case ANDROID_CONTROL_AF_MODE_MACRO: 639 supportedFocusModes += 640 CameraParameters::FOCUS_MODE_MACRO; 641 break; 642 case ANDROID_CONTROL_AF_MODE_CONTINUOUS_VIDEO: 643 supportedFocusModes += 644 CameraParameters::FOCUS_MODE_CONTINUOUS_VIDEO; 645 break; 646 case ANDROID_CONTROL_AF_MODE_CONTINUOUS_PICTURE: 647 supportedFocusModes += 648 CameraParameters::FOCUS_MODE_CONTINUOUS_PICTURE; 649 break; 650 case ANDROID_CONTROL_AF_MODE_EDOF: 651 supportedFocusModes += 652 CameraParameters::FOCUS_MODE_EDOF; 653 break; 654 // Not supported in old API 655 case ANDROID_CONTROL_AF_MODE_OFF: 656 addComma = false; 657 break; 658 default: 659 ALOGW("%s: Camera %d: Unknown AF mode value: %d", 660 __FUNCTION__, cameraId, availableAfModes.data.u8[i]); 661 addComma = false; 662 break; 663 } 664 } 665 params.set(CameraParameters::KEY_SUPPORTED_FOCUS_MODES, 666 supportedFocusModes); 667 } 668 focusState = ANDROID_CONTROL_AF_STATE_INACTIVE; 669 shadowFocusMode = FOCUS_MODE_INVALID; 670 671 camera_metadata_ro_entry_t max3aRegions = 672 staticInfo(ANDROID_CONTROL_MAX_REGIONS, 1, 1); 673 if (!max3aRegions.count) return NO_INIT; 674 675 int32_t maxNumFocusAreas = 0; 676 if (focusMode != Parameters::FOCUS_MODE_FIXED) { 677 maxNumFocusAreas = max3aRegions.data.i32[0]; 678 } 679 params.set(CameraParameters::KEY_MAX_NUM_FOCUS_AREAS, maxNumFocusAreas); 680 params.set(CameraParameters::KEY_FOCUS_AREAS, 681 "(0,0,0,0,0)"); 682 focusingAreas.clear(); 683 focusingAreas.add(Parameters::Area(0,0,0,0,0)); 684 685 camera_metadata_ro_entry_t availableFocalLengths = 686 staticInfo(ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS, 0, 0, false); 687 if (!availableFocalLengths.count) return NO_INIT; 688 689 float minFocalLength = availableFocalLengths.data.f[0]; 690 params.setFloat(CameraParameters::KEY_FOCAL_LENGTH, minFocalLength); 691 692 float horizFov, vertFov; 693 res = calculatePictureFovs(&horizFov, &vertFov); 694 if (res != OK) { 695 ALOGE("%s: Can't calculate field of views!", __FUNCTION__); 696 return res; 697 } 698 699 params.setFloat(CameraParameters::KEY_HORIZONTAL_VIEW_ANGLE, horizFov); 700 params.setFloat(CameraParameters::KEY_VERTICAL_VIEW_ANGLE, vertFov); 701 702 exposureCompensation = 0; 703 params.set(CameraParameters::KEY_EXPOSURE_COMPENSATION, 704 exposureCompensation); 705 706 camera_metadata_ro_entry_t exposureCompensationRange = 707 staticInfo(ANDROID_CONTROL_AE_COMPENSATION_RANGE, 2, 2); 708 if (!exposureCompensationRange.count) return NO_INIT; 709 710 params.set(CameraParameters::KEY_MAX_EXPOSURE_COMPENSATION, 711 exposureCompensationRange.data.i32[1]); 712 params.set(CameraParameters::KEY_MIN_EXPOSURE_COMPENSATION, 713 exposureCompensationRange.data.i32[0]); 714 715 camera_metadata_ro_entry_t exposureCompensationStep = 716 staticInfo(ANDROID_CONTROL_AE_COMPENSATION_STEP, 1, 1); 717 if (!exposureCompensationStep.count) return NO_INIT; 718 719 params.setFloat(CameraParameters::KEY_EXPOSURE_COMPENSATION_STEP, 720 (float)exposureCompensationStep.data.r[0].numerator / 721 exposureCompensationStep.data.r[0].denominator); 722 723 autoExposureLock = false; 724 params.set(CameraParameters::KEY_AUTO_EXPOSURE_LOCK, 725 CameraParameters::FALSE); 726 params.set(CameraParameters::KEY_AUTO_EXPOSURE_LOCK_SUPPORTED, 727 CameraParameters::TRUE); 728 729 autoWhiteBalanceLock = false; 730 params.set(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK, 731 CameraParameters::FALSE); 732 params.set(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK_SUPPORTED, 733 CameraParameters::TRUE); 734 735 meteringAreas.add(Parameters::Area(0, 0, 0, 0, 0)); 736 params.set(CameraParameters::KEY_MAX_NUM_METERING_AREAS, 737 max3aRegions.data.i32[0]); 738 params.set(CameraParameters::KEY_METERING_AREAS, 739 "(0,0,0,0,0)"); 740 741 zoom = 0; 742 params.set(CameraParameters::KEY_ZOOM, zoom); 743 params.set(CameraParameters::KEY_MAX_ZOOM, NUM_ZOOM_STEPS - 1); 744 745 camera_metadata_ro_entry_t maxDigitalZoom = 746 staticInfo(ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM, /*minCount*/1, /*maxCount*/1); 747 if (!maxDigitalZoom.count) return NO_INIT; 748 749 { 750 String8 zoomRatios; 751 float zoom = 1.f; 752 float zoomIncrement = (maxDigitalZoom.data.f[0] - zoom) / 753 (NUM_ZOOM_STEPS-1); 754 bool addComma = false; 755 for (size_t i=0; i < NUM_ZOOM_STEPS; i++) { 756 if (addComma) zoomRatios += ","; 757 addComma = true; 758 zoomRatios += String8::format("%d", static_cast<int>(zoom * 100)); 759 zoom += zoomIncrement; 760 } 761 params.set(CameraParameters::KEY_ZOOM_RATIOS, zoomRatios); 762 } 763 764 params.set(CameraParameters::KEY_ZOOM_SUPPORTED, 765 CameraParameters::TRUE); 766 params.set(CameraParameters::KEY_SMOOTH_ZOOM_SUPPORTED, 767 CameraParameters::FALSE); 768 769 params.set(CameraParameters::KEY_FOCUS_DISTANCES, 770 "Infinity,Infinity,Infinity"); 771 772 params.set(CameraParameters::KEY_MAX_NUM_DETECTED_FACES_HW, 773 fastInfo.maxFaces); 774 params.set(CameraParameters::KEY_MAX_NUM_DETECTED_FACES_SW, 775 0); 776 777 params.set(CameraParameters::KEY_VIDEO_FRAME_FORMAT, 778 CameraParameters::PIXEL_FORMAT_ANDROID_OPAQUE); 779 780 recordingHint = false; 781 params.set(CameraParameters::KEY_RECORDING_HINT, 782 CameraParameters::FALSE); 783 784 params.set(CameraParameters::KEY_VIDEO_SNAPSHOT_SUPPORTED, 785 CameraParameters::TRUE); 786 787 videoStabilization = false; 788 params.set(CameraParameters::KEY_VIDEO_STABILIZATION, 789 CameraParameters::FALSE); 790 791 camera_metadata_ro_entry_t availableVideoStabilizationModes = 792 staticInfo(ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES, 0, 0, 793 false); 794 795 if (availableVideoStabilizationModes.count > 1) { 796 params.set(CameraParameters::KEY_VIDEO_STABILIZATION_SUPPORTED, 797 CameraParameters::TRUE); 798 } else { 799 params.set(CameraParameters::KEY_VIDEO_STABILIZATION_SUPPORTED, 800 CameraParameters::FALSE); 801 } 802 803 // Set up initial state for non-Camera.Parameters state variables 804 805 storeMetadataInBuffers = true; 806 playShutterSound = true; 807 enableFaceDetect = false; 808 809 enableFocusMoveMessages = false; 810 afTriggerCounter = 1; 811 afStateCounter = 0; 812 currentAfTriggerId = -1; 813 afInMotion = false; 814 815 precaptureTriggerCounter = 1; 816 817 takePictureCounter = 0; 818 819 previewCallbackFlags = 0; 820 previewCallbackOneShot = false; 821 previewCallbackSurface = false; 822 823 char value[PROPERTY_VALUE_MAX]; 824 property_get("camera.disable_zsl_mode", value, "0"); 825 if (!strcmp(value,"1")) { 826 ALOGI("Camera %d: Disabling ZSL mode", cameraId); 827 zslMode = false; 828 } else { 829 zslMode = true; 830 } 831 832 lightFx = LIGHTFX_NONE; 833 834 state = STOPPED; 835 836 paramsFlattened = params.flatten(); 837 838 return OK; 839} 840 841String8 Parameters::get() const { 842 return paramsFlattened; 843} 844 845status_t Parameters::buildFastInfo() { 846 847 camera_metadata_ro_entry_t activeArraySize = 848 staticInfo(ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE, 2, 4); 849 if (!activeArraySize.count) return NO_INIT; 850 int32_t arrayWidth; 851 int32_t arrayHeight; 852 if (activeArraySize.count == 2) { 853 ALOGW("%s: Camera %d: activeArraySize is missing xmin/ymin!", 854 __FUNCTION__, cameraId); 855 arrayWidth = activeArraySize.data.i32[0]; 856 arrayHeight = activeArraySize.data.i32[1]; 857 } else if (activeArraySize.count == 4) { 858 arrayWidth = activeArraySize.data.i32[2]; 859 arrayHeight = activeArraySize.data.i32[3]; 860 } else return NO_INIT; 861 862 // We'll set the target FPS range for still captures to be as wide 863 // as possible to give the HAL maximum latitude for exposure selection 864 camera_metadata_ro_entry_t availableFpsRanges = 865 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES, 2); 866 if (availableFpsRanges.count < 2 || availableFpsRanges.count % 2 != 0) { 867 return NO_INIT; 868 } 869 870 int32_t bestStillCaptureFpsRange[2] = { 871 availableFpsRanges.data.i32[0], availableFpsRanges.data.i32[1] 872 }; 873 int32_t curRange = 874 bestStillCaptureFpsRange[1] - bestStillCaptureFpsRange[0]; 875 for (size_t i = 2; i < availableFpsRanges.count; i += 2) { 876 int32_t nextRange = 877 availableFpsRanges.data.i32[i + 1] - 878 availableFpsRanges.data.i32[i]; 879 if ( (nextRange > curRange) || // Maximize size of FPS range first 880 (nextRange == curRange && // Then minimize low-end FPS 881 bestStillCaptureFpsRange[0] > availableFpsRanges.data.i32[i])) { 882 883 bestStillCaptureFpsRange[0] = availableFpsRanges.data.i32[i]; 884 bestStillCaptureFpsRange[1] = availableFpsRanges.data.i32[i + 1]; 885 curRange = nextRange; 886 } 887 } 888 889 camera_metadata_ro_entry_t availableFaceDetectModes = 890 staticInfo(ANDROID_STATISTICS_INFO_AVAILABLE_FACE_DETECT_MODES, 0, 0, 891 false); 892 893 uint8_t bestFaceDetectMode = 894 ANDROID_STATISTICS_FACE_DETECT_MODE_OFF; 895 for (size_t i = 0 ; i < availableFaceDetectModes.count; i++) { 896 switch (availableFaceDetectModes.data.u8[i]) { 897 case ANDROID_STATISTICS_FACE_DETECT_MODE_OFF: 898 break; 899 case ANDROID_STATISTICS_FACE_DETECT_MODE_SIMPLE: 900 if (bestFaceDetectMode != 901 ANDROID_STATISTICS_FACE_DETECT_MODE_FULL) { 902 bestFaceDetectMode = 903 ANDROID_STATISTICS_FACE_DETECT_MODE_SIMPLE; 904 } 905 break; 906 case ANDROID_STATISTICS_FACE_DETECT_MODE_FULL: 907 bestFaceDetectMode = 908 ANDROID_STATISTICS_FACE_DETECT_MODE_FULL; 909 break; 910 default: 911 ALOGE("%s: Camera %d: Unknown face detect mode %d:", 912 __FUNCTION__, cameraId, 913 availableFaceDetectModes.data.u8[i]); 914 return NO_INIT; 915 } 916 } 917 918 int32_t maxFaces = 0; 919 camera_metadata_ro_entry_t maxFacesDetected = 920 staticInfo(ANDROID_STATISTICS_INFO_MAX_FACE_COUNT, 0, 1, false); 921 if (maxFacesDetected.count) { 922 maxFaces = maxFacesDetected.data.i32[0]; 923 } 924 925 camera_metadata_ro_entry_t availableSceneModes = 926 staticInfo(ANDROID_CONTROL_AVAILABLE_SCENE_MODES, 0, 0, false); 927 camera_metadata_ro_entry_t sceneModeOverrides = 928 staticInfo(ANDROID_CONTROL_SCENE_MODE_OVERRIDES, 0, 0, false); 929 camera_metadata_ro_entry_t minFocusDistance = 930 staticInfo(ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE, 0, 0, false); 931 bool fixedLens = minFocusDistance.count == 0 || 932 minFocusDistance.data.f[0] == 0; 933 934 camera_metadata_ro_entry_t availableFocalLengths = 935 staticInfo(ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS); 936 if (!availableFocalLengths.count) return NO_INIT; 937 938 camera_metadata_ro_entry_t availableFormats = 939 staticInfo(ANDROID_SCALER_AVAILABLE_FORMATS); 940 if (!availableFormats.count) return NO_INIT; 941 942 943 if (sceneModeOverrides.count > 0) { 944 // sceneModeOverrides is defined to have 3 entries for each scene mode, 945 // which are AE, AWB, and AF override modes the HAL wants for that scene 946 // mode. 947 const size_t kModesPerSceneMode = 3; 948 if (sceneModeOverrides.count != 949 availableSceneModes.count * kModesPerSceneMode) { 950 ALOGE("%s: Camera %d: Scene mode override list is an " 951 "unexpected size: %zu (expected %zu)", __FUNCTION__, 952 cameraId, sceneModeOverrides.count, 953 availableSceneModes.count); 954 return NO_INIT; 955 } 956 for (size_t i = 0; i < availableSceneModes.count; i++) { 957 DeviceInfo::OverrideModes modes; 958 uint8_t aeMode = 959 sceneModeOverrides.data.u8[i * kModesPerSceneMode + 0]; 960 switch(aeMode) { 961 case ANDROID_CONTROL_AE_MODE_ON: 962 modes.flashMode = FLASH_MODE_OFF; 963 break; 964 case ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH: 965 modes.flashMode = FLASH_MODE_AUTO; 966 break; 967 case ANDROID_CONTROL_AE_MODE_ON_ALWAYS_FLASH: 968 modes.flashMode = FLASH_MODE_ON; 969 break; 970 case ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH_REDEYE: 971 modes.flashMode = FLASH_MODE_RED_EYE; 972 break; 973 default: 974 ALOGE("%s: Unknown override AE mode: %d", __FUNCTION__, 975 aeMode); 976 modes.flashMode = FLASH_MODE_INVALID; 977 break; 978 } 979 modes.wbMode = 980 sceneModeOverrides.data.u8[i * kModesPerSceneMode + 1]; 981 uint8_t afMode = 982 sceneModeOverrides.data.u8[i * kModesPerSceneMode + 2]; 983 switch(afMode) { 984 case ANDROID_CONTROL_AF_MODE_OFF: 985 modes.focusMode = fixedLens ? 986 FOCUS_MODE_FIXED : FOCUS_MODE_INFINITY; 987 break; 988 case ANDROID_CONTROL_AF_MODE_AUTO: 989 case ANDROID_CONTROL_AF_MODE_MACRO: 990 case ANDROID_CONTROL_AF_MODE_CONTINUOUS_VIDEO: 991 case ANDROID_CONTROL_AF_MODE_CONTINUOUS_PICTURE: 992 case ANDROID_CONTROL_AF_MODE_EDOF: 993 modes.focusMode = static_cast<focusMode_t>(afMode); 994 break; 995 default: 996 ALOGE("%s: Unknown override AF mode: %d", __FUNCTION__, 997 afMode); 998 modes.focusMode = FOCUS_MODE_INVALID; 999 break; 1000 } 1001 fastInfo.sceneModeOverrides.add(availableSceneModes.data.u8[i], 1002 modes); 1003 } 1004 } 1005 1006 fastInfo.arrayWidth = arrayWidth; 1007 fastInfo.arrayHeight = arrayHeight; 1008 fastInfo.bestStillCaptureFpsRange[0] = bestStillCaptureFpsRange[0]; 1009 fastInfo.bestStillCaptureFpsRange[1] = bestStillCaptureFpsRange[1]; 1010 fastInfo.bestFaceDetectMode = bestFaceDetectMode; 1011 fastInfo.maxFaces = maxFaces; 1012 1013 // Find smallest (widest-angle) focal length to use as basis of still 1014 // picture FOV reporting. 1015 fastInfo.minFocalLength = availableFocalLengths.data.f[0]; 1016 for (size_t i = 1; i < availableFocalLengths.count; i++) { 1017 if (fastInfo.minFocalLength > availableFocalLengths.data.f[i]) { 1018 fastInfo.minFocalLength = availableFocalLengths.data.f[i]; 1019 } 1020 } 1021 1022 // Check if the HAL supports HAL_PIXEL_FORMAT_YCbCr_420_888 1023 fastInfo.useFlexibleYuv = false; 1024 for (size_t i = 0; i < availableFormats.count; i++) { 1025 if (availableFormats.data.i32[i] == HAL_PIXEL_FORMAT_YCbCr_420_888) { 1026 fastInfo.useFlexibleYuv = true; 1027 break; 1028 } 1029 } 1030 ALOGV("Camera %d: Flexible YUV %s supported", 1031 cameraId, fastInfo.useFlexibleYuv ? "is" : "is not"); 1032 1033 return OK; 1034} 1035 1036status_t Parameters::buildQuirks() { 1037 camera_metadata_ro_entry_t entry; 1038 entry = info->find(ANDROID_QUIRKS_TRIGGER_AF_WITH_AUTO); 1039 quirks.triggerAfWithAuto = (entry.count != 0 && entry.data.u8[0] == 1); 1040 ALOGV_IF(quirks.triggerAfWithAuto, "Camera %d: Quirk triggerAfWithAuto enabled", 1041 cameraId); 1042 1043 entry = info->find(ANDROID_QUIRKS_USE_ZSL_FORMAT); 1044 quirks.useZslFormat = (entry.count != 0 && entry.data.u8[0] == 1); 1045 ALOGV_IF(quirks.useZslFormat, "Camera %d: Quirk useZslFormat enabled", 1046 cameraId); 1047 1048 entry = info->find(ANDROID_QUIRKS_METERING_CROP_REGION); 1049 quirks.meteringCropRegion = (entry.count != 0 && entry.data.u8[0] == 1); 1050 ALOGV_IF(quirks.meteringCropRegion, "Camera %d: Quirk meteringCropRegion" 1051 " enabled", cameraId); 1052 1053 entry = info->find(ANDROID_QUIRKS_USE_PARTIAL_RESULT); 1054 quirks.partialResults = (entry.count != 0 && entry.data.u8[0] == 1); 1055 ALOGV_IF(quirks.partialResults, "Camera %d: Quirk usePartialResult" 1056 " enabled", cameraId); 1057 1058 return OK; 1059} 1060 1061camera_metadata_ro_entry_t Parameters::staticInfo(uint32_t tag, 1062 size_t minCount, size_t maxCount, bool required) const { 1063 camera_metadata_ro_entry_t entry = info->find(tag); 1064 1065 if (CC_UNLIKELY( entry.count == 0 ) && required) { 1066 const char* tagSection = get_camera_metadata_section_name(tag); 1067 if (tagSection == NULL) tagSection = "<unknown>"; 1068 const char* tagName = get_camera_metadata_tag_name(tag); 1069 if (tagName == NULL) tagName = "<unknown>"; 1070 1071 ALOGE("Error finding static metadata entry '%s.%s' (%x)", 1072 tagSection, tagName, tag); 1073 } else if (CC_UNLIKELY( 1074 (minCount != 0 && entry.count < minCount) || 1075 (maxCount != 0 && entry.count > maxCount) ) ) { 1076 const char* tagSection = get_camera_metadata_section_name(tag); 1077 if (tagSection == NULL) tagSection = "<unknown>"; 1078 const char* tagName = get_camera_metadata_tag_name(tag); 1079 if (tagName == NULL) tagName = "<unknown>"; 1080 ALOGE("Malformed static metadata entry '%s.%s' (%x):" 1081 "Expected between %zu and %zu values, but got %zu values", 1082 tagSection, tagName, tag, minCount, maxCount, entry.count); 1083 } 1084 1085 return entry; 1086} 1087 1088status_t Parameters::set(const String8& paramString) { 1089 status_t res; 1090 1091 CameraParameters2 newParams(paramString); 1092 1093 // TODO: Currently ignoring any changes to supposedly read-only parameters 1094 // such as supported preview sizes, etc. Should probably produce an error if 1095 // they're changed. 1096 1097 /** Extract and verify new parameters */ 1098 1099 size_t i; 1100 1101 Parameters validatedParams(*this); 1102 1103 // PREVIEW_SIZE 1104 newParams.getPreviewSize(&validatedParams.previewWidth, 1105 &validatedParams.previewHeight); 1106 1107 if (validatedParams.previewWidth != previewWidth || 1108 validatedParams.previewHeight != previewHeight) { 1109 if (state >= PREVIEW) { 1110 ALOGE("%s: Preview size cannot be updated when preview " 1111 "is active! (Currently %d x %d, requested %d x %d", 1112 __FUNCTION__, 1113 previewWidth, previewHeight, 1114 validatedParams.previewWidth, validatedParams.previewHeight); 1115 return BAD_VALUE; 1116 } 1117 for (i = 0; i < availablePreviewSizes.size(); i++) { 1118 if ((availablePreviewSizes[i].width == 1119 validatedParams.previewWidth) && 1120 (availablePreviewSizes[i].height == 1121 validatedParams.previewHeight)) break; 1122 } 1123 if (i == availablePreviewSizes.size()) { 1124 ALOGE("%s: Requested preview size %d x %d is not supported", 1125 __FUNCTION__, validatedParams.previewWidth, 1126 validatedParams.previewHeight); 1127 return BAD_VALUE; 1128 } 1129 } 1130 1131 // RECORDING_HINT (always supported) 1132 validatedParams.recordingHint = boolFromString( 1133 newParams.get(CameraParameters::KEY_RECORDING_HINT) ); 1134 IF_ALOGV() { // Avoid unused variable warning 1135 bool recordingHintChanged = 1136 validatedParams.recordingHint != recordingHint; 1137 if (recordingHintChanged) { 1138 ALOGV("%s: Recording hint changed to %d", 1139 __FUNCTION__, validatedParams.recordingHint); 1140 } 1141 } 1142 1143 // PREVIEW_FPS_RANGE 1144 1145 /** 1146 * Use the single FPS value if it was set later than the range. 1147 * Otherwise, use the range value. 1148 */ 1149 bool fpsUseSingleValue; 1150 { 1151 const char *fpsRange, *fpsSingle; 1152 1153 fpsRange = newParams.get(CameraParameters::KEY_PREVIEW_FRAME_RATE); 1154 fpsSingle = newParams.get(CameraParameters::KEY_PREVIEW_FPS_RANGE); 1155 1156 /** 1157 * Pick either the range or the single key if only one was set. 1158 * 1159 * If both are set, pick the one that has greater set order. 1160 */ 1161 if (fpsRange == NULL && fpsSingle == NULL) { 1162 ALOGE("%s: FPS was not set. One of %s or %s must be set.", 1163 __FUNCTION__, CameraParameters::KEY_PREVIEW_FRAME_RATE, 1164 CameraParameters::KEY_PREVIEW_FPS_RANGE); 1165 return BAD_VALUE; 1166 } else if (fpsRange == NULL) { 1167 fpsUseSingleValue = true; 1168 ALOGV("%s: FPS range not set, using FPS single value", 1169 __FUNCTION__); 1170 } else if (fpsSingle == NULL) { 1171 fpsUseSingleValue = false; 1172 ALOGV("%s: FPS single not set, using FPS range value", 1173 __FUNCTION__); 1174 } else { 1175 int fpsKeyOrder; 1176 res = newParams.compareSetOrder( 1177 CameraParameters::KEY_PREVIEW_FRAME_RATE, 1178 CameraParameters::KEY_PREVIEW_FPS_RANGE, 1179 &fpsKeyOrder); 1180 LOG_ALWAYS_FATAL_IF(res != OK, "Impossibly bad FPS keys"); 1181 1182 fpsUseSingleValue = (fpsKeyOrder > 0); 1183 1184 } 1185 1186 ALOGV("%s: Preview FPS value is used from '%s'", 1187 __FUNCTION__, fpsUseSingleValue ? "single" : "range"); 1188 } 1189 newParams.getPreviewFpsRange(&validatedParams.previewFpsRange[0], 1190 &validatedParams.previewFpsRange[1]); 1191 1192 validatedParams.previewFpsRange[0] /= kFpsToApiScale; 1193 validatedParams.previewFpsRange[1] /= kFpsToApiScale; 1194 1195 // Ignore the FPS range if the FPS single has higher precedence 1196 if (!fpsUseSingleValue) { 1197 ALOGV("%s: Preview FPS range (%d, %d)", __FUNCTION__, 1198 validatedParams.previewFpsRange[0], 1199 validatedParams.previewFpsRange[1]); 1200 1201 camera_metadata_ro_entry_t availablePreviewFpsRanges = 1202 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES, 2); 1203 for (i = 0; i < availablePreviewFpsRanges.count; i += 2) { 1204 if ((availablePreviewFpsRanges.data.i32[i] == 1205 validatedParams.previewFpsRange[0]) && 1206 (availablePreviewFpsRanges.data.i32[i+1] == 1207 validatedParams.previewFpsRange[1]) ) { 1208 break; 1209 } 1210 } 1211 if (i == availablePreviewFpsRanges.count) { 1212 ALOGE("%s: Requested preview FPS range %d - %d is not supported", 1213 __FUNCTION__, validatedParams.previewFpsRange[0], 1214 validatedParams.previewFpsRange[1]); 1215 return BAD_VALUE; 1216 } 1217 } 1218 1219 // PREVIEW_FORMAT 1220 validatedParams.previewFormat = 1221 formatStringToEnum(newParams.getPreviewFormat()); 1222 if (validatedParams.previewFormat != previewFormat) { 1223 if (state >= PREVIEW) { 1224 ALOGE("%s: Preview format cannot be updated when preview " 1225 "is active!", __FUNCTION__); 1226 return BAD_VALUE; 1227 } 1228 camera_metadata_ro_entry_t availableFormats = 1229 staticInfo(ANDROID_SCALER_AVAILABLE_FORMATS); 1230 // If using flexible YUV, always support NV21/YV12. Otherwise, check 1231 // HAL's list. 1232 if (! (fastInfo.useFlexibleYuv && 1233 (validatedParams.previewFormat == 1234 HAL_PIXEL_FORMAT_YCrCb_420_SP || 1235 validatedParams.previewFormat == 1236 HAL_PIXEL_FORMAT_YV12) ) ) { 1237 // Not using flexible YUV format, so check explicitly 1238 for (i = 0; i < availableFormats.count; i++) { 1239 if (availableFormats.data.i32[i] == 1240 validatedParams.previewFormat) break; 1241 } 1242 if (i == availableFormats.count) { 1243 ALOGE("%s: Requested preview format %s (0x%x) is not supported", 1244 __FUNCTION__, newParams.getPreviewFormat(), 1245 validatedParams.previewFormat); 1246 return BAD_VALUE; 1247 } 1248 } 1249 } 1250 1251 // PREVIEW_FRAME_RATE Deprecated 1252 // - Use only if the single FPS value was set later than the FPS range 1253 if (fpsUseSingleValue) { 1254 int previewFps = newParams.getPreviewFrameRate(); 1255 ALOGV("%s: Preview FPS single value requested: %d", 1256 __FUNCTION__, previewFps); 1257 { 1258 camera_metadata_ro_entry_t availableFrameRates = 1259 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES); 1260 /** 1261 * If recording hint is set, find the range that encompasses 1262 * previewFps with the largest min index. 1263 * 1264 * If recording hint is not set, find the range with previewFps 1265 * with the smallest min index. 1266 * 1267 * Either way, in case of multiple ranges, break the tie by 1268 * selecting the smaller range. 1269 */ 1270 1271 // all ranges which have previewFps 1272 Vector<Range> candidateRanges; 1273 for (i = 0; i < availableFrameRates.count; i+=2) { 1274 Range r = { 1275 availableFrameRates.data.i32[i], 1276 availableFrameRates.data.i32[i+1] 1277 }; 1278 1279 if (r.min <= previewFps && previewFps <= r.max) { 1280 candidateRanges.push(r); 1281 } 1282 } 1283 if (candidateRanges.isEmpty()) { 1284 ALOGE("%s: Requested preview frame rate %d is not supported", 1285 __FUNCTION__, previewFps); 1286 return BAD_VALUE; 1287 } 1288 // most applicable range with targetFps 1289 Range bestRange = candidateRanges[0]; 1290 for (i = 1; i < candidateRanges.size(); ++i) { 1291 Range r = candidateRanges[i]; 1292 1293 // Find by largest minIndex in recording mode 1294 if (validatedParams.recordingHint) { 1295 if (r.min > bestRange.min) { 1296 bestRange = r; 1297 } 1298 else if (r.min == bestRange.min && r.max < bestRange.max) { 1299 bestRange = r; 1300 } 1301 } 1302 // Find by smallest minIndex in preview mode 1303 else { 1304 if (r.min < bestRange.min) { 1305 bestRange = r; 1306 } 1307 else if (r.min == bestRange.min && r.max < bestRange.max) { 1308 bestRange = r; 1309 } 1310 } 1311 } 1312 1313 validatedParams.previewFpsRange[0] = 1314 bestRange.min; 1315 validatedParams.previewFpsRange[1] = 1316 bestRange.max; 1317 1318 ALOGV("%s: New preview FPS range: %d, %d, recordingHint = %d", 1319 __FUNCTION__, 1320 validatedParams.previewFpsRange[0], 1321 validatedParams.previewFpsRange[1], 1322 validatedParams.recordingHint); 1323 } 1324 } 1325 1326 /** 1327 * Update Preview FPS and Preview FPS ranges based on 1328 * what we actually set. 1329 * 1330 * This updates the API-visible (Camera.Parameters#getParameters) values of 1331 * the FPS fields, not only the internal versions. 1332 * 1333 * Order matters: The value that was set last takes precedence. 1334 * - If the client does a setParameters(getParameters()) we retain 1335 * the same order for preview FPS. 1336 */ 1337 if (!fpsUseSingleValue) { 1338 // Set fps single, then fps range (range wins) 1339 newParams.setPreviewFrameRate( 1340 fpsFromRange(/*min*/validatedParams.previewFpsRange[0], 1341 /*max*/validatedParams.previewFpsRange[1])); 1342 newParams.setPreviewFpsRange( 1343 validatedParams.previewFpsRange[0] * kFpsToApiScale, 1344 validatedParams.previewFpsRange[1] * kFpsToApiScale); 1345 } else { 1346 // Set fps range, then fps single (single wins) 1347 newParams.setPreviewFpsRange( 1348 validatedParams.previewFpsRange[0] * kFpsToApiScale, 1349 validatedParams.previewFpsRange[1] * kFpsToApiScale); 1350 // Set this to the same value, but with higher priority 1351 newParams.setPreviewFrameRate( 1352 newParams.getPreviewFrameRate()); 1353 } 1354 1355 // PICTURE_SIZE 1356 newParams.getPictureSize(&validatedParams.pictureWidth, 1357 &validatedParams.pictureHeight); 1358 if (validatedParams.pictureWidth == pictureWidth || 1359 validatedParams.pictureHeight == pictureHeight) { 1360 camera_metadata_ro_entry_t availablePictureSizes = 1361 staticInfo(ANDROID_SCALER_AVAILABLE_JPEG_SIZES); 1362 for (i = 0; i < availablePictureSizes.count; i+=2) { 1363 if ((availablePictureSizes.data.i32[i] == 1364 validatedParams.pictureWidth) && 1365 (availablePictureSizes.data.i32[i+1] == 1366 validatedParams.pictureHeight)) break; 1367 } 1368 if (i == availablePictureSizes.count) { 1369 ALOGE("%s: Requested picture size %d x %d is not supported", 1370 __FUNCTION__, validatedParams.pictureWidth, 1371 validatedParams.pictureHeight); 1372 return BAD_VALUE; 1373 } 1374 } 1375 1376 // JPEG_THUMBNAIL_WIDTH/HEIGHT 1377 validatedParams.jpegThumbSize[0] = 1378 newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_WIDTH); 1379 validatedParams.jpegThumbSize[1] = 1380 newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_HEIGHT); 1381 if (validatedParams.jpegThumbSize[0] != jpegThumbSize[0] || 1382 validatedParams.jpegThumbSize[1] != jpegThumbSize[1]) { 1383 camera_metadata_ro_entry_t availableJpegThumbSizes = 1384 staticInfo(ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES); 1385 for (i = 0; i < availableJpegThumbSizes.count; i+=2) { 1386 if ((availableJpegThumbSizes.data.i32[i] == 1387 validatedParams.jpegThumbSize[0]) && 1388 (availableJpegThumbSizes.data.i32[i+1] == 1389 validatedParams.jpegThumbSize[1])) break; 1390 } 1391 if (i == availableJpegThumbSizes.count) { 1392 ALOGE("%s: Requested JPEG thumbnail size %d x %d is not supported", 1393 __FUNCTION__, validatedParams.jpegThumbSize[0], 1394 validatedParams.jpegThumbSize[1]); 1395 return BAD_VALUE; 1396 } 1397 } 1398 1399 // JPEG_THUMBNAIL_QUALITY 1400 int quality = newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_QUALITY); 1401 // also makes sure quality fits in uint8_t 1402 if (quality < 0 || quality > 100) { 1403 ALOGE("%s: Requested JPEG thumbnail quality %d is not supported", 1404 __FUNCTION__, quality); 1405 return BAD_VALUE; 1406 } 1407 validatedParams.jpegThumbQuality = quality; 1408 1409 // JPEG_QUALITY 1410 quality = newParams.getInt(CameraParameters::KEY_JPEG_QUALITY); 1411 // also makes sure quality fits in uint8_t 1412 if (quality < 0 || quality > 100) { 1413 ALOGE("%s: Requested JPEG quality %d is not supported", 1414 __FUNCTION__, quality); 1415 return BAD_VALUE; 1416 } 1417 validatedParams.jpegQuality = quality; 1418 1419 // ROTATION 1420 validatedParams.jpegRotation = 1421 newParams.getInt(CameraParameters::KEY_ROTATION); 1422 if (validatedParams.jpegRotation != 0 && 1423 validatedParams.jpegRotation != 90 && 1424 validatedParams.jpegRotation != 180 && 1425 validatedParams.jpegRotation != 270) { 1426 ALOGE("%s: Requested picture rotation angle %d is not supported", 1427 __FUNCTION__, validatedParams.jpegRotation); 1428 return BAD_VALUE; 1429 } 1430 1431 // GPS 1432 1433 const char *gpsLatStr = 1434 newParams.get(CameraParameters::KEY_GPS_LATITUDE); 1435 if (gpsLatStr != NULL) { 1436 const char *gpsLongStr = 1437 newParams.get(CameraParameters::KEY_GPS_LONGITUDE); 1438 const char *gpsAltitudeStr = 1439 newParams.get(CameraParameters::KEY_GPS_ALTITUDE); 1440 const char *gpsTimeStr = 1441 newParams.get(CameraParameters::KEY_GPS_TIMESTAMP); 1442 const char *gpsProcMethodStr = 1443 newParams.get(CameraParameters::KEY_GPS_PROCESSING_METHOD); 1444 if (gpsLongStr == NULL || 1445 gpsAltitudeStr == NULL || 1446 gpsTimeStr == NULL || 1447 gpsProcMethodStr == NULL) { 1448 ALOGE("%s: Incomplete set of GPS parameters provided", 1449 __FUNCTION__); 1450 return BAD_VALUE; 1451 } 1452 char *endPtr; 1453 errno = 0; 1454 validatedParams.gpsCoordinates[0] = strtod(gpsLatStr, &endPtr); 1455 if (errno || endPtr == gpsLatStr) { 1456 ALOGE("%s: Malformed GPS latitude: %s", __FUNCTION__, gpsLatStr); 1457 return BAD_VALUE; 1458 } 1459 errno = 0; 1460 validatedParams.gpsCoordinates[1] = strtod(gpsLongStr, &endPtr); 1461 if (errno || endPtr == gpsLongStr) { 1462 ALOGE("%s: Malformed GPS longitude: %s", __FUNCTION__, gpsLongStr); 1463 return BAD_VALUE; 1464 } 1465 errno = 0; 1466 validatedParams.gpsCoordinates[2] = strtod(gpsAltitudeStr, &endPtr); 1467 if (errno || endPtr == gpsAltitudeStr) { 1468 ALOGE("%s: Malformed GPS altitude: %s", __FUNCTION__, 1469 gpsAltitudeStr); 1470 return BAD_VALUE; 1471 } 1472 errno = 0; 1473 validatedParams.gpsTimestamp = strtoll(gpsTimeStr, &endPtr, 10); 1474 if (errno || endPtr == gpsTimeStr) { 1475 ALOGE("%s: Malformed GPS timestamp: %s", __FUNCTION__, gpsTimeStr); 1476 return BAD_VALUE; 1477 } 1478 validatedParams.gpsProcessingMethod = gpsProcMethodStr; 1479 1480 validatedParams.gpsEnabled = true; 1481 } else { 1482 validatedParams.gpsEnabled = false; 1483 } 1484 1485 // EFFECT 1486 validatedParams.effectMode = effectModeStringToEnum( 1487 newParams.get(CameraParameters::KEY_EFFECT) ); 1488 if (validatedParams.effectMode != effectMode) { 1489 camera_metadata_ro_entry_t availableEffectModes = 1490 staticInfo(ANDROID_CONTROL_AVAILABLE_EFFECTS); 1491 for (i = 0; i < availableEffectModes.count; i++) { 1492 if (validatedParams.effectMode == availableEffectModes.data.u8[i]) break; 1493 } 1494 if (i == availableEffectModes.count) { 1495 ALOGE("%s: Requested effect mode \"%s\" is not supported", 1496 __FUNCTION__, 1497 newParams.get(CameraParameters::KEY_EFFECT) ); 1498 return BAD_VALUE; 1499 } 1500 } 1501 1502 // ANTIBANDING 1503 validatedParams.antibandingMode = abModeStringToEnum( 1504 newParams.get(CameraParameters::KEY_ANTIBANDING) ); 1505 if (validatedParams.antibandingMode != antibandingMode) { 1506 camera_metadata_ro_entry_t availableAbModes = 1507 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES); 1508 for (i = 0; i < availableAbModes.count; i++) { 1509 if (validatedParams.antibandingMode == availableAbModes.data.u8[i]) 1510 break; 1511 } 1512 if (i == availableAbModes.count) { 1513 ALOGE("%s: Requested antibanding mode \"%s\" is not supported", 1514 __FUNCTION__, 1515 newParams.get(CameraParameters::KEY_ANTIBANDING)); 1516 return BAD_VALUE; 1517 } 1518 } 1519 1520 // SCENE_MODE 1521 validatedParams.sceneMode = sceneModeStringToEnum( 1522 newParams.get(CameraParameters::KEY_SCENE_MODE) ); 1523 if (validatedParams.sceneMode != sceneMode && 1524 validatedParams.sceneMode != 1525 ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED) { 1526 camera_metadata_ro_entry_t availableSceneModes = 1527 staticInfo(ANDROID_CONTROL_AVAILABLE_SCENE_MODES); 1528 for (i = 0; i < availableSceneModes.count; i++) { 1529 if (validatedParams.sceneMode == availableSceneModes.data.u8[i]) 1530 break; 1531 } 1532 if (i == availableSceneModes.count) { 1533 ALOGE("%s: Requested scene mode \"%s\" is not supported", 1534 __FUNCTION__, 1535 newParams.get(CameraParameters::KEY_SCENE_MODE)); 1536 return BAD_VALUE; 1537 } 1538 } 1539 bool sceneModeSet = 1540 validatedParams.sceneMode != ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED; 1541 1542 // FLASH_MODE 1543 if (sceneModeSet) { 1544 validatedParams.flashMode = 1545 fastInfo.sceneModeOverrides. 1546 valueFor(validatedParams.sceneMode).flashMode; 1547 } else { 1548 validatedParams.flashMode = FLASH_MODE_INVALID; 1549 } 1550 if (validatedParams.flashMode == FLASH_MODE_INVALID) { 1551 validatedParams.flashMode = flashModeStringToEnum( 1552 newParams.get(CameraParameters::KEY_FLASH_MODE) ); 1553 } 1554 1555 if (validatedParams.flashMode != flashMode) { 1556 camera_metadata_ro_entry_t flashAvailable = 1557 staticInfo(ANDROID_FLASH_INFO_AVAILABLE, 1, 1); 1558 if (!flashAvailable.data.u8[0] && 1559 validatedParams.flashMode != Parameters::FLASH_MODE_OFF) { 1560 ALOGE("%s: Requested flash mode \"%s\" is not supported: " 1561 "No flash on device", __FUNCTION__, 1562 newParams.get(CameraParameters::KEY_FLASH_MODE)); 1563 return BAD_VALUE; 1564 } else if (validatedParams.flashMode == Parameters::FLASH_MODE_RED_EYE) { 1565 camera_metadata_ro_entry_t availableAeModes = 1566 staticInfo(ANDROID_CONTROL_AE_AVAILABLE_MODES); 1567 for (i = 0; i < availableAeModes.count; i++) { 1568 if (validatedParams.flashMode == availableAeModes.data.u8[i]) 1569 break; 1570 } 1571 if (i == availableAeModes.count) { 1572 ALOGE("%s: Requested flash mode \"%s\" is not supported", 1573 __FUNCTION__, 1574 newParams.get(CameraParameters::KEY_FLASH_MODE)); 1575 return BAD_VALUE; 1576 } 1577 } else if (validatedParams.flashMode == -1) { 1578 ALOGE("%s: Requested flash mode \"%s\" is unknown", 1579 __FUNCTION__, 1580 newParams.get(CameraParameters::KEY_FLASH_MODE)); 1581 return BAD_VALUE; 1582 } 1583 // Update in case of override 1584 newParams.set(CameraParameters::KEY_FLASH_MODE, 1585 flashModeEnumToString(validatedParams.flashMode)); 1586 } 1587 1588 // WHITE_BALANCE 1589 if (sceneModeSet) { 1590 validatedParams.wbMode = 1591 fastInfo.sceneModeOverrides. 1592 valueFor(validatedParams.sceneMode).wbMode; 1593 } else { 1594 validatedParams.wbMode = ANDROID_CONTROL_AWB_MODE_OFF; 1595 } 1596 if (validatedParams.wbMode == ANDROID_CONTROL_AWB_MODE_OFF) { 1597 validatedParams.wbMode = wbModeStringToEnum( 1598 newParams.get(CameraParameters::KEY_WHITE_BALANCE) ); 1599 } 1600 if (validatedParams.wbMode != wbMode) { 1601 camera_metadata_ro_entry_t availableWbModes = 1602 staticInfo(ANDROID_CONTROL_AWB_AVAILABLE_MODES, 0, 0, false); 1603 for (i = 0; i < availableWbModes.count; i++) { 1604 if (validatedParams.wbMode == availableWbModes.data.u8[i]) break; 1605 } 1606 if (i == availableWbModes.count) { 1607 ALOGE("%s: Requested white balance mode %s is not supported", 1608 __FUNCTION__, 1609 newParams.get(CameraParameters::KEY_WHITE_BALANCE)); 1610 return BAD_VALUE; 1611 } 1612 // Update in case of override 1613 newParams.set(CameraParameters::KEY_WHITE_BALANCE, 1614 wbModeEnumToString(validatedParams.wbMode)); 1615 } 1616 1617 // FOCUS_MODE 1618 if (sceneModeSet) { 1619 validatedParams.focusMode = 1620 fastInfo.sceneModeOverrides. 1621 valueFor(validatedParams.sceneMode).focusMode; 1622 } else { 1623 validatedParams.focusMode = FOCUS_MODE_INVALID; 1624 } 1625 if (validatedParams.focusMode == FOCUS_MODE_INVALID) { 1626 validatedParams.focusMode = focusModeStringToEnum( 1627 newParams.get(CameraParameters::KEY_FOCUS_MODE) ); 1628 } 1629 if (validatedParams.focusMode != focusMode) { 1630 validatedParams.currentAfTriggerId = -1; 1631 if (validatedParams.focusMode != Parameters::FOCUS_MODE_FIXED) { 1632 camera_metadata_ro_entry_t minFocusDistance = 1633 staticInfo(ANDROID_LENS_INFO_MINIMUM_FOCUS_DISTANCE, 0, 0, 1634 false); 1635 if (minFocusDistance.count && minFocusDistance.data.f[0] == 0) { 1636 ALOGE("%s: Requested focus mode \"%s\" is not available: " 1637 "fixed focus lens", 1638 __FUNCTION__, 1639 newParams.get(CameraParameters::KEY_FOCUS_MODE)); 1640 return BAD_VALUE; 1641 } else if (validatedParams.focusMode != 1642 Parameters::FOCUS_MODE_INFINITY) { 1643 camera_metadata_ro_entry_t availableFocusModes = 1644 staticInfo(ANDROID_CONTROL_AF_AVAILABLE_MODES); 1645 for (i = 0; i < availableFocusModes.count; i++) { 1646 if (validatedParams.focusMode == 1647 availableFocusModes.data.u8[i]) break; 1648 } 1649 if (i == availableFocusModes.count) { 1650 ALOGE("%s: Requested focus mode \"%s\" is not supported", 1651 __FUNCTION__, 1652 newParams.get(CameraParameters::KEY_FOCUS_MODE)); 1653 return BAD_VALUE; 1654 } 1655 } 1656 } 1657 validatedParams.focusState = ANDROID_CONTROL_AF_STATE_INACTIVE; 1658 // Always reset shadow focus mode to avoid reverting settings 1659 validatedParams.shadowFocusMode = FOCUS_MODE_INVALID; 1660 // Update in case of override 1661 newParams.set(CameraParameters::KEY_FOCUS_MODE, 1662 focusModeEnumToString(validatedParams.focusMode)); 1663 } else { 1664 validatedParams.currentAfTriggerId = currentAfTriggerId; 1665 } 1666 1667 // FOCUS_AREAS 1668 res = parseAreas(newParams.get(CameraParameters::KEY_FOCUS_AREAS), 1669 &validatedParams.focusingAreas); 1670 size_t max3aRegions = 1671 (size_t)staticInfo(ANDROID_CONTROL_MAX_REGIONS, 1, 1).data.i32[0]; 1672 if (res == OK) res = validateAreas(validatedParams.focusingAreas, 1673 max3aRegions, AREA_KIND_FOCUS); 1674 if (res != OK) { 1675 ALOGE("%s: Requested focus areas are malformed: %s", 1676 __FUNCTION__, newParams.get(CameraParameters::KEY_FOCUS_AREAS)); 1677 return BAD_VALUE; 1678 } 1679 1680 // EXPOSURE_COMPENSATION 1681 validatedParams.exposureCompensation = 1682 newParams.getInt(CameraParameters::KEY_EXPOSURE_COMPENSATION); 1683 camera_metadata_ro_entry_t exposureCompensationRange = 1684 staticInfo(ANDROID_CONTROL_AE_COMPENSATION_RANGE); 1685 if ((validatedParams.exposureCompensation < 1686 exposureCompensationRange.data.i32[0]) || 1687 (validatedParams.exposureCompensation > 1688 exposureCompensationRange.data.i32[1])) { 1689 ALOGE("%s: Requested exposure compensation index is out of bounds: %d", 1690 __FUNCTION__, validatedParams.exposureCompensation); 1691 return BAD_VALUE; 1692 } 1693 1694 // AUTO_EXPOSURE_LOCK (always supported) 1695 validatedParams.autoExposureLock = boolFromString( 1696 newParams.get(CameraParameters::KEY_AUTO_EXPOSURE_LOCK)); 1697 1698 // AUTO_WHITEBALANCE_LOCK (always supported) 1699 validatedParams.autoWhiteBalanceLock = boolFromString( 1700 newParams.get(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK)); 1701 1702 // METERING_AREAS 1703 res = parseAreas(newParams.get(CameraParameters::KEY_METERING_AREAS), 1704 &validatedParams.meteringAreas); 1705 if (res == OK) { 1706 res = validateAreas(validatedParams.meteringAreas, max3aRegions, 1707 AREA_KIND_METERING); 1708 } 1709 if (res != OK) { 1710 ALOGE("%s: Requested metering areas are malformed: %s", 1711 __FUNCTION__, 1712 newParams.get(CameraParameters::KEY_METERING_AREAS)); 1713 return BAD_VALUE; 1714 } 1715 1716 // ZOOM 1717 validatedParams.zoom = newParams.getInt(CameraParameters::KEY_ZOOM); 1718 if (validatedParams.zoom < 0 1719 || validatedParams.zoom >= (int)NUM_ZOOM_STEPS) { 1720 ALOGE("%s: Requested zoom level %d is not supported", 1721 __FUNCTION__, validatedParams.zoom); 1722 return BAD_VALUE; 1723 } 1724 1725 // VIDEO_SIZE 1726 newParams.getVideoSize(&validatedParams.videoWidth, 1727 &validatedParams.videoHeight); 1728 if (validatedParams.videoWidth != videoWidth || 1729 validatedParams.videoHeight != videoHeight) { 1730 if (state == RECORD) { 1731 ALOGE("%s: Video size cannot be updated when recording is active!", 1732 __FUNCTION__); 1733 return BAD_VALUE; 1734 } 1735 for (i = 0; i < availablePreviewSizes.size(); i++) { 1736 if ((availablePreviewSizes[i].width == 1737 validatedParams.videoWidth) && 1738 (availablePreviewSizes[i].height == 1739 validatedParams.videoHeight)) break; 1740 } 1741 if (i == availablePreviewSizes.size()) { 1742 ALOGE("%s: Requested video size %d x %d is not supported", 1743 __FUNCTION__, validatedParams.videoWidth, 1744 validatedParams.videoHeight); 1745 return BAD_VALUE; 1746 } 1747 } 1748 1749 // VIDEO_STABILIZATION 1750 validatedParams.videoStabilization = boolFromString( 1751 newParams.get(CameraParameters::KEY_VIDEO_STABILIZATION) ); 1752 camera_metadata_ro_entry_t availableVideoStabilizationModes = 1753 staticInfo(ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES, 0, 0, 1754 false); 1755 if (validatedParams.videoStabilization && 1756 availableVideoStabilizationModes.count == 1) { 1757 ALOGE("%s: Video stabilization not supported", __FUNCTION__); 1758 } 1759 1760 // LIGHTFX 1761 validatedParams.lightFx = lightFxStringToEnum( 1762 newParams.get(CameraParameters::KEY_LIGHTFX)); 1763 1764 /** Update internal parameters */ 1765 1766 *this = validatedParams; 1767 1768 /** Update external parameters calculated from the internal ones */ 1769 1770 // HORIZONTAL/VERTICAL FIELD OF VIEW 1771 float horizFov, vertFov; 1772 res = calculatePictureFovs(&horizFov, &vertFov); 1773 if (res != OK) { 1774 ALOGE("%s: Can't calculate FOVs", __FUNCTION__); 1775 // continue so parameters are at least consistent 1776 } 1777 newParams.setFloat(CameraParameters::KEY_HORIZONTAL_VIEW_ANGLE, 1778 horizFov); 1779 newParams.setFloat(CameraParameters::KEY_VERTICAL_VIEW_ANGLE, 1780 vertFov); 1781 ALOGV("Current still picture FOV: %f x %f deg", horizFov, vertFov); 1782 1783 // Need to flatten again in case of overrides 1784 paramsFlattened = newParams.flatten(); 1785 params = newParams; 1786 1787 return OK; 1788} 1789 1790status_t Parameters::updateRequest(CameraMetadata *request) const { 1791 ATRACE_CALL(); 1792 status_t res; 1793 1794 /** 1795 * Mixin default important security values 1796 * - android.led.transmit = defaulted ON 1797 */ 1798 camera_metadata_ro_entry_t entry = staticInfo(ANDROID_LED_AVAILABLE_LEDS, 1799 /*minimumCount*/0, 1800 /*maximumCount*/0, 1801 /*required*/false); 1802 for(size_t i = 0; i < entry.count; ++i) { 1803 uint8_t led = entry.data.u8[i]; 1804 1805 switch(led) { 1806 // Transmit LED is unconditionally on when using 1807 // the android.hardware.Camera API 1808 case ANDROID_LED_AVAILABLE_LEDS_TRANSMIT: { 1809 uint8_t transmitDefault = ANDROID_LED_TRANSMIT_ON; 1810 res = request->update(ANDROID_LED_TRANSMIT, 1811 &transmitDefault, 1); 1812 if (res != OK) return res; 1813 break; 1814 } 1815 } 1816 } 1817 1818 /** 1819 * Construct metadata from parameters 1820 */ 1821 1822 uint8_t metadataMode = ANDROID_REQUEST_METADATA_MODE_FULL; 1823 res = request->update(ANDROID_REQUEST_METADATA_MODE, 1824 &metadataMode, 1); 1825 if (res != OK) return res; 1826 1827 camera_metadata_entry_t intent = 1828 request->find(ANDROID_CONTROL_CAPTURE_INTENT); 1829 1830 if (intent.count == 0) return BAD_VALUE; 1831 1832 if (intent.data.u8[0] == ANDROID_CONTROL_CAPTURE_INTENT_STILL_CAPTURE) { 1833 res = request->update(ANDROID_CONTROL_AE_TARGET_FPS_RANGE, 1834 fastInfo.bestStillCaptureFpsRange, 2); 1835 } else { 1836 res = request->update(ANDROID_CONTROL_AE_TARGET_FPS_RANGE, 1837 previewFpsRange, 2); 1838 } 1839 if (res != OK) return res; 1840 1841 uint8_t reqWbLock = autoWhiteBalanceLock ? 1842 ANDROID_CONTROL_AWB_LOCK_ON : ANDROID_CONTROL_AWB_LOCK_OFF; 1843 res = request->update(ANDROID_CONTROL_AWB_LOCK, 1844 &reqWbLock, 1); 1845 1846 res = request->update(ANDROID_CONTROL_EFFECT_MODE, 1847 &effectMode, 1); 1848 if (res != OK) return res; 1849 res = request->update(ANDROID_CONTROL_AE_ANTIBANDING_MODE, 1850 &antibandingMode, 1); 1851 if (res != OK) return res; 1852 1853 // android.hardware.Camera requires that when face detect is enabled, the 1854 // camera is in a face-priority mode. HAL2 splits this into separate parts 1855 // (face detection statistics and face priority scene mode). Map from other 1856 // to the other. 1857 bool sceneModeActive = 1858 sceneMode != (uint8_t)ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED; 1859 uint8_t reqControlMode = ANDROID_CONTROL_MODE_AUTO; 1860 if (enableFaceDetect || sceneModeActive) { 1861 reqControlMode = ANDROID_CONTROL_MODE_USE_SCENE_MODE; 1862 } 1863 res = request->update(ANDROID_CONTROL_MODE, 1864 &reqControlMode, 1); 1865 if (res != OK) return res; 1866 1867 uint8_t reqSceneMode = 1868 sceneModeActive ? sceneMode : 1869 enableFaceDetect ? (uint8_t)ANDROID_CONTROL_SCENE_MODE_FACE_PRIORITY : 1870 (uint8_t)ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED; 1871 res = request->update(ANDROID_CONTROL_SCENE_MODE, 1872 &reqSceneMode, 1); 1873 if (res != OK) return res; 1874 1875 uint8_t reqFlashMode = ANDROID_FLASH_MODE_OFF; 1876 uint8_t reqAeMode = ANDROID_CONTROL_AE_MODE_OFF; 1877 switch (flashMode) { 1878 case Parameters::FLASH_MODE_OFF: 1879 reqAeMode = ANDROID_CONTROL_AE_MODE_ON; break; 1880 case Parameters::FLASH_MODE_AUTO: 1881 reqAeMode = ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH; break; 1882 case Parameters::FLASH_MODE_ON: 1883 reqAeMode = ANDROID_CONTROL_AE_MODE_ON_ALWAYS_FLASH; break; 1884 case Parameters::FLASH_MODE_TORCH: 1885 reqAeMode = ANDROID_CONTROL_AE_MODE_ON; 1886 reqFlashMode = ANDROID_FLASH_MODE_TORCH; 1887 break; 1888 case Parameters::FLASH_MODE_RED_EYE: 1889 reqAeMode = ANDROID_CONTROL_AE_MODE_ON_AUTO_FLASH_REDEYE; break; 1890 default: 1891 ALOGE("%s: Camera %d: Unknown flash mode %d", __FUNCTION__, 1892 cameraId, flashMode); 1893 return BAD_VALUE; 1894 } 1895 res = request->update(ANDROID_FLASH_MODE, 1896 &reqFlashMode, 1); 1897 if (res != OK) return res; 1898 res = request->update(ANDROID_CONTROL_AE_MODE, 1899 &reqAeMode, 1); 1900 if (res != OK) return res; 1901 1902 uint8_t reqAeLock = autoExposureLock ? 1903 ANDROID_CONTROL_AE_LOCK_ON : ANDROID_CONTROL_AE_LOCK_OFF; 1904 res = request->update(ANDROID_CONTROL_AE_LOCK, 1905 &reqAeLock, 1); 1906 if (res != OK) return res; 1907 1908 res = request->update(ANDROID_CONTROL_AWB_MODE, 1909 &wbMode, 1); 1910 if (res != OK) return res; 1911 1912 float reqFocusDistance = 0; // infinity focus in diopters 1913 uint8_t reqFocusMode = ANDROID_CONTROL_AF_MODE_OFF; 1914 switch (focusMode) { 1915 case Parameters::FOCUS_MODE_AUTO: 1916 case Parameters::FOCUS_MODE_MACRO: 1917 case Parameters::FOCUS_MODE_CONTINUOUS_VIDEO: 1918 case Parameters::FOCUS_MODE_CONTINUOUS_PICTURE: 1919 case Parameters::FOCUS_MODE_EDOF: 1920 reqFocusMode = focusMode; 1921 break; 1922 case Parameters::FOCUS_MODE_INFINITY: 1923 case Parameters::FOCUS_MODE_FIXED: 1924 reqFocusMode = ANDROID_CONTROL_AF_MODE_OFF; 1925 break; 1926 default: 1927 ALOGE("%s: Camera %d: Unknown focus mode %d", __FUNCTION__, 1928 cameraId, focusMode); 1929 return BAD_VALUE; 1930 } 1931 res = request->update(ANDROID_LENS_FOCUS_DISTANCE, 1932 &reqFocusDistance, 1); 1933 if (res != OK) return res; 1934 res = request->update(ANDROID_CONTROL_AF_MODE, 1935 &reqFocusMode, 1); 1936 if (res != OK) return res; 1937 1938 size_t reqFocusingAreasSize = focusingAreas.size() * 5; 1939 int32_t *reqFocusingAreas = new int32_t[reqFocusingAreasSize]; 1940 for (size_t i = 0, j = 0; i < reqFocusingAreasSize; i += 5, j++) { 1941 if (focusingAreas[j].weight != 0) { 1942 reqFocusingAreas[i + 0] = 1943 normalizedXToArray(focusingAreas[j].left); 1944 reqFocusingAreas[i + 1] = 1945 normalizedYToArray(focusingAreas[j].top); 1946 reqFocusingAreas[i + 2] = 1947 normalizedXToArray(focusingAreas[j].right); 1948 reqFocusingAreas[i + 3] = 1949 normalizedYToArray(focusingAreas[j].bottom); 1950 } else { 1951 reqFocusingAreas[i + 0] = 0; 1952 reqFocusingAreas[i + 1] = 0; 1953 reqFocusingAreas[i + 2] = 0; 1954 reqFocusingAreas[i + 3] = 0; 1955 } 1956 reqFocusingAreas[i + 4] = focusingAreas[j].weight; 1957 } 1958 res = request->update(ANDROID_CONTROL_AF_REGIONS, 1959 reqFocusingAreas, reqFocusingAreasSize); 1960 if (res != OK) return res; 1961 delete[] reqFocusingAreas; 1962 1963 res = request->update(ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION, 1964 &exposureCompensation, 1); 1965 if (res != OK) return res; 1966 1967 size_t reqMeteringAreasSize = meteringAreas.size() * 5; 1968 int32_t *reqMeteringAreas = new int32_t[reqMeteringAreasSize]; 1969 for (size_t i = 0, j = 0; i < reqMeteringAreasSize; i += 5, j++) { 1970 if (meteringAreas[j].weight != 0) { 1971 reqMeteringAreas[i + 0] = 1972 normalizedXToArray(meteringAreas[j].left); 1973 reqMeteringAreas[i + 1] = 1974 normalizedYToArray(meteringAreas[j].top); 1975 reqMeteringAreas[i + 2] = 1976 normalizedXToArray(meteringAreas[j].right); 1977 reqMeteringAreas[i + 3] = 1978 normalizedYToArray(meteringAreas[j].bottom); 1979 } else { 1980 reqMeteringAreas[i + 0] = 0; 1981 reqMeteringAreas[i + 1] = 0; 1982 reqMeteringAreas[i + 2] = 0; 1983 reqMeteringAreas[i + 3] = 0; 1984 } 1985 reqMeteringAreas[i + 4] = meteringAreas[j].weight; 1986 } 1987 res = request->update(ANDROID_CONTROL_AE_REGIONS, 1988 reqMeteringAreas, reqMeteringAreasSize); 1989 if (res != OK) return res; 1990 1991 delete[] reqMeteringAreas; 1992 1993 /* don't include jpeg thumbnail size - it's valid for 1994 it to be set to (0,0), meaning 'no thumbnail' */ 1995 CropRegion crop = calculateCropRegion( (CropRegion::Outputs)( 1996 CropRegion::OUTPUT_PREVIEW | 1997 CropRegion::OUTPUT_VIDEO | 1998 CropRegion::OUTPUT_PICTURE )); 1999 int32_t reqCropRegion[4] = { 2000 static_cast<int32_t>(crop.left), 2001 static_cast<int32_t>(crop.top), 2002 static_cast<int32_t>(crop.width), 2003 static_cast<int32_t>(crop.height) 2004 }; 2005 res = request->update(ANDROID_SCALER_CROP_REGION, 2006 reqCropRegion, 4); 2007 if (res != OK) return res; 2008 2009 uint8_t reqVstabMode = videoStabilization ? 2010 ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_ON : 2011 ANDROID_CONTROL_VIDEO_STABILIZATION_MODE_OFF; 2012 res = request->update(ANDROID_CONTROL_VIDEO_STABILIZATION_MODE, 2013 &reqVstabMode, 1); 2014 if (res != OK) return res; 2015 2016 uint8_t reqFaceDetectMode = enableFaceDetect ? 2017 fastInfo.bestFaceDetectMode : 2018 (uint8_t)ANDROID_STATISTICS_FACE_DETECT_MODE_OFF; 2019 res = request->update(ANDROID_STATISTICS_FACE_DETECT_MODE, 2020 &reqFaceDetectMode, 1); 2021 if (res != OK) return res; 2022 2023 return OK; 2024} 2025 2026status_t Parameters::updateRequestJpeg(CameraMetadata *request) const { 2027 status_t res; 2028 2029 res = request->update(ANDROID_JPEG_THUMBNAIL_SIZE, 2030 jpegThumbSize, 2); 2031 if (res != OK) return res; 2032 res = request->update(ANDROID_JPEG_THUMBNAIL_QUALITY, 2033 &jpegThumbQuality, 1); 2034 if (res != OK) return res; 2035 res = request->update(ANDROID_JPEG_QUALITY, 2036 &jpegQuality, 1); 2037 if (res != OK) return res; 2038 res = request->update( 2039 ANDROID_JPEG_ORIENTATION, 2040 &jpegRotation, 1); 2041 if (res != OK) return res; 2042 2043 if (gpsEnabled) { 2044 res = request->update( 2045 ANDROID_JPEG_GPS_COORDINATES, 2046 gpsCoordinates, 3); 2047 if (res != OK) return res; 2048 res = request->update( 2049 ANDROID_JPEG_GPS_TIMESTAMP, 2050 &gpsTimestamp, 1); 2051 if (res != OK) return res; 2052 res = request->update( 2053 ANDROID_JPEG_GPS_PROCESSING_METHOD, 2054 gpsProcessingMethod); 2055 if (res != OK) return res; 2056 } else { 2057 res = request->erase(ANDROID_JPEG_GPS_COORDINATES); 2058 if (res != OK) return res; 2059 res = request->erase(ANDROID_JPEG_GPS_TIMESTAMP); 2060 if (res != OK) return res; 2061 res = request->erase(ANDROID_JPEG_GPS_PROCESSING_METHOD); 2062 if (res != OK) return res; 2063 } 2064 return OK; 2065} 2066 2067 2068const char* Parameters::getStateName(State state) { 2069#define CASE_ENUM_TO_CHAR(x) case x: return(#x); break; 2070 switch(state) { 2071 CASE_ENUM_TO_CHAR(DISCONNECTED) 2072 CASE_ENUM_TO_CHAR(STOPPED) 2073 CASE_ENUM_TO_CHAR(WAITING_FOR_PREVIEW_WINDOW) 2074 CASE_ENUM_TO_CHAR(PREVIEW) 2075 CASE_ENUM_TO_CHAR(RECORD) 2076 CASE_ENUM_TO_CHAR(STILL_CAPTURE) 2077 CASE_ENUM_TO_CHAR(VIDEO_SNAPSHOT) 2078 default: 2079 return "Unknown state!"; 2080 break; 2081 } 2082#undef CASE_ENUM_TO_CHAR 2083} 2084 2085int Parameters::formatStringToEnum(const char *format) { 2086 return 2087 !format ? 2088 HAL_PIXEL_FORMAT_YCrCb_420_SP : 2089 !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV422SP) ? 2090 HAL_PIXEL_FORMAT_YCbCr_422_SP : // NV16 2091 !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV420SP) ? 2092 HAL_PIXEL_FORMAT_YCrCb_420_SP : // NV21 2093 !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV422I) ? 2094 HAL_PIXEL_FORMAT_YCbCr_422_I : // YUY2 2095 !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV420P) ? 2096 HAL_PIXEL_FORMAT_YV12 : // YV12 2097 !strcmp(format, CameraParameters::PIXEL_FORMAT_RGB565) ? 2098 HAL_PIXEL_FORMAT_RGB_565 : // RGB565 2099 !strcmp(format, CameraParameters::PIXEL_FORMAT_RGBA8888) ? 2100 HAL_PIXEL_FORMAT_RGBA_8888 : // RGB8888 2101 !strcmp(format, CameraParameters::PIXEL_FORMAT_BAYER_RGGB) ? 2102 HAL_PIXEL_FORMAT_RAW_SENSOR : // Raw sensor data 2103 -1; 2104} 2105 2106const char* Parameters::formatEnumToString(int format) { 2107 const char *fmt; 2108 switch(format) { 2109 case HAL_PIXEL_FORMAT_YCbCr_422_SP: // NV16 2110 fmt = CameraParameters::PIXEL_FORMAT_YUV422SP; 2111 break; 2112 case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21 2113 fmt = CameraParameters::PIXEL_FORMAT_YUV420SP; 2114 break; 2115 case HAL_PIXEL_FORMAT_YCbCr_422_I: // YUY2 2116 fmt = CameraParameters::PIXEL_FORMAT_YUV422I; 2117 break; 2118 case HAL_PIXEL_FORMAT_YV12: // YV12 2119 fmt = CameraParameters::PIXEL_FORMAT_YUV420P; 2120 break; 2121 case HAL_PIXEL_FORMAT_RGB_565: // RGB565 2122 fmt = CameraParameters::PIXEL_FORMAT_RGB565; 2123 break; 2124 case HAL_PIXEL_FORMAT_RGBA_8888: // RGBA8888 2125 fmt = CameraParameters::PIXEL_FORMAT_RGBA8888; 2126 break; 2127 case HAL_PIXEL_FORMAT_RAW_SENSOR: 2128 ALOGW("Raw sensor preview format requested."); 2129 fmt = CameraParameters::PIXEL_FORMAT_BAYER_RGGB; 2130 break; 2131 default: 2132 ALOGE("%s: Unknown preview format: %x", 2133 __FUNCTION__, format); 2134 fmt = NULL; 2135 break; 2136 } 2137 return fmt; 2138} 2139 2140int Parameters::wbModeStringToEnum(const char *wbMode) { 2141 return 2142 !wbMode ? 2143 ANDROID_CONTROL_AWB_MODE_AUTO : 2144 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_AUTO) ? 2145 ANDROID_CONTROL_AWB_MODE_AUTO : 2146 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_INCANDESCENT) ? 2147 ANDROID_CONTROL_AWB_MODE_INCANDESCENT : 2148 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_FLUORESCENT) ? 2149 ANDROID_CONTROL_AWB_MODE_FLUORESCENT : 2150 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_WARM_FLUORESCENT) ? 2151 ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT : 2152 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_DAYLIGHT) ? 2153 ANDROID_CONTROL_AWB_MODE_DAYLIGHT : 2154 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_CLOUDY_DAYLIGHT) ? 2155 ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT : 2156 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_TWILIGHT) ? 2157 ANDROID_CONTROL_AWB_MODE_TWILIGHT : 2158 !strcmp(wbMode, CameraParameters::WHITE_BALANCE_SHADE) ? 2159 ANDROID_CONTROL_AWB_MODE_SHADE : 2160 -1; 2161} 2162 2163const char* Parameters::wbModeEnumToString(uint8_t wbMode) { 2164 switch (wbMode) { 2165 case ANDROID_CONTROL_AWB_MODE_AUTO: 2166 return CameraParameters::WHITE_BALANCE_AUTO; 2167 case ANDROID_CONTROL_AWB_MODE_INCANDESCENT: 2168 return CameraParameters::WHITE_BALANCE_INCANDESCENT; 2169 case ANDROID_CONTROL_AWB_MODE_FLUORESCENT: 2170 return CameraParameters::WHITE_BALANCE_FLUORESCENT; 2171 case ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT: 2172 return CameraParameters::WHITE_BALANCE_WARM_FLUORESCENT; 2173 case ANDROID_CONTROL_AWB_MODE_DAYLIGHT: 2174 return CameraParameters::WHITE_BALANCE_DAYLIGHT; 2175 case ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT: 2176 return CameraParameters::WHITE_BALANCE_CLOUDY_DAYLIGHT; 2177 case ANDROID_CONTROL_AWB_MODE_TWILIGHT: 2178 return CameraParameters::WHITE_BALANCE_TWILIGHT; 2179 case ANDROID_CONTROL_AWB_MODE_SHADE: 2180 return CameraParameters::WHITE_BALANCE_SHADE; 2181 default: 2182 ALOGE("%s: Unknown AWB mode enum: %d", 2183 __FUNCTION__, wbMode); 2184 return "unknown"; 2185 } 2186} 2187 2188int Parameters::effectModeStringToEnum(const char *effectMode) { 2189 return 2190 !effectMode ? 2191 ANDROID_CONTROL_EFFECT_MODE_OFF : 2192 !strcmp(effectMode, CameraParameters::EFFECT_NONE) ? 2193 ANDROID_CONTROL_EFFECT_MODE_OFF : 2194 !strcmp(effectMode, CameraParameters::EFFECT_MONO) ? 2195 ANDROID_CONTROL_EFFECT_MODE_MONO : 2196 !strcmp(effectMode, CameraParameters::EFFECT_NEGATIVE) ? 2197 ANDROID_CONTROL_EFFECT_MODE_NEGATIVE : 2198 !strcmp(effectMode, CameraParameters::EFFECT_SOLARIZE) ? 2199 ANDROID_CONTROL_EFFECT_MODE_SOLARIZE : 2200 !strcmp(effectMode, CameraParameters::EFFECT_SEPIA) ? 2201 ANDROID_CONTROL_EFFECT_MODE_SEPIA : 2202 !strcmp(effectMode, CameraParameters::EFFECT_POSTERIZE) ? 2203 ANDROID_CONTROL_EFFECT_MODE_POSTERIZE : 2204 !strcmp(effectMode, CameraParameters::EFFECT_WHITEBOARD) ? 2205 ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD : 2206 !strcmp(effectMode, CameraParameters::EFFECT_BLACKBOARD) ? 2207 ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD : 2208 !strcmp(effectMode, CameraParameters::EFFECT_AQUA) ? 2209 ANDROID_CONTROL_EFFECT_MODE_AQUA : 2210 -1; 2211} 2212 2213int Parameters::abModeStringToEnum(const char *abMode) { 2214 return 2215 !abMode ? 2216 ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO : 2217 !strcmp(abMode, CameraParameters::ANTIBANDING_AUTO) ? 2218 ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO : 2219 !strcmp(abMode, CameraParameters::ANTIBANDING_OFF) ? 2220 ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF : 2221 !strcmp(abMode, CameraParameters::ANTIBANDING_50HZ) ? 2222 ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ : 2223 !strcmp(abMode, CameraParameters::ANTIBANDING_60HZ) ? 2224 ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ : 2225 -1; 2226} 2227 2228int Parameters::sceneModeStringToEnum(const char *sceneMode) { 2229 return 2230 !sceneMode ? 2231 ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED : 2232 !strcmp(sceneMode, CameraParameters::SCENE_MODE_AUTO) ? 2233 ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED : 2234 !strcmp(sceneMode, CameraParameters::SCENE_MODE_ACTION) ? 2235 ANDROID_CONTROL_SCENE_MODE_ACTION : 2236 !strcmp(sceneMode, CameraParameters::SCENE_MODE_PORTRAIT) ? 2237 ANDROID_CONTROL_SCENE_MODE_PORTRAIT : 2238 !strcmp(sceneMode, CameraParameters::SCENE_MODE_LANDSCAPE) ? 2239 ANDROID_CONTROL_SCENE_MODE_LANDSCAPE : 2240 !strcmp(sceneMode, CameraParameters::SCENE_MODE_NIGHT) ? 2241 ANDROID_CONTROL_SCENE_MODE_NIGHT : 2242 !strcmp(sceneMode, CameraParameters::SCENE_MODE_NIGHT_PORTRAIT) ? 2243 ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT : 2244 !strcmp(sceneMode, CameraParameters::SCENE_MODE_THEATRE) ? 2245 ANDROID_CONTROL_SCENE_MODE_THEATRE : 2246 !strcmp(sceneMode, CameraParameters::SCENE_MODE_BEACH) ? 2247 ANDROID_CONTROL_SCENE_MODE_BEACH : 2248 !strcmp(sceneMode, CameraParameters::SCENE_MODE_SNOW) ? 2249 ANDROID_CONTROL_SCENE_MODE_SNOW : 2250 !strcmp(sceneMode, CameraParameters::SCENE_MODE_SUNSET) ? 2251 ANDROID_CONTROL_SCENE_MODE_SUNSET : 2252 !strcmp(sceneMode, CameraParameters::SCENE_MODE_STEADYPHOTO) ? 2253 ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO : 2254 !strcmp(sceneMode, CameraParameters::SCENE_MODE_FIREWORKS) ? 2255 ANDROID_CONTROL_SCENE_MODE_FIREWORKS : 2256 !strcmp(sceneMode, CameraParameters::SCENE_MODE_SPORTS) ? 2257 ANDROID_CONTROL_SCENE_MODE_SPORTS : 2258 !strcmp(sceneMode, CameraParameters::SCENE_MODE_PARTY) ? 2259 ANDROID_CONTROL_SCENE_MODE_PARTY : 2260 !strcmp(sceneMode, CameraParameters::SCENE_MODE_CANDLELIGHT) ? 2261 ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT : 2262 !strcmp(sceneMode, CameraParameters::SCENE_MODE_BARCODE) ? 2263 ANDROID_CONTROL_SCENE_MODE_BARCODE: 2264 -1; 2265} 2266 2267Parameters::Parameters::flashMode_t Parameters::flashModeStringToEnum( 2268 const char *flashMode) { 2269 return 2270 !flashMode ? 2271 Parameters::FLASH_MODE_INVALID : 2272 !strcmp(flashMode, CameraParameters::FLASH_MODE_OFF) ? 2273 Parameters::FLASH_MODE_OFF : 2274 !strcmp(flashMode, CameraParameters::FLASH_MODE_AUTO) ? 2275 Parameters::FLASH_MODE_AUTO : 2276 !strcmp(flashMode, CameraParameters::FLASH_MODE_ON) ? 2277 Parameters::FLASH_MODE_ON : 2278 !strcmp(flashMode, CameraParameters::FLASH_MODE_RED_EYE) ? 2279 Parameters::FLASH_MODE_RED_EYE : 2280 !strcmp(flashMode, CameraParameters::FLASH_MODE_TORCH) ? 2281 Parameters::FLASH_MODE_TORCH : 2282 Parameters::FLASH_MODE_INVALID; 2283} 2284 2285const char *Parameters::flashModeEnumToString(flashMode_t flashMode) { 2286 switch (flashMode) { 2287 case FLASH_MODE_OFF: 2288 return CameraParameters::FLASH_MODE_OFF; 2289 case FLASH_MODE_AUTO: 2290 return CameraParameters::FLASH_MODE_AUTO; 2291 case FLASH_MODE_ON: 2292 return CameraParameters::FLASH_MODE_ON; 2293 case FLASH_MODE_RED_EYE: 2294 return CameraParameters::FLASH_MODE_RED_EYE; 2295 case FLASH_MODE_TORCH: 2296 return CameraParameters::FLASH_MODE_TORCH; 2297 default: 2298 ALOGE("%s: Unknown flash mode enum %d", 2299 __FUNCTION__, flashMode); 2300 return "unknown"; 2301 } 2302} 2303 2304Parameters::Parameters::focusMode_t Parameters::focusModeStringToEnum( 2305 const char *focusMode) { 2306 return 2307 !focusMode ? 2308 Parameters::FOCUS_MODE_INVALID : 2309 !strcmp(focusMode, CameraParameters::FOCUS_MODE_AUTO) ? 2310 Parameters::FOCUS_MODE_AUTO : 2311 !strcmp(focusMode, CameraParameters::FOCUS_MODE_INFINITY) ? 2312 Parameters::FOCUS_MODE_INFINITY : 2313 !strcmp(focusMode, CameraParameters::FOCUS_MODE_MACRO) ? 2314 Parameters::FOCUS_MODE_MACRO : 2315 !strcmp(focusMode, CameraParameters::FOCUS_MODE_FIXED) ? 2316 Parameters::FOCUS_MODE_FIXED : 2317 !strcmp(focusMode, CameraParameters::FOCUS_MODE_EDOF) ? 2318 Parameters::FOCUS_MODE_EDOF : 2319 !strcmp(focusMode, CameraParameters::FOCUS_MODE_CONTINUOUS_VIDEO) ? 2320 Parameters::FOCUS_MODE_CONTINUOUS_VIDEO : 2321 !strcmp(focusMode, CameraParameters::FOCUS_MODE_CONTINUOUS_PICTURE) ? 2322 Parameters::FOCUS_MODE_CONTINUOUS_PICTURE : 2323 Parameters::FOCUS_MODE_INVALID; 2324} 2325 2326const char *Parameters::focusModeEnumToString(focusMode_t focusMode) { 2327 switch (focusMode) { 2328 case FOCUS_MODE_AUTO: 2329 return CameraParameters::FOCUS_MODE_AUTO; 2330 case FOCUS_MODE_MACRO: 2331 return CameraParameters::FOCUS_MODE_MACRO; 2332 case FOCUS_MODE_CONTINUOUS_VIDEO: 2333 return CameraParameters::FOCUS_MODE_CONTINUOUS_VIDEO; 2334 case FOCUS_MODE_CONTINUOUS_PICTURE: 2335 return CameraParameters::FOCUS_MODE_CONTINUOUS_PICTURE; 2336 case FOCUS_MODE_EDOF: 2337 return CameraParameters::FOCUS_MODE_EDOF; 2338 case FOCUS_MODE_INFINITY: 2339 return CameraParameters::FOCUS_MODE_INFINITY; 2340 case FOCUS_MODE_FIXED: 2341 return CameraParameters::FOCUS_MODE_FIXED; 2342 default: 2343 ALOGE("%s: Unknown focus mode enum: %d", 2344 __FUNCTION__, focusMode); 2345 return "unknown"; 2346 } 2347} 2348 2349Parameters::Parameters::lightFxMode_t Parameters::lightFxStringToEnum( 2350 const char *lightFxMode) { 2351 return 2352 !lightFxMode ? 2353 Parameters::LIGHTFX_NONE : 2354 !strcmp(lightFxMode, CameraParameters::LIGHTFX_LOWLIGHT) ? 2355 Parameters::LIGHTFX_LOWLIGHT : 2356 !strcmp(lightFxMode, CameraParameters::LIGHTFX_HDR) ? 2357 Parameters::LIGHTFX_HDR : 2358 Parameters::LIGHTFX_NONE; 2359} 2360 2361status_t Parameters::parseAreas(const char *areasCStr, 2362 Vector<Parameters::Area> *areas) { 2363 static const size_t NUM_FIELDS = 5; 2364 areas->clear(); 2365 if (areasCStr == NULL) { 2366 // If no key exists, use default (0,0,0,0,0) 2367 areas->push(); 2368 return OK; 2369 } 2370 String8 areasStr(areasCStr); 2371 ssize_t areaStart = areasStr.find("(", 0) + 1; 2372 while (areaStart != 0) { 2373 const char* area = areasStr.string() + areaStart; 2374 char *numEnd; 2375 int vals[NUM_FIELDS]; 2376 for (size_t i = 0; i < NUM_FIELDS; i++) { 2377 errno = 0; 2378 vals[i] = strtol(area, &numEnd, 10); 2379 if (errno || numEnd == area) return BAD_VALUE; 2380 area = numEnd + 1; 2381 } 2382 areas->push(Parameters::Area( 2383 vals[0], vals[1], vals[2], vals[3], vals[4]) ); 2384 areaStart = areasStr.find("(", areaStart) + 1; 2385 } 2386 return OK; 2387} 2388 2389status_t Parameters::validateAreas(const Vector<Parameters::Area> &areas, 2390 size_t maxRegions, 2391 AreaKind areaKind) const { 2392 // Definition of valid area can be found in 2393 // include/camera/CameraParameters.h 2394 if (areas.size() == 0) return BAD_VALUE; 2395 if (areas.size() == 1) { 2396 if (areas[0].left == 0 && 2397 areas[0].top == 0 && 2398 areas[0].right == 0 && 2399 areas[0].bottom == 0 && 2400 areas[0].weight == 0) { 2401 // Single (0,0,0,0,0) entry is always valid (== driver decides) 2402 return OK; 2403 } 2404 } 2405 2406 // fixed focus can only set (0,0,0,0,0) focus area 2407 if (areaKind == AREA_KIND_FOCUS && focusMode == FOCUS_MODE_FIXED) { 2408 return BAD_VALUE; 2409 } 2410 2411 if (areas.size() > maxRegions) { 2412 ALOGE("%s: Too many areas requested: %zu", 2413 __FUNCTION__, areas.size()); 2414 return BAD_VALUE; 2415 } 2416 2417 for (Vector<Parameters::Area>::const_iterator a = areas.begin(); 2418 a != areas.end(); a++) { 2419 if (a->weight < 1 || a->weight > 1000) return BAD_VALUE; 2420 if (a->left < -1000 || a->left > 1000) return BAD_VALUE; 2421 if (a->top < -1000 || a->top > 1000) return BAD_VALUE; 2422 if (a->right < -1000 || a->right > 1000) return BAD_VALUE; 2423 if (a->bottom < -1000 || a->bottom > 1000) return BAD_VALUE; 2424 if (a->left >= a->right) return BAD_VALUE; 2425 if (a->top >= a->bottom) return BAD_VALUE; 2426 } 2427 return OK; 2428} 2429 2430bool Parameters::boolFromString(const char *boolStr) { 2431 return !boolStr ? false : 2432 !strcmp(boolStr, CameraParameters::TRUE) ? true : 2433 false; 2434} 2435 2436int Parameters::degToTransform(int degrees, bool mirror) { 2437 if (!mirror) { 2438 if (degrees == 0) return 0; 2439 else if (degrees == 90) return HAL_TRANSFORM_ROT_90; 2440 else if (degrees == 180) return HAL_TRANSFORM_ROT_180; 2441 else if (degrees == 270) return HAL_TRANSFORM_ROT_270; 2442 } else { // Do mirror (horizontal flip) 2443 if (degrees == 0) { // FLIP_H and ROT_0 2444 return HAL_TRANSFORM_FLIP_H; 2445 } else if (degrees == 90) { // FLIP_H and ROT_90 2446 return HAL_TRANSFORM_FLIP_H | HAL_TRANSFORM_ROT_90; 2447 } else if (degrees == 180) { // FLIP_H and ROT_180 2448 return HAL_TRANSFORM_FLIP_V; 2449 } else if (degrees == 270) { // FLIP_H and ROT_270 2450 return HAL_TRANSFORM_FLIP_V | HAL_TRANSFORM_ROT_90; 2451 } 2452 } 2453 ALOGE("%s: Bad input: %d", __FUNCTION__, degrees); 2454 return -1; 2455} 2456 2457int Parameters::cropXToArray(int x) const { 2458 ALOG_ASSERT(x >= 0, "Crop-relative X coordinate = '%d' is out of bounds" 2459 "(lower = 0)", x); 2460 2461 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2462 ALOG_ASSERT(x < previewCrop.width, "Crop-relative X coordinate = '%d' " 2463 "is out of bounds (upper = %f)", x, previewCrop.width); 2464 2465 int ret = x + previewCrop.left; 2466 2467 ALOG_ASSERT( (ret >= 0 && ret < fastInfo.arrayWidth), 2468 "Calculated pixel array value X = '%d' is out of bounds (upper = %d)", 2469 ret, fastInfo.arrayWidth); 2470 return ret; 2471} 2472 2473int Parameters::cropYToArray(int y) const { 2474 ALOG_ASSERT(y >= 0, "Crop-relative Y coordinate = '%d' is out of bounds " 2475 "(lower = 0)", y); 2476 2477 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2478 ALOG_ASSERT(y < previewCrop.height, "Crop-relative Y coordinate = '%d' is " 2479 "out of bounds (upper = %f)", y, previewCrop.height); 2480 2481 int ret = y + previewCrop.top; 2482 2483 ALOG_ASSERT( (ret >= 0 && ret < fastInfo.arrayHeight), 2484 "Calculated pixel array value Y = '%d' is out of bounds (upper = %d)", 2485 ret, fastInfo.arrayHeight); 2486 2487 return ret; 2488 2489} 2490 2491int Parameters::normalizedXToCrop(int x) const { 2492 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2493 return (x + 1000) * (previewCrop.width - 1) / 2000; 2494} 2495 2496int Parameters::normalizedYToCrop(int y) const { 2497 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2498 return (y + 1000) * (previewCrop.height - 1) / 2000; 2499} 2500 2501int Parameters::arrayXToCrop(int x) const { 2502 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2503 return x - previewCrop.left; 2504} 2505 2506int Parameters::arrayYToCrop(int y) const { 2507 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2508 return y - previewCrop.top; 2509} 2510 2511int Parameters::cropXToNormalized(int x) const { 2512 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2513 return x * 2000 / (previewCrop.width - 1) - 1000; 2514} 2515 2516int Parameters::cropYToNormalized(int y) const { 2517 CropRegion previewCrop = calculateCropRegion(CropRegion::OUTPUT_PREVIEW); 2518 return y * 2000 / (previewCrop.height - 1) - 1000; 2519} 2520 2521int Parameters::arrayXToNormalized(int width) const { 2522 int ret = cropXToNormalized(arrayXToCrop(width)); 2523 2524 ALOG_ASSERT(ret >= -1000, "Calculated normalized value out of " 2525 "lower bounds %d", ret); 2526 ALOG_ASSERT(ret <= 1000, "Calculated normalized value out of " 2527 "upper bounds %d", ret); 2528 2529 // Work-around for HAL pre-scaling the coordinates themselves 2530 if (quirks.meteringCropRegion) { 2531 return width * 2000 / (fastInfo.arrayWidth - 1) - 1000; 2532 } 2533 2534 return ret; 2535} 2536 2537int Parameters::arrayYToNormalized(int height) const { 2538 int ret = cropYToNormalized(arrayYToCrop(height)); 2539 2540 ALOG_ASSERT(ret >= -1000, "Calculated normalized value out of lower bounds" 2541 " %d", ret); 2542 ALOG_ASSERT(ret <= 1000, "Calculated normalized value out of upper bounds" 2543 " %d", ret); 2544 2545 // Work-around for HAL pre-scaling the coordinates themselves 2546 if (quirks.meteringCropRegion) { 2547 return height * 2000 / (fastInfo.arrayHeight - 1) - 1000; 2548 } 2549 2550 return ret; 2551} 2552 2553int Parameters::normalizedXToArray(int x) const { 2554 2555 // Work-around for HAL pre-scaling the coordinates themselves 2556 if (quirks.meteringCropRegion) { 2557 return (x + 1000) * (fastInfo.arrayWidth - 1) / 2000; 2558 } 2559 2560 return cropXToArray(normalizedXToCrop(x)); 2561} 2562 2563int Parameters::normalizedYToArray(int y) const { 2564 // Work-around for HAL pre-scaling the coordinates themselves 2565 if (quirks.meteringCropRegion) { 2566 return (y + 1000) * (fastInfo.arrayHeight - 1) / 2000; 2567 } 2568 2569 return cropYToArray(normalizedYToCrop(y)); 2570} 2571 2572status_t Parameters::getFilteredPreviewSizes(Size limit, Vector<Size> *sizes) { 2573 if (info == NULL) { 2574 ALOGE("%s: Static metadata is not initialized", __FUNCTION__); 2575 return NO_INIT; 2576 } 2577 if (sizes == NULL) { 2578 ALOGE("%s: Input size is null", __FUNCTION__); 2579 return BAD_VALUE; 2580 } 2581 2582 const size_t SIZE_COUNT = sizeof(Size) / sizeof(int); 2583 camera_metadata_ro_entry_t availableProcessedSizes = 2584 staticInfo(ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES, SIZE_COUNT); 2585 if (availableProcessedSizes.count < SIZE_COUNT) return BAD_VALUE; 2586 2587 Size previewSize; 2588 for (size_t i = 0; i < availableProcessedSizes.count; i += SIZE_COUNT) { 2589 previewSize.width = availableProcessedSizes.data.i32[i]; 2590 previewSize.height = availableProcessedSizes.data.i32[i+1]; 2591 // Need skip the preview sizes that are too large. 2592 if (previewSize.width <= limit.width && 2593 previewSize.height <= limit.height) { 2594 sizes->push(previewSize); 2595 } 2596 } 2597 if (sizes->isEmpty()) { 2598 ALOGE("generated preview size list is empty!!"); 2599 return BAD_VALUE; 2600 } 2601 return OK; 2602} 2603 2604Parameters::Size Parameters::getMaxSizeForRatio( 2605 float ratio, const int32_t* sizeArray, size_t count) { 2606 ALOG_ASSERT(sizeArray != NULL, "size array shouldn't be NULL"); 2607 ALOG_ASSERT(count >= 2 && count % 2 == 0, "count must be a positive even number"); 2608 2609 Size maxSize = {0, 0}; 2610 for (size_t i = 0; i < count; i += 2) { 2611 if (sizeArray[i] > 0 && sizeArray[i+1] > 0) { 2612 float curRatio = static_cast<float>(sizeArray[i]) / sizeArray[i+1]; 2613 if (fabs(curRatio - ratio) < ASPECT_RATIO_TOLERANCE && maxSize.width < sizeArray[i]) { 2614 maxSize.width = sizeArray[i]; 2615 maxSize.height = sizeArray[i+1]; 2616 } 2617 } 2618 } 2619 2620 if (maxSize.width == 0 || maxSize.height == 0) { 2621 maxSize.width = sizeArray[0]; 2622 maxSize.height = sizeArray[1]; 2623 ALOGW("Unable to find the size to match the given aspect ratio %f." 2624 "Fall back to %d x %d", ratio, maxSize.width, maxSize.height); 2625 } 2626 2627 return maxSize; 2628} 2629 2630Parameters::CropRegion Parameters::calculateCropRegion( 2631 Parameters::CropRegion::Outputs outputs) const { 2632 2633 float zoomLeft, zoomTop, zoomWidth, zoomHeight; 2634 2635 // Need to convert zoom index into a crop rectangle. The rectangle is 2636 // chosen to maximize its area on the sensor 2637 2638 camera_metadata_ro_entry_t maxDigitalZoom = 2639 staticInfo(ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM); 2640 // For each zoom step by how many pixels more do we change the zoom 2641 float zoomIncrement = (maxDigitalZoom.data.f[0] - 1) / 2642 (NUM_ZOOM_STEPS-1); 2643 // The desired activeAreaWidth/cropAreaWidth ratio (or height if h>w) 2644 // via interpolating zoom step into a zoom ratio 2645 float zoomRatio = 1 + zoomIncrement * zoom; 2646 ALOG_ASSERT( (zoomRatio >= 1.f && zoomRatio <= maxDigitalZoom.data.f[0]), 2647 "Zoom ratio calculated out of bounds. Expected 1 - %f, actual: %f", 2648 maxDigitalZoom.data.f[0], zoomRatio); 2649 2650 ALOGV("Zoom maxDigital=%f, increment=%f, ratio=%f, previewWidth=%d, " 2651 "previewHeight=%d, activeWidth=%d, activeHeight=%d", 2652 maxDigitalZoom.data.f[0], zoomIncrement, zoomRatio, previewWidth, 2653 previewHeight, fastInfo.arrayWidth, fastInfo.arrayHeight); 2654 2655 /* 2656 * Assumption: On the HAL side each stream buffer calculates its crop 2657 * rectangle as follows: 2658 * cropRect = (zoomLeft, zoomRight, 2659 * zoomWidth, zoomHeight * zoomWidth / outputWidth); 2660 * 2661 * Note that if zoomWidth > bufferWidth, the new cropHeight > zoomHeight 2662 * (we can then get into trouble if the cropHeight > arrayHeight). 2663 * By selecting the zoomRatio based on the smallest outputRatio, we 2664 * guarantee this will never happen. 2665 */ 2666 2667 // Enumerate all possible output sizes, select the one with the smallest 2668 // aspect ratio 2669 float minOutputWidth, minOutputHeight, minOutputRatio; 2670 { 2671 float outputSizes[][2] = { 2672 { static_cast<float>(previewWidth), 2673 static_cast<float>(previewHeight) }, 2674 { static_cast<float>(videoWidth), 2675 static_cast<float>(videoHeight) }, 2676 { static_cast<float>(jpegThumbSize[0]), 2677 static_cast<float>(jpegThumbSize[1]) }, 2678 { static_cast<float>(pictureWidth), 2679 static_cast<float>(pictureHeight) }, 2680 }; 2681 2682 minOutputWidth = outputSizes[0][0]; 2683 minOutputHeight = outputSizes[0][1]; 2684 minOutputRatio = minOutputWidth / minOutputHeight; 2685 for (unsigned int i = 0; 2686 i < sizeof(outputSizes) / sizeof(outputSizes[0]); 2687 ++i) { 2688 2689 // skip over outputs we don't want to consider for the crop region 2690 if ( !((1 << i) & outputs) ) { 2691 continue; 2692 } 2693 2694 float outputWidth = outputSizes[i][0]; 2695 float outputHeight = outputSizes[i][1]; 2696 float outputRatio = outputWidth / outputHeight; 2697 2698 if (minOutputRatio > outputRatio) { 2699 minOutputRatio = outputRatio; 2700 minOutputWidth = outputWidth; 2701 minOutputHeight = outputHeight; 2702 } 2703 2704 // and then use this output ratio instead of preview output ratio 2705 ALOGV("Enumerating output ratio %f = %f / %f, min is %f", 2706 outputRatio, outputWidth, outputHeight, minOutputRatio); 2707 } 2708 } 2709 2710 /* Ensure that the width/height never go out of bounds 2711 * by scaling across a diffent dimension if an out-of-bounds 2712 * possibility exists. 2713 * 2714 * e.g. if the previewratio < arrayratio and e.g. zoomratio = 1.0, then by 2715 * calculating the zoomWidth from zoomHeight we'll actually get a 2716 * zoomheight > arrayheight 2717 */ 2718 float arrayRatio = 1.f * fastInfo.arrayWidth / fastInfo.arrayHeight; 2719 if (minOutputRatio >= arrayRatio) { 2720 // Adjust the height based on the width 2721 zoomWidth = fastInfo.arrayWidth / zoomRatio; 2722 zoomHeight = zoomWidth * 2723 minOutputHeight / minOutputWidth; 2724 2725 } else { 2726 // Adjust the width based on the height 2727 zoomHeight = fastInfo.arrayHeight / zoomRatio; 2728 zoomWidth = zoomHeight * 2729 minOutputWidth / minOutputHeight; 2730 } 2731 // centering the zoom area within the active area 2732 zoomLeft = (fastInfo.arrayWidth - zoomWidth) / 2; 2733 zoomTop = (fastInfo.arrayHeight - zoomHeight) / 2; 2734 2735 ALOGV("Crop region calculated (x=%d,y=%d,w=%f,h=%f) for zoom=%d", 2736 (int32_t)zoomLeft, (int32_t)zoomTop, zoomWidth, zoomHeight, this->zoom); 2737 2738 2739 CropRegion crop = { zoomLeft, zoomTop, zoomWidth, zoomHeight }; 2740 return crop; 2741} 2742 2743status_t Parameters::calculatePictureFovs(float *horizFov, float *vertFov) 2744 const { 2745 camera_metadata_ro_entry_t sensorSize = 2746 staticInfo(ANDROID_SENSOR_INFO_PHYSICAL_SIZE, 2, 2); 2747 if (!sensorSize.count) return NO_INIT; 2748 2749 float arrayAspect = static_cast<float>(fastInfo.arrayWidth) / 2750 fastInfo.arrayHeight; 2751 float stillAspect = static_cast<float>(pictureWidth) / pictureHeight; 2752 ALOGV("Array aspect: %f, still aspect: %f", arrayAspect, stillAspect); 2753 2754 // The crop factors from the full sensor array to the still picture crop 2755 // region 2756 float horizCropFactor = 1.f; 2757 float vertCropFactor = 1.f; 2758 2759 /** 2760 * Need to calculate the still image field of view based on the total pixel 2761 * array field of view, and the relative aspect ratios of the pixel array 2762 * and output streams. 2763 * 2764 * Special treatment for quirky definition of crop region and relative 2765 * stream cropping. 2766 */ 2767 if (quirks.meteringCropRegion) { 2768 // Use max of preview and video as first crop 2769 float previewAspect = static_cast<float>(previewWidth) / previewHeight; 2770 float videoAspect = static_cast<float>(videoWidth) / videoHeight; 2771 if (videoAspect > previewAspect) { 2772 previewAspect = videoAspect; 2773 } 2774 // First crop sensor to preview aspect ratio 2775 if (arrayAspect < previewAspect) { 2776 vertCropFactor = arrayAspect / previewAspect; 2777 } else { 2778 horizCropFactor = previewAspect / arrayAspect; 2779 } 2780 // Second crop to still aspect ratio 2781 if (stillAspect < previewAspect) { 2782 horizCropFactor *= stillAspect / previewAspect; 2783 } else { 2784 vertCropFactor *= previewAspect / stillAspect; 2785 } 2786 } else { 2787 /** 2788 * Crop are just a function of just the still/array relative aspect 2789 * ratios. Since each stream will maximize its area within the crop 2790 * region, and for FOV we assume a full-sensor crop region, we only ever 2791 * crop the FOV either vertically or horizontally, never both. 2792 */ 2793 horizCropFactor = (arrayAspect > stillAspect) ? 2794 (stillAspect / arrayAspect) : 1.f; 2795 vertCropFactor = (arrayAspect < stillAspect) ? 2796 (arrayAspect / stillAspect) : 1.f; 2797 } 2798 ALOGV("Horiz crop factor: %f, vert crop fact: %f", 2799 horizCropFactor, vertCropFactor); 2800 /** 2801 * Basic field of view formula is: 2802 * angle of view = 2 * arctangent ( d / 2f ) 2803 * where d is the physical sensor dimension of interest, and f is 2804 * the focal length. This only applies to rectilinear sensors, for focusing 2805 * at distances >> f, etc. 2806 */ 2807 if (horizFov != NULL) { 2808 *horizFov = 180 / M_PI * 2 * 2809 atanf(horizCropFactor * sensorSize.data.f[0] / 2810 (2 * fastInfo.minFocalLength)); 2811 } 2812 if (vertFov != NULL) { 2813 *vertFov = 180 / M_PI * 2 * 2814 atanf(vertCropFactor * sensorSize.data.f[1] / 2815 (2 * fastInfo.minFocalLength)); 2816 } 2817 return OK; 2818} 2819 2820int32_t Parameters::fpsFromRange(int32_t /*min*/, int32_t max) const { 2821 return max; 2822} 2823 2824}; // namespace camera2 2825}; // namespace android 2826