장면에서 현실적으로 밝은 가상 객체

밝기 추정을 사용하는 방법 알아보기 활용할 수 있습니다.

기본 요건

기본 AR 개념을 이해합니다. ARCore 세션을 구성하는 방법을 알아보세요.

적절한 모드로 세션당 한 번씩 API 구성

사용하려는 모드에 대해 세션당 한 번 광원 추정을 구성합니다.

자바

// Configure the session with the Lighting Estimation API in ENVIRONMENTAL_HDR mode.
Config config = session.getConfig();
config.setLightEstimationMode(LightEstimationMode.ENVIRONMENTAL_HDR);
session.configure(config);

// Configure the session with the Lighting Estimation API in AMBIENT_INTENSITY mode.
Config config = session.getConfig();
config.setLightEstimationMode(LightEstimationMode.AMBIENT_INTENSITY);
session.configure(config);

// Configure the session with the Lighting Estimation API turned off.
Config config = session.getConfig();
config.setLightEstimationMode(LightEstimationMode.DISABLED);
session.configure(config);

Kotlin

// Configure the session with the Lighting Estimation API in ENVIRONMENTAL_HDR mode.
Config config = session.config
config.lightEstimationMode = LightEstimationMode.ENVIRONMENTAL_HDR
session.configure(config)

// Configure the session with the Lighting Estimation API in AMBIENT_INTENSITY mode.
Config config = session.config
config.lightEstimationMode = LightEstimationMode.AMBIENT_INTENSITY
session.configure(config)

// Configure the session with the Lighting Estimation API turned off.
Config config = session.config
config.lightEstimationMode = LightEstimationMode.DISABLED
session.configure(config)

ENVIRONMENTAL_HDR 모드 구성

ENVIRONMENTAL_HDR 모드를 구성하려면 각 프레임의 광원 추정치를 가져옵니다. 그런 다음 사용하려는 환경 HDR 조명 구성요소를 가져옵니다.

자바

void update() {
  // Get the current frame.
  Frame frame = session.update();

  // Get the light estimate for the current frame.
  LightEstimate lightEstimate = frame.getLightEstimate();

  // Get intensity and direction of the main directional light from the current light estimate.
  float[] intensity = lightEstimate.getEnvironmentalHdrMainLightIntensity(); // note - currently only out param.
  float[] direction = lightEstimate.getEnvironmentalHdrMainLightDirection();
  app.setDirectionalLightValues(intensity, direction); // app-specific code.

  // Get ambient lighting as spherical harmonics coefficients.
  float[] harmonics = lightEstimate.getEnvironmentalHdrAmbientSphericalHarmonics();
  app.setAmbientSphericalHarmonicsLightValues(harmonics); // app-specific code.

  // Get HDR environmental lighting as a cubemap in linear color space.
  Image[] lightmaps = lightEstimate.acquireEnvironmentalHdrCubeMap();
  for (int i = 0; i < lightmaps.length /*should be 6*/; ++i) {
    app.uploadToTexture(i, lightmaps[i]);  // app-specific code.
  }
}

Kotlin

fun update() {
  // Get the current frame.
  val frame = session.update()

  // Get the light estimate for the current frame.
  val lightEstimate = frame.lightEstimate

  // Get intensity and direction of the main directional light from the current light estimate.
  val intensity = lightEstimate.environmentalHdrMainLightIntensity
  val direction = lightEstimate.environmentalHdrMainLightDirection
  app.setDirectionalLightValues(intensity, direction) // app-specific code.

  // Get ambient lighting as spherical harmonics coefficients.
  val harmonics = lightEstimate.environmentalHdrAmbientSphericalHarmonics
  app.ambientSphericalHarmonicsLightValues = harmonics // app-specific code.

  // Get HDR environmental lighting as a cubemap in linear color space.
  val lightMaps = lightEstimate.acquireEnvironmentalHdrCubeMap();
  for ((index, lightMap) in lightMaps.withIndex()) { // 6 maps total.
    app.uploadToTexture(index, lightMap); // app-specific code.
  }
}

AMBIENT_INTENSITY 모드 구성

AMBIENT_INTENSITY의 색상 보정 구성요소를 사용하려는 경우 먼저 공유 할당을 재사용하여 모든 프레임에서 색상 보정 할당을 피할 수 있습니다.

자바

 // Avoid allocation on every frame.
float[] colorCorrection = new float[4];

Kotlin

val colorCorrection = floatArrayOf(0.0f, 0.0f, 0.0f, 0.0f)

각 프레임의 조도 추정치와 주변 강도 구성요소를 가져옵니다. 선택합니다.

자바

void update() {
  // Get the current frame.
  Frame frame = session.update();

  // Get the light estimate for the current frame.
  LightEstimate lightEstimate = frame.getLightEstimate();

  // Get the pixel intensity of AMBIENT_INTENSITY mode.
  float pixelIntensity = lightEstimate.getPixelIntensity();

  // Read the pixel color correction of AMBIENT_INTENSITY mode into colorCorrection.
  lightEstimate.getColorCorrection(colorCorrection, 0);
}

Kotlin

fun update() {
    // Get the current frame.
  val frame = session.update()

  // Get the light estimate for the current frame.
  val lightEstimate = frame.lightEstimate

  // Get the pixel intensity of AMBIENT_INTENSITY mode.
  val pixelIntensity = lightEstimate.pixelIntensity

  // Read the pixel color correction of AMBIENT_INTENSITY mode into colorCorrection.
  lightEstimate.getColorCorrection(colorCorrection, 0)
}

Environmental HDR API를 통한 에너지 절약

에너지 보존은 표면에서 반사되는 빛이 표면에 닿기 전보다 결코 더 강렬하지 않죠. 이 규칙: 물리적 기반 렌더링에서 적용되지만 일반적으로 레거시에서는 생략됩니다. 비디오 게임과 모바일 앱에 사용되는 렌더링 파이프라인을 살펴봤죠

환경 HDR 조명 추정치와 함께 물리 기반 렌더링 파이프라인을 사용하는 경우 가상 물체에 물리 기반 재료가 사용되는지 확인하기만 하면 됩니다.

그러나 물리적 기반 파이프라인을 사용하지 않는 경우에는 옵션:

  • 가장 이상적인 해결 방법은 물리적 기반 파이프라인으로 이전하는 것입니다.

  • 그러나 불가능하다면 물리적 기반이 아닌 재료의 알베도 값에 에너지 보존 계수를 곱하는 것이 좋습니다. 이렇게 하면 적어도 BRDF 음영 모델을 물리 기반으로 변환할 수 있습니다. BRDF마다 다른 요소가 있습니다. 예를 들어 확산 반사의 경우 1/Pi입니다.