ForceMountToView when Opacity or other View-specific properties are applied to a FlatShadowNode

Summary: @public There are some properties, such as alpha or scale that we ONLY handle on a View level. This means that whenever we encounter a FlatShadowNode with this property, it should be mapped to a View. This diff is doing exactly this.

Reviewed By: ahmedre

Differential Revision: D2694495
This commit is contained in:
Denis Koroskin 2015-12-15 14:29:58 -08:00 committed by Ahmed El-Helw
parent 0d042c2ef4
commit 1da7049426
2 changed files with 37 additions and 3 deletions

View File

@ -11,6 +11,7 @@ package com.facebook.react.flat;
import javax.annotation.Nullable; import javax.annotation.Nullable;
import com.facebook.react.uimanager.CatalystStylesDiffMap;
import com.facebook.react.uimanager.LayoutShadowNode; import com.facebook.react.uimanager.LayoutShadowNode;
import com.facebook.react.uimanager.ReactProp; import com.facebook.react.uimanager.ReactProp;
import com.facebook.react.uimanager.ViewProps; import com.facebook.react.uimanager.ViewProps;
@ -23,6 +24,15 @@ import com.facebook.react.uimanager.ViewProps;
/* package */ static final FlatShadowNode[] EMPTY_ARRAY = new FlatShadowNode[0]; /* package */ static final FlatShadowNode[] EMPTY_ARRAY = new FlatShadowNode[0];
private static final String PROP_DECOMPOSED_MATRIX = "decomposedMatrix";
private static final String PROP_OPACITY = "opacity";
private static final String PROP_RENDER_TO_HARDWARE_TEXTURE = "renderToHardwareTextureAndroid";
private static final String PROP_ACCESSIBILITY_LABEL = "accessibilityLabel";
private static final String PROP_ACCESSIBILITY_COMPONENT_TYPE = "accessibilityComponentType";
private static final String PROP_ACCESSIBILITY_LIVE_REGION = "accessibilityLiveRegion";
private static final String PROP_IMPORTANT_FOR_ACCESSIBILITY = "importantForAccessibility";
private static final String PROP_TEST_ID = "testID";
private DrawCommand[] mDrawCommands = DrawCommand.EMPTY_ARRAY; private DrawCommand[] mDrawCommands = DrawCommand.EMPTY_ARRAY;
private AttachDetachListener[] mAttachDetachListeners = AttachDetachListener.EMPTY_ARRAY; private AttachDetachListener[] mAttachDetachListeners = AttachDetachListener.EMPTY_ARRAY;
private NodeRegion[] mNodeRegions = NodeRegion.EMPTY_ARRAY; private NodeRegion[] mNodeRegions = NodeRegion.EMPTY_ARRAY;
@ -37,6 +47,22 @@ import com.facebook.react.uimanager.ViewProps;
private boolean mBackingViewIsCreated; private boolean mBackingViewIsCreated;
private @Nullable DrawBackgroundColor mDrawBackground; private @Nullable DrawBackgroundColor mDrawBackground;
/* package */ void handleUpdateProperties(CatalystStylesDiffMap styles) {
if (!mountsToView()) {
// Make sure we mount this FlatShadowNode to a View if any of these properties are present.
if (styles.hasKey(PROP_DECOMPOSED_MATRIX) ||
styles.hasKey(PROP_OPACITY) ||
styles.hasKey(PROP_RENDER_TO_HARDWARE_TEXTURE) ||
styles.hasKey(PROP_TEST_ID) ||
styles.hasKey(PROP_ACCESSIBILITY_LABEL) ||
styles.hasKey(PROP_ACCESSIBILITY_COMPONENT_TYPE) ||
styles.hasKey(PROP_ACCESSIBILITY_LIVE_REGION) ||
styles.hasKey(PROP_IMPORTANT_FOR_ACCESSIBILITY)) {
forceMountToView();
}
}
}
/** /**
* Collects DrawCommands produced by this FlatShadoNode. * Collects DrawCommands produced by this FlatShadoNode.
*/ */

View File

@ -79,10 +79,15 @@ public class FlatUIImplementation extends UIImplementation {
protected void handleCreateView( protected void handleCreateView(
ReactShadowNode cssNode, ReactShadowNode cssNode,
int rootViewTag, int rootViewTag,
CatalystStylesDiffMap styles) { @Nullable CatalystStylesDiffMap styles) {
int tag = cssNode.getReactTag();
FlatShadowNode node = (FlatShadowNode) cssNode; FlatShadowNode node = (FlatShadowNode) cssNode;
if (styles != null) {
node.handleUpdateProperties(styles);
}
if (node.mountsToView()) { if (node.mountsToView()) {
int tag = cssNode.getReactTag();
mStateBuilder.ensureBackingViewIsCreated(node, tag, styles); mStateBuilder.ensureBackingViewIsCreated(node, tag, styles);
} }
} }
@ -92,9 +97,12 @@ public class FlatUIImplementation extends UIImplementation {
ReactShadowNode cssNode, ReactShadowNode cssNode,
String className, String className,
CatalystStylesDiffMap styles) { CatalystStylesDiffMap styles) {
int tag = cssNode.getReactTag();
FlatShadowNode node = (FlatShadowNode) cssNode; FlatShadowNode node = (FlatShadowNode) cssNode;
node.handleUpdateProperties(styles);
if (node.mountsToView()) { if (node.mountsToView()) {
int tag = cssNode.getReactTag();
mStateBuilder.ensureBackingViewIsCreated(node, tag, styles); mStateBuilder.ensureBackingViewIsCreated(node, tag, styles);
} }
} }