On iOS, orientation changes don't animate in a way that "looks native"
See original GitHub issueIs this a bug report?
Yes
Have you read the Contributing Guidelines?
Yes
Environment
Environment: OS: macOS Sierra 10.12.6 Node: 8.4.0 Yarn: 1.0.1 npm: 5.4.1 Watchman: 4.5.0 Xcode: Xcode 8.3.3 Build version 8E3004b Android Studio: 2.3 AI-162.3934792
Packages: (wanted => installed) react: 16.0.0-alpha.12 => 16.0.0-alpha.12 react-native: 0.48.3 => 0.48.3
Steps to Reproduce
- Create a react native app w/ react native init
- Run it on an iOS device or the iOS simulator
- (If on a simulator) Turn on slow animations (CMD+T) so the issue will be more obvious.
- Rotate the device a few times to landscape and portrait
- Observe that immediately after the orientation changes, the view is resized to the dimensions of the new orientation, and THEN the rotation animation begins. The view’s contents and dimensions are not smoothly resized while the view is being rotated.
Expected Behavior
In a regular native iOS app, when the orientation of the device changes, the view’s contents and dimensions smoothly resize while the view is also rotated at the same time.
Here is a animated gif. This is a simple native app written in swift, see how the view resizes and rotates smoothly (at the same time) on orientation changes:
Actual Behavior
On orientation changes, the view’s dimensions and contents are resized once at the very beginning of the change, and then the rotation animation happens.
Here is another animated git. This is a simple RN app, with a red border applied to the view so you can see how the view’s dimensions are immediately changed (not smoothly animated).
Reproducible Demo
Sadly I can’t seem to get the expo app to handle rotations so I guess having a Snack wouldn’t be useful.
But you can see if yourself pretty easily if you:
- Use
react-native init
to create a new app - Edit
index.ios.js
and add to the container’s styles (line ~40):
borderColor: 'red',
borderWidth: 10,
- Then run it, turn on slow animations in the simulator (CMD+T), and change the orientation a few times.
Issue Analytics
- State:
- Created 6 years ago
- Reactions:23
- Comments:29 (3 by maintainers)
Top GitHub Comments
This issue is becoming a blocker for us for using react-native. Also applies to Android. I would love to see it fixed, and can help if necessary.
Is this going to be solved. I am making a video player app and I like to open the player in landscape mode. And when I force the app to show in landcape. The animation is horrible.
Thanks