diff --git a/Libraries/NativeAnimation/RCTNativeAnimatedModule.m b/Libraries/NativeAnimation/RCTNativeAnimatedModule.m index 5e182ab680..38ba6395b0 100644 --- a/Libraries/NativeAnimation/RCTNativeAnimatedModule.m +++ b/Libraries/NativeAnimation/RCTNativeAnimatedModule.m @@ -239,11 +239,11 @@ RCT_EXPORT_METHOD(removeAnimatedEventFromView:(nonnull NSNumber *)viewTag - (void)eventDispatcherWillDispatchEvent:(id)event { - // Native animated events only work for events dispatched from the main queue. - if (!RCTIsMainQueue()) { - return; - } - return [_nodesManager handleAnimatedEvent:event]; + // Events can be dispatched from any queue so we have to make sure handleAnimatedEvent + // is run from the main queue. + RCTExecuteOnMainQueue(^{ + [self->_nodesManager handleAnimatedEvent:event]; + }); } @end diff --git a/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java b/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java index c802663359..68b0ad62a3 100644 --- a/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java +++ b/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.java @@ -361,12 +361,22 @@ import javax.annotation.Nullable; } @Override - public void onEventDispatch(Event event) { - // Only support events dispatched from the UI thread. - if (!UiThreadUtil.isOnUiThread()) { - return; + public void onEventDispatch(final Event event) { + // Events can be dispatched from any thread so we have to make sure handleEvent is run from the + // UI thread. + if (UiThreadUtil.isOnUiThread()) { + handleEvent(event); + } else { + UiThreadUtil.runOnUiThread(new Runnable() { + @Override + public void run() { + handleEvent(event); + } + }); } + } + private void handleEvent(Event event) { if (!mEventDrivers.isEmpty()) { // If the event has a different name in native convert it to it's JS name. String eventName = mCustomEventNamesResolver.resolveCustomEventName(event.getEventName());