Jan 2, 2023

React Native Hybrid Meet-up @ GeekyAnts, December 2022

We hosted a hybrid meetup focused on everything React Native on December 10, 2022.
Chayan
ChayanGrowth Marketing Specialist
lines

React Reanimated 2, Skia, Expo, and creating a custom renderer were among the topics discussed. Find the speaker-wise breakdown of the meetup below.

Keynote On React Native By Neeraj Sinha | Associate Engineering Manager, GeekyAnts

B cddArtboard 5.jpg

React Native is often compared with Flutter in terms of performance and animation capabilities. A number of new animation enhancements, a new architectural approach, and a new JSI model are going to reinforce and strengthen the positioning of React Native as the go-to technology stack in comparison to Flutter. A beta version of Expo SDK 47 will be released soon as well, adding to the arsenal of React Native ecosystem.

React Native Reanimated 2 By Aishwarya P Shetty | Senior Engineer, Nagarro

B cddArtboard 6 (1).jpg

React Native Reanimated 2 helps build smooth UI and animation on the UI thread. The primary aim of this library is to provide event-handling logic onto the UI thread.

Worklets help in implementing this process.

Worklets are pure JS functions that run on the main React Native thread or are executed directly on the UI thread using runOnUI.

To install React Native, Reanimated 2 use the following:

B cddArtboard 7 (1).jpg

Key takeaways from this library include:

  • Ability to run on UI and JS threads.
  • Dedicated JS functions in worklets for creating animations.
  • Ability to access shared values for UI and JS threads.
  • Addition to animation prowess in - Interrupting updates, Customizing, and Modifiers.

There are still some limitations to this library:

  • It doesn’t support older versions of React Native.
  • Full support for the Turbo Module is not yet available.
  • Remote debugging for JS context is not supported.
  • You can’t animate virtual components of a layout.

React Native Skia | Doing Better 2D By Sourav Ganguly | React Native Developer | GeekyAnts

B cddArtboard 8_1.jpg

React Native's old architecture went through some revamping due to some significant shortcomings.

Due to its use of bridges to communicate among internal modules, React Native was slower than Flutter, which had Skia (a drawing API).

So in the new React Native architecture:

  • JSI enabled the use of other JavaScript engines.
  • JS code can directly communicate with the native side from the JS side.
  • The need to serialize JSON messages is no longer required.

The new architecture also replaced the bridges with faster modules. The only added requirement was to add drawings that render faster on screen, which brought Skia into the picture.

Skia is a GPU-accelerated 2D drawing API and graphics rendering engine that enables the creation of essential drawing components like circles, ovals, and simple designs in no time.

Thanks to Shopify, William Candollin, Christian Falch, and the entire dev team behind react-native-skia, we can now use Skia in our React Native applications to draw excellent graphics and create trendy UI concepts like Neumorphism and Glassmorphism.

Skia is not limited to this. With a lot of experimenting happening with this new library, now’s a good time to shift from an existing library or React Native code base for smoother drawings and animations.

React Reconciler Or How To Create A Custom Renderer By Nagarajan N | Tech Lead, GoGuardian

B cddArtboard 13.jpg

Web applications using React DOM and native applications using React Native employ the same principle. React-DOM and React-Native use all of the excellent, functional features that are a part of the React ecosystem.

B cddArtboard 9.jpg

The upper image in the figure below is something we are attempting to construct, and the picture below the former is how it's displayed using the renderer.

B cddArtboard 12.jpg

React employs a third-party library called React Reconciler to render the above, primarily used for cross-platform React.

A renderer combines HostConfig, Reconciler, and Platform host implementation.

A host config includes:

B cddArtboard 10.jpg

The legacy architecture ( the old one ) uses the mutation renderer. It’s a host-config that mutates the component tree after every update. The new architecture introduced a persistent renderer, which re-creates a component tree for every new update.

These renderers are directly responsible for the excellent animation we make utilizing the React Native architecture. The new architecture will usher in a slew of innovative products with highly dynamic user interfaces.

Expo Ecosystem In 2022 By Tarun Soni | Software Engineer, GeekyAnts

B cddArtboard 11.jpg

While creating a React Native app, we have two choices: 

  • To use the React Native CLI 
  • To use Expo 

Earlier, Expo wasn’t the preferred choice due to the following shortcomings:

  • Lack of Native Modules Support.
  • Difficulty in implementing Expo eject.
  • Many unsupported APIs exist, like the Bluetooth module and the Filesystem Module.

With the release of a new Expo CLI, significant enhancements have been added, including:

An Expo router

It helps achieve navigation in React Native using file-based routing inspired by Next.js. (Still in its early stages.)

An ecosystem of React Native Packages

As React Native developers heavily rely upon open-source community packages, Expo has added some new packages:

  • Expo modules: bringing native modules to Expo lets you create Swift and Kotlin libraries.
  • EAS, the deployment solution from Expo

Expo is also helping in achieving the dream of single codebase cross-platform development via:

  • Code sharing
  • Shared logic and navigation
  • Using packages like expo-next-react-navigation, which is now a framework.

So is it wise to choose Expo now?

Absolutely! Popular apps like Replit were built using Expo, underscoring the potential and growing significance of the Expo ecosystem.

Wrap Up!

Communities and collaboration are key pillars of the GeekyAnts way. This meetup was a result of this philosophy. We plan to continue holding similar events in the future.

To know more about what we do, check out our website and follow us on our social channels:

LinkedIn, Twitter, and Discord.

Hire our Development experts.