Embodiments of the present disclosure relate to the field of image processing technologies, and in particular, to a game screen rendering method and apparatus, a terminal, and a storage medium.
With the continuous improvement in image processing technologies, a game implementation program can display a richer and higher-quality game screen.
A rendering process of the game screen usually includes the following two stages: a rendering stage and a screen post-processing stage. At the rendering stage, a game scene is rendered, and lighting and shading are performed on the rendered game scene, to obtain a lighted and shaded render target. At the screen post-processing stage, a screen effect is added to the lighted and shaded render target, to generate the game screen.
In certain existing technologies, a rendering manner of the game screen is relatively undiversified, and cannot meet individualized requirements in different scenarios.
One aspect of the present disclosure provides a game screen rendering method. The method is performed by a terminal and includes obtaining scene data of a game screen, the scene data being used for constructing a game scene and an element included in the game scene, selecting a target rendering mode from n pre-configured rendering modes, n being an integer greater than 1, rendering the scene data using the target rendering mode to generate the game screen, and displaying the game screen.
Another aspect of the present disclosure provides a game rendering apparatus. The apparatus includes a memory a memory storing computer program instructions, and a processor coupled to the memory and configured to executing the computer program instructions and perform obtaining scene data of a game screen, the scene data being used for constructing a game scene and an element included in the game scene, selecting a target rendering mode from n pre-configured rendering modes, n being an integer greater than 1, rendering the scene data using the target rendering mode to generate the game screen, and displaying the game screen.
Yet another aspect of the present disclosure provides a non-transitory computer-readable storage medium. The non-transitory computer-readable storage medium stores computer program instructions executable by at least one processor to perform obtaining scene data of a game screen, the scene data being used for constructing a game scene and an element included in the game scene, selecting a target rendering mode from n pre-configured rendering modes, n being an integer greater than 1, rendering the scene data using the target rendering mode to generate the game screen, and displaying the game screen.
Other aspects of the present disclosure can be understood by those skilled in the art in light of the description, the claims, and the drawings of the present disclosure.
To more clearly describe technical solutions of certain embodiments of the present disclosure, accompanying drawings are described below. The accompanying drawings are illustrative of embodiments of the present disclosure, and a person of ordinary skill in the art may still derive other drawings from these accompanying drawings without having to exert creative efforts. When the following descriptions are made with reference to the accompanying drawings, unless otherwise indicated, same numbers in different accompanying drawings represent same or similar elements. The accompanying drawings are not necessarily drawn to scale.
To make objectives, technical solutions, and advantages of the present disclosure clearer and more comprehensible, certain embodiments of the present disclosure are further elaborated in detail with reference to the accompanying drawings. The described embodiments are not to be construed as a limitation to embodiments of the present disclosure. All other embodiments obtained by a person of ordinary skill in the art without creative efforts shall fall within the protection scope of embodiments of the present disclosure.
Before the technical solutions of the present disclosure are described, a related rendering process is described first. An entire rendering process may include the following two stages: a rendering stage and a screen post-processing stage.
At the rendering stage, a game scene is rendered, and lighting and shading are performed on the rendered game scene, to obtain a lighted and shaded render target. The game scene refers to an environment where people and objects in a game are located. The game scene is usually a 3D virtual scene constructed by a game developer or designer, rather than a real-world scene. Elements included in the game scene are the people and the objects in the game scene, such as game characters, ground, sky, water, mountains, flowers, grass, trees, stones, birds, beasts, insects, fishes, vehicles, and houses. A rendering process of the game scene is a process of converting a 3D game scene into a 2D image.
At the screen post-processing stage, a screen effect is added to the lighted and shaded render target, to generate the game screen. In certain embodiments, the screen effect includes, but is not limited to at least one of the following: screen-space ambient occlusion (SSAO), depth of field, shadow, rain (such as a raindrop effect and a rainwater effect), fog (such as a height fog effect and a dynamic fog effect), screen space reflection, water (such as a sea water effect, a lake water effect, and an underwater effect), tone mapping, Bloom (full-screen glow), and the like.
At the rendering stage, operations are performed using a rendering pipeline, to generate the render target. The render target is a 2D image. The 2D image may be referred to as a screen rendering image. The rendering pipeline is also referred to as a rendering assembly line, referring to an overall process of converting data from a 3D scene into a 2D image. As shown in
Main tasks of the implementation stage 1 are to identify a potentially visible grid instance, and present the grid instance and a material thereof to graphics hardware for rendering. At a tail end of the implementation stage 1, geometry data is generated, including vertex coordinates, normal vectors, texture coordinates, textures, and the like. Algorithms such as collision detection, scene graph establishment, spatial octree update, and view frustum clipping may all be performed at the implementation stage 1.
Main tasks of the geometry stage 2 are vertex coordinate transformation, lighting, clipping, projection, and screen mapping. At the stage, calculation is performed based on a GPU. Vertex coordinates, colors, and texture coordinates after transformation and projection are obtained at a tail end of the geometry stage 2. Main jobs of the geometry stage 2 may be summarized as “transformation of three-dimensional vertex coordinates” and “lighting”. “Transformation of three-dimensional vertex coordinates” is to transform vertex information from one coordinate system to another coordinate system through various transformation matrices, so that 3D vertex data can finally be displayed on a 2D screen. “Lighting” refers to calculating lighting attributes of vertexes through a position of a camera and a position of a light source. After the processing at the geometry stage 2 is performed, a stack of triangular patches are sent to the rasterizer stage 3, so that primitive assembly may need to be performed on the vertexes at the geometry stage 2. The primitive assembly refers to restoring a grid structure of a model according to an original connection relationship among the vertexes.
A purpose of the rasterizer stage 3 is to calculate a color value of each pixel, to correctly draw an entire image. At the rasterizer stage 3, the triangle patches sent from the geometry stage 2 are converted into fragments, and the fragments are colored. At the rasterizer stage 3, processing such as a scissor test, an alpha test, a stencil test, a depth test, alpha blending, and dithering may be performed on the fragments, to finally obtain a screen rendering image.
Step 201. Obtain scene data of a game screen.
The terminal may obtain scene data of a game screen, the scene data being used for constructing a game scene and an element included in the game scene. For descriptions of the game scene and the element, reference may be made to the description above, and details are not described herein. In certain embodiments, the game scene is a 3D virtual scene, and the element in the game scene also exists in a 3D form.
Step 202. Select a target rendering mode used for rendering the game screen from n pre-configured rendering modes, n being an integer greater than 1.
In this embodiment of the present disclosure, a plurality of different rendering modes are pre-configured. Processing procedures corresponding to the different rendering modes are different. The terminal may select a target rendering mode used for rendering the game screen from n pre-configured rendering modes.
In a possible implementation, the terminal obtains mode selection information, the mode selection information being used for indicating a rendering mode selected by a user; and selects a rendering mode indicated by the mode selection information as the target rendering mode used for rendering the game screen from the n pre-configured rendering modes. The user may be a game developer or designer, or may be a common user (that is, a game player). For example, three rendering modes are pre-configured, and are assumed as a first rendering mode, a second rendering mode, and a third rendering mode. If the rendering mode indicated by the mode selection information is the first rendering mode, the terminal determines the first rendering mode as the target rendering mode used for rendering the game screen.
In another possible implementation, the terminal obtains a device performance parameter of the terminal, the device performance parameter being used for indicating computing and processing capabilities of the terminal; and selects a rendering mode matching the device performance parameter as the target rendering mode used for rendering the game screen from the n pre-configured rendering modes. In certain embodiments, the device performance parameter includes a static performance parameter and/or a dynamic performance parameter. The static performance parameter includes a hardware configuration of the terminal, that is, an inherent configuration of terminal hardware, such as a quantity of central processing unit (CPU) cores, CPU frequency, a quantity of graphics processing unit (GPU) cores, and a size of a memory. The dynamic performance parameter includes hardware usage of the terminal, that is, a parameter that dynamically changes with a terminal load, such as a CPU usage rate, a GPU usage rate, a memory occupancy rate, and a quantity of processes. In certain embodiments, a value of a device performance parameter matching each rendering mode is pre-configured. The terminal selects a target rendering mode matching a device performance parameter of the terminal from the n rendering modes according to the configuration.
In certain embodiments, when the device performance parameter includes the dynamic performance parameter, the terminal may further re-obtain the dynamic performance parameter every preset duration, and adjust the target rendering mode according to the re-obtained dynamic performance parameter. The preset duration may be preset by the terminal or the user. For example, the preset duration is 10 minutes, 30 minutes, or 1 hour. Two adjacent preset durations may be the same or different. After re-obtaining the dynamic performance parameter, the terminal may still select a rendering mode matching the re-obtained dynamic performance parameter from the n rendering modes according to the configuration as an adjusted target rendering mode. Afterward, the terminal may render the scene data using the adjusted target rendering mode to generate the game screen. Through the above manner, the rendering mode used may be dynamically adjusted according to an actual load of the terminal. When the load permits, the terminal may select a rendering mode with higher rendering quality, to improve a display effect of the game screen as much as possible. When the load does not permit, the terminal may select a rendering mode with lower rendering quality to reduce load pressure as much as possible.
Step 203. Render the scene data using the target rendering mode, to generate the game screen.
After selecting the target rendering mode from the n pre-configured rendering modes, the terminal renders the scene data using the target rendering mode, to generate the game screen. The rendering process may include the following two stages: a rendering stage and a screen post-processing stage. At the rendering stage, the terminal constructs a 3D game scene and elements in the 3D game scene according to the scene data, and then converts the 3D game scene into a 2D image. The 2D image may be referred to as a screen rendering image. At the screen post-processing stage, the terminal adds a screen effect to the screen rendering image, to generate the game screen.
For different rendering modes, processing performed at the rendering stage may be different, and processing performed at the screen post-processing stage may also be different. For a plurality of pre-configured rendering modes and a specific processing flow corresponding to each rendering mode, description is made in the following embodiments.
Step 204. Display the game screen.
After performing rendering to generate the game screen, the terminal displays the game screen on a screen. In certain embodiments, the game screen usually includes a plurality of frames. The terminal performs rendering in turn according to scene data corresponding to each frame of the game screen to generate each frame of the game screen, and displays the game screen frame by frame.
To sum up, in the technical solution provided by this embodiment of the present disclosure, a plurality of different rendering modes are pre-configured, so that when performing rendering to generate the game screen, the terminal may select a target rendering mode to render the scene data, to generate the game screen. Rendering manners of the game screen are enriched, and individualized requirements in different scenarios are better met.
In addition, the terminal may select a suitable rendering mode from the plurality of pre-configured rendering modes according to the mode selection information or the device performance parameter of the terminal, to ensure that the finally selected rendering mode can meet customization requirements of the user or meet performance requirements of the device.
In an optional embodiment provided based on the embodiment of
The first rendering mode refers to a rendering mode of performing lighting and adding a screen effect at a screen post-processing stage using a deferred rendering policy. The second rendering mode refers to a rendering mode of performing lighting at a rendering stage and adding a screen effect at the screen post-processing stage using a forward rendering policy.
A main difference between the deferred rendering policy and the forward rendering policy lies in that execution timings of the lighting are different. In the deferred rendering policy, the lighting is performed at the screen post-processing stage, while in the forward rendering policy, the lighting is performed at the rendering stage. If the terminal performs the lighting at the rendering stage, the terminal may need to calculate a lighting attribute of each vertex in the game scene. When a quantity of elements included in the game scene is relatively large, the terminal may need to calculate lighting attributes of a large quantity of vertexes. A calculation amount is large, resulting in low efficiency of the lighting. If the terminal performs the lighting at the screen post-processing stage, the terminal may only need to calculate a lighting attribute of each screen pixel, and the calculation amount of the lighting is irrelevant to the quantity of elements included in the game scene, thereby helping to reduce the calculation amount and improve the efficiency of the lighting when the quantity of elements included in the game scene is relatively large.
In addition, the third rendering mode refers to a rendering mode provided for a low-end model. The low-end model refers to a terminal device with a lower device performance parameter, such as a device performance parameter less than a preset threshold. The preset threshold may be set for different parameters. For example, a terminal with a CPU core quantity less than 2 is determined as a low-end model, and a terminal with a CPU frequency less than 1.8 GHz is determined as a low-end model. For example, in the first rendering mode and the second rendering mode, lighting and shading may be performed in a physically based rendering (PBR) manner, so that a result of the lighting and shading is more realistic. In the third rendering mode, the lighting and shading may be performed in a related rendering manner, for example, the lighting is performed using a related diffuse reflection algorithm. Compared with the performing the lighting and shading in the PBR manner, the lighting and shading is performed in the related rendering manner, to reduce requirements for device computing and processing performance and reduce the calculation amount by sacrificing a certain rendering effect. In another example, the first rendering mode and the second rendering mode may support more types of screen effects, while the third rendering mode only supports a small quantity of screen effects, to reduce the requirements for device computing and processing performance. Therefore, the third rendering mode may be regarded as a rendering mode provided for a low-end model, and has relatively low requirements for device computing and processing performance, and relatively high rendering efficiency, but relatively poor rendering effects.
When the target rendering mode is the first rendering mode, as shown in
Step 203a. Render the scene data to obtain a first render target at the rendering stage.
In the first rendering mode, the rendering stage may include constructing a 3D game scene and elements, performing coordinate transformation, and calculating a color value of each pixel, but does not include performing the lighting.
In certain embodiments, the first render target includes: a color texture of a main camera, depth and normal textures of the main camera, and a depth texture of a shadow camera. The step may include: rendering the scene data using the main camera, to obtain the color texture of the main camera, and the depth and normal textures of the main camera; and rendering the scene data using the shadow camera, to obtain the depth texture of the shadow camera. In certain embodiments, the terminal may use the multiple render targets (MRT) technology when rendering the scene data using the main camera. For example, a first rendering channel outputs the color texture of the main camera, and a second rendering channel outputs the depth and normal textures of the main camera. The color texture of the main camera, the depth and normal textures of the main camera, and the depth texture of the shadow camera may be stored in different buffers separately, to be extracted and used from the corresponding buffers in the screen post-processing stage.
Step 203b: Perform lighting on the first render target at the screen post-processing stage, to generate a lighted first render target; and add a screen effect to the lighted first render target, to generate the game screen.
In the first rendering mode, the terminal may perform the lighting on the first render target in the PBR manner, to obtain a more realistic lighting effect. In certain embodiments, the screen effect includes, but is not limited to at least one of the following: SSAO, depth of field, shadow, rain (such as a raindrop effect and a rainwater effect), fog (such as a height fog effect and a dynamic fog effect), screen space reflection, water (such as a sea water effect, a lake water effect, and an underwater effect), tone mapping, Bloom (full-screen glow), and the like.
In certain embodiments, a rendering pipeline pre-configured in the first rendering mode includes x types of screen effects, x being an integer greater than 1. The terminal adds a screen effect to the lighted first render target to generate the game screen according to a switch configuration corresponding to each of the x types of screen effects. When or in response to determining a switch configuration corresponding to an ith type of screen effect in the x types of screen effects is on, the ith type of screen effect is added; and when or in response to determining the switch configuration corresponding to the ith type of screen effect is off, the ith type of screen effect is not added, i being a positive integer less than or equal to x. In this embodiment of the present disclosure, the addition/non-addition of the screen effect is implemented in a switch configuration manner, to flexibly control and dynamically adjust the addition of the screen effect.
In an example, it is assumed that the pre-configured rendering pipeline includes the following three screen effects: a screen effect 1, a screen effect 2, and a screen effect 3. Meanwhile, it is assumed that switch configurations corresponding to the three screen effects are sequentially: on, off, and on. It is assumed that the lighted first render target is denoted as an “image A”. The terminal first adds the screen effect 1 to the “image A” according to the switch configuration corresponding to the screen effect 1, to obtain the processed “image A”. Then, the terminal determines not to add the screen effect 2 according to the switch configuration corresponding to the screen effect 2. Next, the terminal further adds the screen effect 3 to the processed “image A” according to the switch configuration corresponding to the screen effect 3, to obtain the further processed “image A”, and outputs and displays the further processed “image A” as a final game screen.
In certain embodiments, the terminal may further perform the following steps before performing the lighting on the first render target to generate the lighted first render target: drawing a mask using a stencil, and then superimposing the mask on an upper layer of the first render target. The mask includes at least one UI control. The UI control may be an operation control such as a button, a slider, or a joystick, for a player to control a game character during the game. The lighting and the adding a screen effect are performed on an area, in the first render target, that is not blocked by the UI control. In other words, the lighting and/or the adding a screen effect may not be performed on an area, in the first render target, that is blocked by the UI control, to reduce calculation and processing amounts.
In certain embodiments, the lighting and/or the adding a screen effect is performed in at least one of the following manners: an alternate-frame rendering manner, an alternate-pixel rendering manner, and a reduced-resolution rendering manner. Using the above manner, the calculation and processing amounts required for rendering can be reduced as much as possible while a rendering effect is ensured maximally, thereby improving the rendering efficiency.
In certain embodiments, performing the lighting and/or the adding a screen effect in a DrawMesh manner can further improve processing efficiency. For example,
When the target rendering mode is the second rendering mode, as shown in
Step 203c. Render and perform lighting and shading on the scene data to obtain a lighted and shaded second render target at the rendering stage in a PBR manner.
Step 203d. Add b pre-configured screen effects to the second render target at the screen post-processing stage, to generate the game screen, b being a positive integer.
Different from the first rendering mode, in the first rendering mode, the deferred rendering policy is used to perform the lighting at the screen post-processing stage, while in the second rendering mode, the forward rendering policy is used to perform the lighting at the rendering stage. In addition, a quantity and types of screen effects included in the rendering pipeline pre-configured in the second rendering mode may be the same or different from a quantity and types of screen effects included in the rendering pipeline pre-configured in the first rendering mode.
When the target rendering mode is the third rendering mode, as shown in
Step 203e. Render and perform lighting and shading on the scene data to obtain a lighted and shaded third render target at the rendering stage in a related rendering manner.
Step 203f. Add c pre-configured screen effects to the third render target at the screen post-processing stage, to generate the game screen, c being a positive integer.
In certain embodiments, in the third rendering mode, the lighting is performed using a related diffuse reflection algorithm, rather than performing the lighting and shading in the PBR manner, to reduce requirements for device computing and processing performance and reduce the calculation amount by sacrificing a certain rendering effect. In addition, a quantity and types of screen effects included in the rendering pipeline pre-configured in the third rendering mode may be less than those in the first rendering mode and the second rendering mode. For example, the third rendering mode merely supports a small quantity of basic screen effects, to reduce the requirements for device computing and processing performance.
In certain embodiments, for the second rendering mode and the third rendering mode, the mask may also be drawn using a stencil. Then, the mask is superimposed on an upper layer of the second render target or the third render target. A screen effect is added to an area, in the second render target or the third render target, that is not blocked by the UI control. In other words, the adding a screen effect may not be performed on an area, in the second render target or the third render target, that is blocked by the UI control, to reduce calculation and processing amounts. In addition, for the second rendering mode and the third rendering mode, the terminal may also perform the lighting and/or the adding a screen effect using an alternate-frame rendering manner, an alternate-pixel rendering manner, a reduced-resolution rendering manner, and the like, to reduce the calculation and processing amounts required for the rendering as much as possible, and improve the rendering efficiency.
In addition, in the rendering stage, the terminal may need to transform vertexes from a view space to a clip space, that is, transform vertex coordinates from a 3D scene space to a 2D screen space through coordinate transformation. The transformation process may be implemented by a using clip matrix. The clip matrix may be also referred to as a projection matrix. A goal of the clip space is to be able to clip a primitive conveniently. A primitive located inside the space is retained, a primitive located outside the space is removed, and a primitive intersecting with a boundary of the space is clipped. The clip space is determined by a view frustum of a camera. The view frustum refers to an area in the space. The area determines a space that the camera can see. The view frustum is surrounded by six planes. The planes are also referred to as clip planes. There are two types of view frustums corresponding to two types of projections: an orthographic projection and a perspective projection. A view frustum corresponding to the orthographic projection is a quadrangular prism, and a view frustum corresponding to the perspective projection is a quadrangular frustum. Among 6 clip planes of the view frustum, a clip plane closest to the camera is referred to as a near clip plane, and a clip plane farthest from the camera is referred to as a far clip plane. The near clip plane and the far clip plane determine a depth range that the camera can see.
This embodiment of the present disclosure provides a coordinate transformation manner, to draw a patch in the screen space, so that the patch just covers the entire screen, that is, a size of the patch is the same as a size of the screen. Then, in a vertex shader, the vertex coordinates are converted from three-dimensional coordinates to two-dimensional coordinates according to a principle of geometric transformation. There are two methods to draw the above patch, one method is to draw at the near clip plane of the camera, and the other method is to draw at the far clip plane of the camera. When calculating position coordinates, in a scene space, corresponding to a screen space pixel, the terminal may use a principle of similar triangles to first calculate position coordinates, in a far clip plane, corresponding to the screen space pixel, and then calculate the position coordinates, in the scene space, corresponding to the screen space pixel according to the position coordinates in the far clip plane and a scene depth. As shown in
To sum up, in the technical solutions provided in the embodiments of the present disclosure, the above three different rendering modes are provided. In the first rendering mode, based on the deferred rendering policy, the lighting is performed at the screen post-processing stage using the customized rendering pipeline different from the related rendering pipeline, thereby reducing the calculation amount for the lighting and improving the efficiency of the lighting. In the second rendering mode, based on the forward rendering policy, the entire rendering process is implemented using the related rendering pipeline, thereby being compatible with the related rendering pipeline. The third rendering mode is suitable for a low-end model to use, and has relatively low requirements for device computing and processing performance, and relatively high rendering efficiency. In practical implementations, a suitable rendering mode may be selected from the three different rendering modes according to actual requirements, to achieve an optimal rendering effect.
The following describes apparatus embodiments of the present disclosure, which can be used to execute the method embodiments of the present disclosure. For details not disclosed in the apparatus embodiments of the present disclosure, refer to the method embodiments of the present disclosure.
The data obtaining module 1410 is configured to obtain scene data of a game screen, the scene data being used for constructing a game scene and an element included in the game scene.
The mode selection module 1420 is configured to select a target rendering mode used for rendering the game screen from n pre-configured rendering modes, n being an integer greater than 1.
The screen rendering module 1430 is configured to render the scene data using the target rendering mode, to generate the game screen.
The screen display module 1440 is configured to display the game screen.
To sum up, in the technical solution provided by this embodiment of the present disclosure, a plurality of different rendering modes are pre-configured, so that when performing rendering to generate the game screen, the terminal may select a target rendering mode to render the scene data, to generate the game screen. Rendering manners of the game screen are enriched, and individualized requirements in different scenarios are better met.
In an optional embodiment provided based on the embodiment in
In another optional embodiment provided based on the embodiment in
In certain embodiments, when the device performance parameter includes the dynamic performance parameter, the mode selection module 1420 is further configured to: re-obtain the dynamic performance parameter every preset duration; and adjust the target rendering mode according to the re-obtained dynamic performance parameter.
In another optional embodiment provided based on the embodiment in
In certain embodiments, as shown in
The first rendering unit 1431 is configured to render the scene data to obtain a first render target at the rendering stage when or in response to determining the target rendering mode is the first rendering mode.
The first processing unit 1432 is configured to perform lighting on the first render target at the screen post-processing stage, to generate a lighted first render target; and add a screen effect to the lighted first render target, to generate the game screen.
In certain embodiments, the first render target includes: a color texture of a main camera, depth and normal textures of the main camera, and a depth texture of a shadow camera. The first rendering unit 1431 is configured to render the scene data using the main camera, to obtain the color texture of the main camera, and the depth and normal textures of the main camera; and render the scene data using the shadow camera, to obtain the depth texture of the shadow camera.
In certain embodiments, a rendering pipeline pre-configured in the first rendering mode includes x types of screen effects, x being an integer greater than 1. The first processing unit 1432 is configured to add a screen effect to the lighted first render target to generate the game screen according to a switch configuration corresponding to each of the x types of screen effects. When or in response to determining a switch configuration corresponding to an ith type of screen effect in the x types of screen effects is on, the ith type of screen effect is added; and when or in response to determining the switch configuration corresponding to the ith type of screen effect is off, the ith type of screen effect is not added, i being a positive integer less than or equal to x.
In certain embodiments, the screen rendering module 1430 is further configured to: draw a mask using a stencil, the mask including at least one UI control; and superimpose the mask on an upper layer of the first render target; and the lighting and the adding a screen effect are performed on an area, in the first render target, that is not blocked by the UI control.
In certain embodiments, the lighting and/or the adding a screen effect is performed in at least one of the following manners: an alternate-frame rendering manner, an alternate-pixel rendering manner, and a reduced-resolution rendering manner.
In certain embodiments, as shown in
The second rendering unit 1433 is configured to render and perform lighting and shading on the scene data to obtain a lighted and shaded second render target at the rendering stage in a physically based rendering PBR manner when or in response to determining the target rendering mode is the second rendering mode.
The second processing unit 1434 is configured to add b pre-configured screen effects to the second render target at the screen post-processing stage, to generate the game screen, b being a positive integer.
In certain embodiments, as shown in
The third rendering unit 1435 is configured to render and perform lighting and shading on the scene data to obtain a lighted and shaded third render target at the rendering stage in a related rendering manner when or in response to determining the target rendering mode is the third rendering mode.
The third processing unit 1436 is configured to add c pre-configured screen effects to the third render target at the screen post-processing stage, to generate the game screen, c being a positive integer.
When the apparatus provided in the foregoing embodiments implements functions of the apparatus, it is illustrated with an example of division of each functional module. In the practical implementations, the function distribution may be finished by different functional modules according to the requirements, that is, the internal structure of the device is divided into different functional modules, to implement all or some of the functions described above. In addition, the apparatus and method embodiments provided in the foregoing embodiments belong to one conception. For the specific implementation process, refer to the method embodiments, and details are not described herein again.
Generally, the terminal 1600 includes a processor 1601 and a memory 1602.
The processor 1601 may include one or more processing cores, and may be, for example, a 4-core processor or an 8-core processor. The processor 1601 may be implemented using at least one hardware form of a digital signal processor (DSP), a field programmable gate array (FPGA), and a programmable logic array (PLA). The processor 1601 may alternatively include a main processor and a coprocessor. The main processor is a processor that is configured to process data in an awake state, also referred to as a central processing unit (CPU), and the coprocessor is a low-power processor that is configured to process data in an idle state. In some embodiments, the processor 1601 may be integrated with a graphics processing unit (GPU). The GPU is configured to be responsible for rendering and drawing content that a display may need to display. In some embodiments, the processor 1601 may further include an artificial intelligence (AI) processor. The AI processor is configured to process a calculation operation related to machine learning.
The memory 1602 may include one or more computer-readable storage media that may be non-transitory. The memory 1602 may further include a high-speed random access memory and a non-volatile memory, for example, one or more disk storage devices or flash memory devices. In some embodiments, the non-transient computer-readable storage medium in the memory 1602 is configured to store at least one computer-readable instruction, and the at least one computer-readable instruction is configured to be executed by the processor 1601 to implement the game screen rendering method provided in the method embodiment of the present disclosure.
In some embodiments, the terminal 1600 may alternatively include: a peripheral interface 1603 and at least one peripheral. The processor 1601, the memory 1602, and the peripheral interface 1603 may be connected through a bus or a signal cable. Each peripheral may be connected to the peripheral interface 1603 through a bus, a signal cable, or a circuit board. Specifically, the peripheral device includes at least one of a radio frequency circuit 1604, a touch display screen 1605, a camera 1606, an audio circuit 1607, a positioning component 1608, and a power supply 1609.
The peripheral device interface 1603 may be configured to connect the at least one peripheral device related to input/output (I/O) to the processor 1601 and the memory 1602. In some embodiments, the processor 1601, the memory 1602, and the peripheral device interface 1603 are integrated on a same chip or circuit board. In some other embodiments, any one or two of the processor 1601, the memory 1602, and the peripheral device interface 1603 may be implemented on a separate chip or the circuit board. This is not limited in this embodiment.
The radio frequency circuit 1604 is configured to receive and transmit a radio frequency (RF) signal, also referred to as an electromagnetic signal. The RF circuit 1604 communicates with a communication network and another communication device using the electromagnetic signal. The RF circuit 1604 converts an electric signal into an electromagnetic signal for transmission, or converts a received electromagnetic signal into an electric signal. In certain embodiments, the RF circuit 1604 includes: an antenna system, an RF transceiver, one or more amplifiers, a tuner, an oscillator, a digital signal processor, a codec chip set, a subscriber identity module card, and the like. The RF circuit 1604 may communicate with other devices through at least one wireless communication protocol. The wireless communication protocol includes, but is not limited to: a metropolitan area network, generations of mobile communication networks (2G, 3G, 4G, and 5G), a wireless local area network and/or a wireless fidelity (Wi-Fi) network. In some embodiments, the RF circuit 1604 may further include a circuit related to a near field communication (NFC) related circuit. This is not limited in the present disclosure.
The display screen 1605 is configured to display a user interface (UI). The UI may include a graph, text, an icon, a video, and any combination thereof. When the display screen 1605 is a touch display screen, the display screen 1605 also has the capability to collect a touch signal on or above a surface of the display screen 1605. The touch signal may be used as a control signal to be inputted into the processor 1601 for processing. In this case, the display screen 1605 may be further configured to provide a virtual button and/or a virtual keyboard that are/is also referred to as a soft button and/or a soft keyboard. In some embodiments, there may be one display screen 1605, disposed on a front panel of the terminal 1600. In some other embodiments, there may be two display screens 1605, respectively disposed on different surfaces of the terminal 1600 or designed in a foldable shape. In still some other embodiments, the display screen 1605 may be a flexible display screen, disposed on a curved surface or a folded surface of the terminal 1600. The display screen 1605 may also be set to a non-rectangular irregular pattern, that is, a special-shaped screen. The display screen 1605 may be made of materials such as a liquid crystal display (LCD), an organic light-emitting diode (OLED), and the like.
The camera assembly 1606 is configured to collect images or videos. In certain embodiments, the camera component 1606 includes a front-facing camera and a rear-facing camera. Generally, the front-facing camera is disposed on the front panel of a computing device such as the terminal, and the rear-facing camera is disposed on a back face of the computing device. In some embodiments, there are at least two rear cameras, which are respectively any of a main camera, a depth-of-field camera, a wide-angle camera, and a telephoto camera, to achieve background blur through fusion of the main camera and the depth-of-field camera, panoramic photographing and virtual reality (VR) photographing through fusion of the main camera and the wide-angle camera, or other fusion photographing functions. In some embodiments, the camera component 1606 may further include a flash. The flashlight may be a single-color-temperature flashlight or a dual-color-temperature flashlight. The dual-color-temperature flashlight is a combination of a warm flashlight and a cold flashlight, which may be used for light compensation at different color temperatures.
The audio circuit 1607 may include a microphone and a speaker. The microphone is configured to collect sound waves of a user and an environment, and convert the sound waves into electrical signals and input the electrical signals into the processor 1601 for processing, or input the electrical signals into the RF circuit 1604 to implement speech communication. For the purpose of stereo collection or noise reduction, there may be a plurality of microphones, disposed at different portions of the terminal 1600 respectively. The microphone may be further an array microphone or an omni-directional collection type microphone. The speaker is configured to convert electrical signals from the processor 1601 or the RF circuit 1604 into sound waves. The speaker may be a thin-film speaker or a piezoelectric ceramic speaker. When the speaker is the piezoelectric ceramic speaker, electric signals not only may be converted into sound waves that can be heard by human, but also may be converted into sound waves that cannot be heard by human for ranging and the like. In some embodiments, the audio circuit 1607 may further include an earphone jack.
The positioning component 1608 is configured to determine a current geographic location of the terminal 1600, to implement a navigation or a location based service (LBS). The positioning component 1608 may be a positioning component based on the global positioning system (GPS) of the United States, the BeiDou Navigation Satellite System (BDS) of China, the GLONASS System of Russia, or the GALILEO System of the European Union.
The power supply 1609 is configured to supply power to components in the terminal 1600. The power supply 1609 may be an alternating current, a direct current, a primary battery, or a rechargeable battery. When or in response to determining the power supply 1609 includes the rechargeable battery, the rechargeable battery may be a wired charging battery or a wireless charging battery. The rechargeable battery may be further configured to support a fast charging technology.
In some embodiments, the terminal 1600 may further include one or more sensors 1610. The one or more sensors 1610 include, but are not limited to, an acceleration sensor 1611, a gyroscope sensor 1612, a pressure sensor 1613, a fingerprint sensor 1614, an optical sensor 1615, and a proximity sensor 1616.
The acceleration sensor 1611 may detect the magnitude of acceleration on three coordinate axes of a coordinate system established with the terminal 1600. For example, the acceleration sensor 1611 may be configured to detect components of gravity acceleration on the three coordinate axes. The processor 1601 may control, according to a gravity acceleration signal collected by the acceleration sensor 1611, the touch display screen 1605 to display the user interface in a frame view or a portrait view. The acceleration sensor 1611 may be further configured to collect data of a game or a user movement.
The gyroscope sensor 1612 may detect a body direction and a rotation angle of the terminal 1600. The gyroscope sensor 1612 may cooperate with the acceleration sensor 1611 to collect a 3D action by the user on the terminal 1600. The processor 1601 may implement the following functions according to the data collected by the gyroscope sensor 1612: motion sensing (such as changing the UI according to a tilt operation of the user), image stabilization at shooting, game control, and inertial navigation.
The pressure sensor 1613 may be disposed at a side frame of the terminal 1600 and/or a lower layer of the touch display screen 1605. When the pressure sensor 1613 is disposed at the side frame of the terminal 1600, a holding signal of the user on the terminal 1600 may be detected. The processor 1601 performs left and right hand recognition or a quick operation according to the holding signal collected by the pressure sensor 1613. When the pressure sensor 1613 is disposed at the lower layer of the touch display screen 1605, the processor 1601 controls, according to a pressure operation of the user on the touch display screen 1605, an operable control on the UI. The operable control includes at least one of a button control, a scroll-bar control, an icon control, and a menu control.
The fingerprint sensor 1614 is configured to collect a fingerprint of a user, and the processor 1601 recognizes an identity of the user according to the fingerprint collected by the fingerprint sensor 1614, or the fingerprint sensor 1614 recognizes the identity of the user based on the collected fingerprint. When or in response to determining the identity of the user is recognizes as credible, the processor 1601 authorizes the user to perform a related sensitive operation. The sensitive operation includes screen unlocking, viewing of encrypted information, software downloading, payment, setting changing, and the like. The fingerprint sensor 1614 may be disposed on a front surface, a back surface, or a side surface of the terminal 1600. When a physical button or a vendor logo is disposed on the terminal 1600, the fingerprint 1614 may be integrated with the physical button or the vendor logo.
The optical sensor 1615 is configured to collect ambient light intensity. In an embodiment, the processor 1601 may control display brightness of the touch display 1605 according to the ambient light intensity collected by the optical sensor 1615. Specifically, when the ambient light intensity is relatively high, the display luminance of the touch display screen 1605 is increased. When the ambient light intensity is relatively low, the display luminance of the touch display screen 1605 is reduced. In another embodiment, the processor 1601 may further dynamically adjust a photographing parameter of the camera assembly 1606 according to the ambient light intensity collected by the optical sensor 1615.
The proximity sensor 1616, also referred to as a distance sensor, is usually disposed on a front panel of the terminal 1600. The proximity sensor 1616 is configured to collect a distance between the user and the front surface of the terminal 1600. In an embodiment, when the proximity sensor 1616 detects that the distance between the user and the front surface of the terminal 1600 gradually becomes smaller, the touch display screen 1605 is controlled by the processor 1601 to switch from a screen-on state to a screen-off state. When the proximity sensor 1616 detects that the distance between the user and the front surface of the terminal 1600 gradually becomes larger, the touch display screen 1605 is controlled by the processor 1601 to switch from the screen-off state to the screen-on state.
Each module/unit in various disclosed embodiments can be integrated in a processing unit, or each module/unit can exist separately and physically, or two or more modules/units can be integrated in one unit. The modules/units as disclosed herein can be implemented in the form of hardware (e.g., processing circuitry and/or memory) or in the form of software functional unit(s) (e.g., developed using one or more computer programming languages), or a combination of hardware and software. Each module/unit or submodule/subunit can be implemented using one or more processors (or processors and memory). Likewise, a processor (or processor and memory) can be used to implement one or more modules/units or submodules/subunits. Moreover, each module/unit may be developed using a computer programming language, or be part of an overall module/unit that is developed using a computer programming language to encompass the functionalities of each module/unit.
A person skilled in the art may understand that a structure shown in
In an exemplary embodiment, a terminal is further provided, including a processor and a memory, the memory storing at least one computer-readable instruction, at least one program, a code set, or a computer-readable instruction set. The at least one computer-readable instruction, the at least one program, the code set, or the computer-readable instruction set is configured to be executed by one or more processors to implement the game screen rendering method provided in the foregoing embodiment.
In an exemplary embodiment, a computer-readable storage medium is further provided, the storage medium storing at least one computer-readable instruction, at least one program, a code set, or a computer-readable instruction set, and the at least one computer-readable instruction, the at least one program, the code set, or the computer-readable instruction set, when executed by a processor of a computing device, implementing the game screen rendering method provided in the foregoing embodiment. In certain embodiments, the computer-readable storage medium may be a ROM, a RAM, a CD-ROM, a magnetic tape, a floppy disk, an optical data storage device, or the like.
In an exemplary embodiment, a computer program product is further provided, when executed, the computer program product being configured to perform the game screen rendering method provided in the foregoing embodiment.
It is to be understood that “plurality of” mentioned in the specification means two or more. “And/or” describes an association relationship for associated objects and represents that three relationships may exist. For example, A and/or B may represent the following three cases: only A exists, both A and B exist, and only B exists. The character “/” generally indicates an “or” relationship between the associated objects. In addition, the step numbers described in this specification merely exemplarily show a possible execution sequence of the steps. In some other embodiments, the steps may not be performed according to the number sequence. For example, two steps with different numbers may be performed simultaneously, or two steps with different numbers may be performed according to a sequence contrary to the sequence shown in the figure. This is not limited in the embodiments of the present disclosure.
The foregoing descriptions are merely exemplary embodiments of the present disclosure, but are not intended to limit the present disclosure. Any modification, equivalent replacement, or improvement made within the spirit and principle of the present disclosure shall fall within the protection scope of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
201811525614.6 | Dec 2018 | CN | national |
This application is a continuation application of PCT Patent Application No. PCT/CN2019/120922, filed on Nov. 26, 2019, which claims priority to Chinese Patent Application No. 201811525614.6, entitled “GAME SCREEN RENDERING METHOD AND APPARATUS, TERMINAL, AND STORAGE MEDIUM” filed with the China National Intellectual Property Administration on Dec. 13, 2018, all of which are incorporated herein by reference in entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2019/120922 | Nov 2019 | US |
Child | 17220903 | US |