mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
ab5e87fd95
Summary: For debugging, add prettyPrint method to AnimatedNode classes. Changelog: [Internal] Reviewed By: shergin Differential Revision: D22752292 fbshipit-source-id: ce1f08fc4fd97f38629dd82151c6ea762026c7c9
128 lines
4.7 KiB
Java
128 lines
4.7 KiB
Java
/*
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
package com.facebook.react.animated;
|
|
|
|
import androidx.annotation.Nullable;
|
|
import com.facebook.react.bridge.JSApplicationIllegalArgumentException;
|
|
import com.facebook.react.bridge.JavaOnlyMap;
|
|
import com.facebook.react.bridge.ReadableMap;
|
|
import com.facebook.react.bridge.ReadableMapKeySetIterator;
|
|
import com.facebook.react.bridge.UIManager;
|
|
import com.facebook.react.uimanager.common.UIManagerType;
|
|
import com.facebook.react.uimanager.common.ViewUtil;
|
|
import java.util.HashMap;
|
|
import java.util.Map;
|
|
|
|
/**
|
|
* Animated node that represents view properties. There is a special handling logic implemented for
|
|
* the nodes of this type in {@link NativeAnimatedNodesManager} that is responsible for extracting a
|
|
* map of updated properties, which can be then passed down to the view.
|
|
*/
|
|
/*package*/ class PropsAnimatedNode extends AnimatedNode {
|
|
|
|
private int mConnectedViewTag = -1;
|
|
private final NativeAnimatedNodesManager mNativeAnimatedNodesManager;
|
|
private final Map<String, Integer> mPropNodeMapping;
|
|
private final JavaOnlyMap mPropMap;
|
|
@Nullable private UIManager mUIManager;
|
|
|
|
PropsAnimatedNode(ReadableMap config, NativeAnimatedNodesManager nativeAnimatedNodesManager) {
|
|
ReadableMap props = config.getMap("props");
|
|
ReadableMapKeySetIterator iter = props.keySetIterator();
|
|
mPropNodeMapping = new HashMap<>();
|
|
while (iter.hasNextKey()) {
|
|
String propKey = iter.nextKey();
|
|
int nodeIndex = props.getInt(propKey);
|
|
mPropNodeMapping.put(propKey, nodeIndex);
|
|
}
|
|
mPropMap = new JavaOnlyMap();
|
|
mNativeAnimatedNodesManager = nativeAnimatedNodesManager;
|
|
}
|
|
|
|
public void connectToView(int viewTag, UIManager uiManager) {
|
|
if (mConnectedViewTag != -1) {
|
|
throw new JSApplicationIllegalArgumentException(
|
|
"Animated node " + mTag + " is " + "already attached to a view: " + mConnectedViewTag);
|
|
}
|
|
mConnectedViewTag = viewTag;
|
|
mUIManager = uiManager;
|
|
}
|
|
|
|
public void disconnectFromView(int viewTag) {
|
|
if (mConnectedViewTag != viewTag && mConnectedViewTag != -1) {
|
|
throw new JSApplicationIllegalArgumentException(
|
|
"Attempting to disconnect view that has "
|
|
+ "not been connected with the given animated node: "
|
|
+ viewTag
|
|
+ " but is connected to view "
|
|
+ mConnectedViewTag);
|
|
}
|
|
|
|
mConnectedViewTag = -1;
|
|
}
|
|
|
|
public void restoreDefaultValues() {
|
|
// Cannot restore default values if this view has already been disconnected.
|
|
if (mConnectedViewTag == -1) {
|
|
return;
|
|
}
|
|
// Don't restore default values in Fabric.
|
|
// In Non-Fabric this had the effect of "restore the value to whatever the value was on the
|
|
// ShadowNode instead of in the View hierarchy". However, "synchronouslyUpdateViewOnUIThread"
|
|
// will not have that impact on Fabric, because the FabricUIManager doesn't have access to the
|
|
// ShadowNode layer.
|
|
if (ViewUtil.getUIManagerType(mConnectedViewTag) == UIManagerType.FABRIC) {
|
|
return;
|
|
}
|
|
|
|
ReadableMapKeySetIterator it = mPropMap.keySetIterator();
|
|
while (it.hasNextKey()) {
|
|
mPropMap.putNull(it.nextKey());
|
|
}
|
|
|
|
mUIManager.synchronouslyUpdateViewOnUIThread(mConnectedViewTag, mPropMap);
|
|
}
|
|
|
|
public final void updateView() {
|
|
if (mConnectedViewTag == -1) {
|
|
return;
|
|
}
|
|
for (Map.Entry<String, Integer> entry : mPropNodeMapping.entrySet()) {
|
|
@Nullable AnimatedNode node = mNativeAnimatedNodesManager.getNodeById(entry.getValue());
|
|
if (node == null) {
|
|
throw new IllegalArgumentException("Mapped property node does not exists");
|
|
} else if (node instanceof StyleAnimatedNode) {
|
|
((StyleAnimatedNode) node).collectViewUpdates(mPropMap);
|
|
} else if (node instanceof ValueAnimatedNode) {
|
|
Object animatedObject = ((ValueAnimatedNode) node).getAnimatedObject();
|
|
if (animatedObject instanceof String) {
|
|
mPropMap.putString(entry.getKey(), (String) animatedObject);
|
|
} else {
|
|
mPropMap.putDouble(entry.getKey(), ((ValueAnimatedNode) node).getValue());
|
|
}
|
|
} else {
|
|
throw new IllegalArgumentException(
|
|
"Unsupported type of node used in property node " + node.getClass());
|
|
}
|
|
}
|
|
|
|
mUIManager.synchronouslyUpdateViewOnUIThread(mConnectedViewTag, mPropMap);
|
|
}
|
|
|
|
public String prettyPrint() {
|
|
return "PropsAnimatedNode["
|
|
+ mTag
|
|
+ "] connectedViewTag: "
|
|
+ mConnectedViewTag
|
|
+ " mPropNodeMapping: "
|
|
+ (mPropNodeMapping != null ? mPropNodeMapping.toString() : "null")
|
|
+ " mPropMap: "
|
|
+ (mPropMap != null ? mPropMap.toString() : "null");
|
|
}
|
|
}
|