| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "modules/imagecapture/ImageCapture.h" | 5 #include "modules/imagecapture/ImageCapture.h" |
| 6 | 6 |
| 7 #include "bindings/core/v8/CallbackPromiseAdapter.h" | 7 #include "bindings/core/v8/CallbackPromiseAdapter.h" |
| 8 #include "bindings/core/v8/ScriptPromiseResolver.h" | 8 #include "bindings/core/v8/ScriptPromiseResolver.h" |
| 9 #include "core/dom/DOMException.h" | 9 #include "core/dom/DOMException.h" |
| 10 #include "core/dom/ExceptionCode.h" | 10 #include "core/dom/ExceptionCode.h" |
| 11 #include "core/fileapi/Blob.h" | 11 #include "core/fileapi/Blob.h" |
| 12 #include "core/frame/ImageBitmap.h" | 12 #include "core/frame/ImageBitmap.h" |
| 13 #include "modules/EventTargetModules.h" | 13 #include "modules/EventTargetModules.h" |
| 14 #include "modules/imagecapture/MediaSettingsRange.h" | 14 #include "modules/imagecapture/MediaSettingsRange.h" |
| 15 #include "modules/imagecapture/PhotoCapabilities.h" | 15 #include "modules/imagecapture/PhotoCapabilities.h" |
| 16 #include "modules/imagecapture/PhotoSettings.h" | 16 #include "modules/imagecapture/PhotoSettings.h" |
| 17 #include "modules/mediastream/MediaStreamTrack.h" | 17 #include "modules/mediastream/MediaStreamTrack.h" |
| 18 #include "modules/mediastream/MediaTrackCapabilities.h" | 18 #include "modules/mediastream/MediaTrackCapabilities.h" |
| 19 #include "modules/mediastream/MediaTrackConstraintSet.h" | |
| 20 #include "platform/WaitableEvent.h" | 19 #include "platform/WaitableEvent.h" |
| 21 #include "platform/mojo/MojoHelper.h" | 20 #include "platform/mojo/MojoHelper.h" |
| 22 #include "public/platform/InterfaceProvider.h" | 21 #include "public/platform/InterfaceProvider.h" |
| 23 #include "public/platform/Platform.h" | 22 #include "public/platform/Platform.h" |
| 24 #include "public/platform/WebImageCaptureFrameGrabber.h" | 23 #include "public/platform/WebImageCaptureFrameGrabber.h" |
| 25 #include "public/platform/WebMediaStreamTrack.h" | 24 #include "public/platform/WebMediaStreamTrack.h" |
| 26 #include "wtf/PtrUtil.h" | 25 #include "wtf/PtrUtil.h" |
| 27 | 26 |
| 28 namespace blink { | 27 namespace blink { |
| 29 | 28 |
| (...skipping 263 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 293 } | 292 } |
| 294 m_serviceRequests.insert(resolver); | 293 m_serviceRequests.insert(resolver); |
| 295 | 294 |
| 296 auto settings = media::mojom::blink::PhotoSettings::New(); | 295 auto settings = media::mojom::blink::PhotoSettings::New(); |
| 297 | 296 |
| 298 // TODO(mcasas): support other Mode types beyond simple string i.e. the | 297 // TODO(mcasas): support other Mode types beyond simple string i.e. the |
| 299 // equivalents of "sequence<DOMString>"" or "ConstrainDOMStringParameters". | 298 // equivalents of "sequence<DOMString>"" or "ConstrainDOMStringParameters". |
| 300 settings->has_white_balance_mode = constraints.hasWhiteBalanceMode() && | 299 settings->has_white_balance_mode = constraints.hasWhiteBalanceMode() && |
| 301 constraints.whiteBalanceMode().isString(); | 300 constraints.whiteBalanceMode().isString(); |
| 302 if (settings->has_white_balance_mode) { | 301 if (settings->has_white_balance_mode) { |
| 302 m_currentConstraints.setWhiteBalanceMode(constraints.whiteBalanceMode()); |
| 303 settings->white_balance_mode = | 303 settings->white_balance_mode = |
| 304 parseMeteringMode(constraints.whiteBalanceMode().getAsString()); | 304 parseMeteringMode(constraints.whiteBalanceMode().getAsString()); |
| 305 } | 305 } |
| 306 settings->has_exposure_mode = | 306 settings->has_exposure_mode = |
| 307 constraints.hasExposureMode() && constraints.exposureMode().isString(); | 307 constraints.hasExposureMode() && constraints.exposureMode().isString(); |
| 308 if (settings->has_exposure_mode) { | 308 if (settings->has_exposure_mode) { |
| 309 m_currentConstraints.setExposureMode(constraints.exposureMode()); |
| 309 settings->exposure_mode = | 310 settings->exposure_mode = |
| 310 parseMeteringMode(constraints.exposureMode().getAsString()); | 311 parseMeteringMode(constraints.exposureMode().getAsString()); |
| 311 } | 312 } |
| 312 | 313 |
| 313 settings->has_focus_mode = | 314 settings->has_focus_mode = |
| 314 constraints.hasFocusMode() && constraints.focusMode().isString(); | 315 constraints.hasFocusMode() && constraints.focusMode().isString(); |
| 315 if (settings->has_focus_mode) { | 316 if (settings->has_focus_mode) { |
| 317 m_currentConstraints.setFocusMode(constraints.focusMode()); |
| 316 settings->focus_mode = | 318 settings->focus_mode = |
| 317 parseMeteringMode(constraints.focusMode().getAsString()); | 319 parseMeteringMode(constraints.focusMode().getAsString()); |
| 318 } | 320 } |
| 319 | 321 |
| 320 // TODO(mcasas): support ConstrainDoubleRange where applicable. | 322 // TODO(mcasas): support ConstrainDoubleRange where applicable. |
| 321 settings->has_exposure_compensation = | 323 settings->has_exposure_compensation = |
| 322 constraints.hasExposureCompensation() && | 324 constraints.hasExposureCompensation() && |
| 323 constraints.exposureCompensation().isDouble(); | 325 constraints.exposureCompensation().isDouble(); |
| 324 if (settings->has_exposure_compensation) { | 326 if (settings->has_exposure_compensation) { |
| 327 m_currentConstraints.setExposureCompensation( |
| 328 constraints.exposureCompensation()); |
| 325 settings->exposure_compensation = | 329 settings->exposure_compensation = |
| 326 constraints.exposureCompensation().getAsDouble(); | 330 constraints.exposureCompensation().getAsDouble(); |
| 327 } | 331 } |
| 328 settings->has_color_temperature = constraints.hasColorTemperature() && | 332 settings->has_color_temperature = constraints.hasColorTemperature() && |
| 329 constraints.colorTemperature().isDouble(); | 333 constraints.colorTemperature().isDouble(); |
| 330 if (settings->has_color_temperature) | 334 if (settings->has_color_temperature) { |
| 335 m_currentConstraints.setColorTemperature(constraints.colorTemperature()); |
| 331 settings->color_temperature = constraints.colorTemperature().getAsDouble(); | 336 settings->color_temperature = constraints.colorTemperature().getAsDouble(); |
| 337 } |
| 332 settings->has_iso = constraints.hasIso() && constraints.iso().isDouble(); | 338 settings->has_iso = constraints.hasIso() && constraints.iso().isDouble(); |
| 333 if (settings->has_iso) | 339 if (settings->has_iso) { |
| 340 m_currentConstraints.setIso(constraints.iso()); |
| 334 settings->iso = constraints.iso().getAsDouble(); | 341 settings->iso = constraints.iso().getAsDouble(); |
| 342 } |
| 335 | 343 |
| 336 settings->has_brightness = | 344 settings->has_brightness = |
| 337 constraints.hasBrightness() && constraints.brightness().isDouble(); | 345 constraints.hasBrightness() && constraints.brightness().isDouble(); |
| 338 if (settings->has_brightness) | 346 if (settings->has_brightness) { |
| 347 m_currentConstraints.setBrightness(constraints.brightness()); |
| 339 settings->brightness = constraints.brightness().getAsDouble(); | 348 settings->brightness = constraints.brightness().getAsDouble(); |
| 349 } |
| 340 settings->has_contrast = | 350 settings->has_contrast = |
| 341 constraints.hasContrast() && constraints.contrast().isDouble(); | 351 constraints.hasContrast() && constraints.contrast().isDouble(); |
| 342 if (settings->has_contrast) | 352 if (settings->has_contrast) { |
| 353 m_currentConstraints.setContrast(constraints.contrast()); |
| 343 settings->contrast = constraints.contrast().getAsDouble(); | 354 settings->contrast = constraints.contrast().getAsDouble(); |
| 355 } |
| 344 settings->has_saturation = | 356 settings->has_saturation = |
| 345 constraints.hasSaturation() && constraints.saturation().isDouble(); | 357 constraints.hasSaturation() && constraints.saturation().isDouble(); |
| 346 if (settings->has_saturation) | 358 if (settings->has_saturation) { |
| 359 m_currentConstraints.setSaturation(constraints.saturation()); |
| 347 settings->saturation = constraints.saturation().getAsDouble(); | 360 settings->saturation = constraints.saturation().getAsDouble(); |
| 361 } |
| 348 settings->has_sharpness = | 362 settings->has_sharpness = |
| 349 constraints.hasSharpness() && constraints.sharpness().isDouble(); | 363 constraints.hasSharpness() && constraints.sharpness().isDouble(); |
| 350 if (settings->has_sharpness) | 364 if (settings->has_sharpness) { |
| 365 m_currentConstraints.setSharpness(constraints.sharpness()); |
| 351 settings->sharpness = constraints.sharpness().getAsDouble(); | 366 settings->sharpness = constraints.sharpness().getAsDouble(); |
| 367 } |
| 352 | 368 |
| 353 settings->has_zoom = constraints.hasZoom() && constraints.zoom().isDouble(); | 369 settings->has_zoom = constraints.hasZoom() && constraints.zoom().isDouble(); |
| 354 if (settings->has_zoom) | 370 if (settings->has_zoom) { |
| 371 m_currentConstraints.setZoom(constraints.zoom()); |
| 355 settings->zoom = constraints.zoom().getAsDouble(); | 372 settings->zoom = constraints.zoom().getAsDouble(); |
| 373 } |
| 356 | 374 |
| 357 // TODO(mcasas): add |torch| when the mojom interface is updated, | 375 // TODO(mcasas): add |torch| when the mojom interface is updated, |
| 358 // https://crbug.com/700607. | 376 // https://crbug.com/700607. |
| 359 | 377 |
| 360 m_service->SetOptions(m_streamTrack->component()->source()->id(), | 378 m_service->SetOptions(m_streamTrack->component()->source()->id(), |
| 361 std::move(settings), | 379 std::move(settings), |
| 362 convertToBaseCallback(WTF::bind( | 380 convertToBaseCallback(WTF::bind( |
| 363 &ImageCapture::onSetOptions, wrapPersistent(this), | 381 &ImageCapture::onSetOptions, wrapPersistent(this), |
| 364 wrapPersistent(resolver)))); | 382 wrapPersistent(resolver)))); |
| 365 } | 383 } |
| 366 | 384 |
| 385 const MediaTrackConstraintSet& ImageCapture::getMediaTrackConstraints() const { |
| 386 return m_currentConstraints; |
| 387 } |
| 388 |
| 367 ImageCapture::ImageCapture(ExecutionContext* context, MediaStreamTrack* track) | 389 ImageCapture::ImageCapture(ExecutionContext* context, MediaStreamTrack* track) |
| 368 : ContextLifecycleObserver(context), m_streamTrack(track) { | 390 : ContextLifecycleObserver(context), m_streamTrack(track) { |
| 369 DCHECK(m_streamTrack); | 391 DCHECK(m_streamTrack); |
| 370 DCHECK(!m_service.is_bound()); | 392 DCHECK(!m_service.is_bound()); |
| 371 | 393 |
| 372 Platform::current()->interfaceProvider()->getInterface( | 394 Platform::current()->interfaceProvider()->getInterface( |
| 373 mojo::MakeRequest(&m_service)); | 395 mojo::MakeRequest(&m_service)); |
| 374 | 396 |
| 375 m_service.set_connection_error_handler(convertToBaseCallback(WTF::bind( | 397 m_service.set_connection_error_handler(convertToBaseCallback(WTF::bind( |
| 376 &ImageCapture::onServiceConnectionError, wrapWeakPersistent(this)))); | 398 &ImageCapture::onServiceConnectionError, wrapWeakPersistent(this)))); |
| (...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 519 | 541 |
| 520 DEFINE_TRACE(ImageCapture) { | 542 DEFINE_TRACE(ImageCapture) { |
| 521 visitor->trace(m_streamTrack); | 543 visitor->trace(m_streamTrack); |
| 522 visitor->trace(m_capabilities); | 544 visitor->trace(m_capabilities); |
| 523 visitor->trace(m_serviceRequests); | 545 visitor->trace(m_serviceRequests); |
| 524 EventTargetWithInlineData::trace(visitor); | 546 EventTargetWithInlineData::trace(visitor); |
| 525 ContextLifecycleObserver::trace(visitor); | 547 ContextLifecycleObserver::trace(visitor); |
| 526 } | 548 } |
| 527 | 549 |
| 528 } // namespace blink | 550 } // namespace blink |
| OLD | NEW |