All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.facebook.react.uimanager.ReactClippingViewGroup Maven / Gradle / Ivy

There is a newer version: 0.52.u
Show newest version
/**
 * Copyright (c) 2015-present, Facebook, Inc.
 * All rights reserved.
 *
 * This source code is licensed under the BSD-style license found in the
 * LICENSE file in the root directory of this source tree. An additional grant
 * of patent rights can be found in the PATENTS file in the same directory.
 */

package com.facebook.react.uimanager;

import android.graphics.Rect;
import android.view.View;

/**
 * Interface that should be implemented by {@link View} subclasses that support
 * {@code removeClippedSubviews} property. When this property is set for the {@link ViewGroup}
 * subclass it's responsible for detaching it's child views that are clipped by the view boundaries.
 * Those view boundaries should be determined based on it's parent clipping area and current view's
 * offset in parent and doesn't necessarily reflect the view visible area (in a sense of a value
 * that {@link View#getGlobalVisibleRect} may return). In order to determine the clipping rect for
 * current view helper method {@link ReactClippingViewGroupHelper#calculateClippingRect} can be used
 * that takes into account parent view settings.
 */
public interface ReactClippingViewGroup {

  /**
   * Notify view that clipping area may have changed and it should recalculate the list of children
   * that should be attached/detached. This method should be called only when property
   * {@code removeClippedSubviews} is set to {@code true} on a view.
   *
   * CAUTION: Views are responsible for calling {@link #updateClippingRect} on it's children. This
   * should happen if child implement {@link ReactClippingViewGroup}, return true from
   * {@link #getRemoveClippedSubviews} and clipping rect change of the current view may affect
   * clipping rect of this child.
   */
  void updateClippingRect();

  /**
   * Get rectangular bounds to which view is currently clipped to. Called only on views that has set
   * {@code removeCLippedSubviews} property value to {@code true}.
   *
   * @param outClippingRect output clipping rect should be written to this object.
   */
  void getClippingRect(Rect outClippingRect);

  /**
   * Sets property {@code removeClippedSubviews} as a result of property update in JS. Should be
   * called only from @{link ViewManager#updateView} method.
   *
   * Helper method {@link ReactClippingViewGroupHelper#applyRemoveClippedSubviewsProperty} may be
   * used by {@link ViewManager} subclass to apply this property based on property update map
   * {@link ReactStylesDiffMap}.
   */
  void setRemoveClippedSubviews(boolean removeClippedSubviews);

  /**
   * Get the current value of {@code removeClippedSubviews} property.
   */
  boolean getRemoveClippedSubviews();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy