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