I believe you have experienced this year’s Alipay Wufu activities, both the homepage of this year’s Wufu and the game are driven by ant interactive graphics Engine (code name: Oasis Engine).
Oasis Engine is the Web 3D interactive graphics Engine of Ant Group, and also the preferred Web 3D Engine of Alibaba interactive technology direction, which has been officially open source on February 1st.
This article will give you an overview of Oasis Engine, its past life and future prospects. Hopefully this article will give you a glimpse of the Oasis Engine.
The engine is introduced
Oasis Engine is a Web first, mobile first interactive/authoring platform. Use a component system architecture and strive for ease of use and lightweight. Oasis Engine consists of Oasis Runtime, Oasis Editor and Oasis Store. Next we will introduce the engine in terms of overview, features, stability and performance.
An overview of the
Oasis Engine adopts component system architecture. Oasis Engine not only needs to have 3D rendering capability, but also needs to contain a lot of functions from various fields, such as 2D, 3D, UI, audio, physics, VR/AR, logic writing, etc. These functions are just needed by developers. At the same time, developers usually want to keep the structure of the engine clear and flexible combination of functions.
In addition to this, business development often wants to do feature precipitation, which is actually a ease-of-use category. In this trade-off between functional complexity and ease of use, we chose the component system architecture. In the component system architecture, everything is a component, and any function can be inserted and removed in the form of components, flexible combination. Scripts are also a special kind of component, and developers can naturally reuse business functions as components.
Oasis engine uses scripting system for logic writing. We provide a lot of script life cycle callbacks, and developers can simply override the callbacks they need.
Scripting has obvious advantages over writing logic through events in terms of ease of use and readability. Scripting systems are a more natural approach, especially in component systems architecture. Even when we do engine architecture, we never think that any kind of architecture is absolutely right or wrong. It is more about trade-offs and appropriate discussions. At the same time, we have also made a lot of experience optimization in the scripting system, such as providing clone decorators, developers can choose different clone decorators according to the actual situation of the property to set the clone mode, compared with manual writing clone function is more easy to use.
The Oasis engine uses TypeScript as its development language. TypeScript is a strongly typed superset of JavaScript that has significant advantages over weakly typed JavaScript. Especially for large and complex projects, TypeScript’s productivity gains are significant. Many front-end developers have seen this in recent years. We also recommend writing logical scripts in TypeScript.
The Oasis engine’s pursuit of rigor, simplicity, and ease of use in the design of its APIS may sound very general, but behind this is the accumulation of countless design details. In terms of motion, API design that is clean, natural, easy to use and intuitive to developers is good design. We also use a lot of modern syntactic features in API design, such as function overloading, decorators, async/await, generics, etc. These syntactic features are very important for API design and will directly improve the user development experience.
Function is introduced
Transform is a frequently used function of the engine. Both rendering and physics require Transform description coordinates and other relevant information. Therefore, an excellent Transform should not only have powerful functions, but also have good performance optimization.
One of the most significant features of Transfrom is that the parent transformation will affect the child transformation. For example, we can think that modifying the local position of the parent node will trigger the world position change of itself and its children. However, it can be much more complicated than that, and if you modify the local rotation of the parent node, you trigger not only a change in the world rotation of itself and its children, but also a change in the world position of itself and its children. Modifying local scaling also has a similar effect. We do a lot of atomized dirty tags inside the Transform. The basic principle is that no get attribute is evaluated, and if the get attribute is evaluated, the dirty tag is used to determine whether to recalculate.
Webgl-based engines often face the problem that JS does not have destructors. The engine’s video memory objects are not managed by JS and will leak if left untreated. Therefore, the Oasis engine provides a manual resource release function, which can directly call the object destruction function to release the video memory. However, the actual problem is more complicated. When designing a model for the developer, we do not know the reference relationship of the model to the resource. For example, entities refer to materials, and materials refer to textures, and the relationship between them is very complicated. First, these resources are hard to find; Second, once found, it is difficult to ensure that it is not referenced by other models and safely destroyed.
The resource system is the basic capability of the engine, including the responsibility of loading and managing resources. The Oasis engine’s resource system loading API is very easy to use and supports generic and asynchronous programming. We do resource reference counting, developers only need to care about the destruction of entity nodes, the engine automatically maintains reference counting, and when calling Resourcemanager.gc (), all assets with zero reference count are automatically destroyed, thus directly balancing functionality and ease of use.
The shader/shader system is the rendering heart of the engine, and to some extent determines the health of the engine. The Oasis engine is very simple to customize shaders, allowing developers to focus on the shader logic itself. The data setting for the shader is also very simple, requiring only a call to the relevant interface in shaderData. For those of you with development experience, you may also know the shader macro function, which in Oasis is as simple as calling the enableMacro interface. The associated child shader compilation is handled automatically inside the reference.
In addition to being simple, Oasis’s entire shader system is very powerful. Oasis is also a GPU-friendly engine that can set shader data not only by materials, but also by scenes, renderers, cameras, and other objects. In addition, modules such as skin calculation, particle trajectory calculation and material coloring can be naturally put into GPU for execution, giving full play to the parallel computing capability of GPU.
In addition to custom shaders, the Oasis engine also provides a flexible and powerful BufferGeometry system that developers can use to customize geometry data. The BufferGeometry system supports staggered vertex buffers, independent vertex buffers, instance buffers, and index buffers, which will be familiar to those who have done low-level graphics development. Oasis’ BufferGeometry system contains almost all gPU-related geometry data processing capabilities. It is essential that the engine contains easy-to-use features, and it is great if it is flexible and powerful at the same time.
Let’s talk about what BufferGeometry can do, but advanced developers can use it to access any custom particles, tailers, etc. For example, Mars and Spine components are connected by the BufferGeometry system. Mars is also a high-performance animation and special effects software from Ant Group. As you probably know, Spine is a very popular 2D animation software.
Stability and performance
Stability and performance are very important for engines. We have made great efforts in stability and performance, and the crash rate is less than 0.3 per 10,000 in platform projects with hundreds of millions of traffic:
- On the testing side, we added a single test case for each feature as we wrote it, and we also deployed automated CI tests on Github.
- We also put a lot of effort into performance optimization, such as component-driven correlation optimization, Transform optimization, video memory upload optimization, math library optimization, and so on.
- In terms of memory optimization, we provide GPU texture compression, which can reduce texture memory by about 80%, and also provide a good resource GC management mechanism. In every system design, we will consider the balance between performance and memory, and will not blindly use “space for time”.
Let’s talk about our current performance status. Based on the performance test case shown in the figure above, the performance of Oasis is also compared with that of well-known foreign Web3D engines. With the same test scale and environment, the performance of Oasis is about two times that of well-known foreign Web3D engines. Although this case is not very comprehensive, it is at least the comprehensive performance of some pieces of function.
conclusion
Finally, we summarize the engine introduction. Oasis engine adopts component system architecture, logic writing adopts scripting system, engine source code is written in TypeScript. In terms of functions, we have introduced several basic systems of the engine, namely Transform system, Resource system, material/Coloring system and BufferGeometry system. We believe that we will have the opportunity to introduce more functions with you in the future. Stability and performance, with financial stability and leading performance.
All men are mortal
Next, we will introduce the past and present of Oasis engine. According to Wang Xiaobo’s “Trilogy of Times”, Oasis engine has been divided into three stages: black Iron Age, Bronze Age and silver Age.
Black iron age
The first stage is the “Black Iron Era” (2016-2018). In 2016, the mobile terminal business of Alibaba and Ant is booming, but the graphics technology facing interactive demand is still lagging behind. Take the Web 3D engine as an example, it relies on the Three. Js engine which is not born for mobile terminal for a long time. In terms of asset standards, glTF 2.0 has not yet been born, and obJ + MTL, an ancient format, does not support advanced materials such as PBR. Although FBX is convenient for designers to export, many projects are aborted in the engine stage of art assets due to its large size and unstable loader of Three.
At the end of 2016, the first hero appeared in the history of Ant graphics engine, Jing Fu (ant senior graphics technical expert, Xianjian third main program, R3 core developer) wrote down the first line of ant graphics engine code, the project was named R3 (meaning Render for 3D). R3 is born for the interactive business of Ant mobile terminal. It adopts the advanced component system game engine architecture in the industry. In order to minimize the runtime volume in engineering, it adopts the popular Monorepo multi-package single-warehouse development mode. In order to solve the problem of scene editing more conveniently, R3 has also defined its own development workflow. It uses the industry-leading Unity editor as the scene editor, and exports glTF files through its own Unity plug-in for the runtime to load and parse into scenes.
There are several classic games from the Black Iron era, and today you can still see these Low Ploygon style games on the “Games” panel in Ant Manor. Starball was the first interactive game to use the R3 engine, and there was even an AR version, which was pioneering.
The Bronze Age
The second stage is the “Bronze Age” (2018-2020). Ant graphics engine was transferred from the experience technology department to RichLab team with richer business scenarios, upgraded from R3 to Oasis, and the new team began to rethink the significance of graphics engine for Ant interactive business and front-end engineers. In the context of mobile payment and financial digitization, a large number of rich interaction scenarios of mobile terminal services have emerged, but the stability requirements are very demanding. In order to solve business demands faster and better, we started to embrace the front-end ecosystem on the one hand:
Refactoring the engine in Typescript makes the engine code more robust and developers get a better code prompting experience.
Integrate ant front-end development framework, so that the engine can run naturally in frameworks such as React, and have the ability to deposit assets;
Cooperated with clients and small program container students to adapt alipay small program, so that the engine can run in more environments.
On the other hand, we are focusing on 3D development and efficiency. Through the Oasis Editor cloud scene Editor developed by ourselves, we have realized the core capabilities of asset management, scene Editor and script writing. At the same time, we are also concerned about the connection between upstream and downstream of workflow, such as the import of art assets. We suggest using FBX files as input, and then processing them into files suitable for runtime loading through the asset conversion and compression capabilities of the cloud. For example, we provide the ability to export different products, such as React/Rax/ applets, to achieve multiple deployments in one development place.
The silver age
The third age is the “Silver Age”. . The second hero in the history of The Ant graphics engine appears, and the addition of dust is like the Prometheus myth bringing fire to the rebirth of the Oasis engine. After four iterations over eight months, the engine has undergone qualitative changes in functionality, performance, and ease of use:
- In terms of functions, the engine’s basic system capabilities such as entity/component system, script system, resource system, material /Shader system have reached the advanced level in the industry.
- In terms of ease of use, the core system of the engine is redesigned and thought over. In terms of API details, the previous mode of sending parameters by objects is completely abandoned, which is controlled by set/ GET attributes. The features of Typescript language are fully utilized, allowing developers to fully enjoy the refreshing feeling of “guessing API”.
- In terms of performance, the overall performance of the engine has increased to four times that of the Bronze Age, including the single performance of the BufferGeometry system and the Material /Shader system, which are more than ten times that of the previous version, far ahead of the well-known foreign Web 3D engine.
In addition to the continuous upgrading of technology, Oasis team also attaches great importance to the implementation of business. We have served the projects of many business divisions of Alibaba and Ant Group, which has won a good reputation among all business parties and verified the compatibility and stability of the engine in each client.
future
The Silver Age was also an era of open source. In fact, the R&D iteration of Oasis engine entered internal open source as early as the Bronze Age, iterating through milestone and issue management functions in accordance with the working mode of open source. Although the engine has been able to meet the business needs in terms of basic functions, we hope to put the engine on a larger stage in the future and further enhance its capabilities through open source. The physics engine, for example, is currently being integrated into the engine via WebAssembly. In terms of the completeness of the engine, we will first complement the capabilities of 2D graphics, while enabling the engine to render the types of sprites needed for more interactions, such as Spine and Lottie. The further goal is to make the engine cross-platform. Although currently only WebGL 1.0 and 2.0 are supported, it can be seen that the API of the engine, such as WebCanvas, has been designed as the interface of the cross-platform engine. In the future, Metal/Vulkan/WebGPU and other new graphics language interfaces will be accessed according to the priority of requirements.
Frankly speaking, Oasis is still in the development stage. Open source is just a new starting point for Oasis today, and there is still a long way to go in the future. I hope Oasis engine can make a contribution to the cause of domestic 3D engine in its own way. I also hope Oasis team can stay true to our original aspiration. We will use 3D interaction and expression to make the world a better place and realize the Oasis in our hearts.