[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2023088041A1 - 虚拟角色的行走动画生成方法、装置、设备及存储介质 - Google Patents

虚拟角色的行走动画生成方法、装置、设备及存储介质 Download PDF

Info

Publication number
WO2023088041A1
WO2023088041A1 PCT/CN2022/127073 CN2022127073W WO2023088041A1 WO 2023088041 A1 WO2023088041 A1 WO 2023088041A1 CN 2022127073 W CN2022127073 W CN 2022127073W WO 2023088041 A1 WO2023088041 A1 WO 2023088041A1
Authority
WO
WIPO (PCT)
Prior art keywords
leg
virtual character
animation
gait
swing
Prior art date
Application number
PCT/CN2022/127073
Other languages
English (en)
French (fr)
Inventor
刘石开
Original Assignee
腾讯科技(深圳)有限公司
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 腾讯科技(深圳)有限公司 filed Critical 腾讯科技(深圳)有限公司
Publication of WO2023088041A1 publication Critical patent/WO2023088041A1/zh
Priority to US18/338,330 priority Critical patent/US20230334744A1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T13/00Animation
    • G06T13/203D [Three Dimensional] animation
    • G06T13/403D [Three Dimensional] animation of characters, e.g. humans, animals or virtual beings
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/40Processing input control signals of video game devices, e.g. signals generated by the player or derived from the environment
    • A63F13/42Processing input control signals of video game devices, e.g. signals generated by the player or derived from the environment by mapping the input signals into game commands, e.g. mapping the displacement of a stylus on a touch screen to the steering angle of a virtual vehicle
    • A63F13/428Processing input control signals of video game devices, e.g. signals generated by the player or derived from the environment by mapping the input signals into game commands, e.g. mapping the displacement of a stylus on a touch screen to the steering angle of a virtual vehicle involving motion or position input signals, e.g. signals representing the rotation of an input controller or a player's arm motions sensed by accelerometers or gyroscopes
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/55Controlling game characters or game objects based on the game progress
    • A63F13/56Computing the motion of game characters with respect to other game characters, game objects or elements of the game scene, e.g. for simulating the behaviour of a group of virtual soldiers or for path finding
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/55Controlling game characters or game objects based on the game progress
    • A63F13/57Simulating properties, behaviour or motion of objects in the game world, e.g. computing tyre load in a car race game
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/60Generating or modifying game content before or while executing the game program, e.g. authoring tools specially adapted for game development or game-integrated level editor
    • A63F13/65Generating or modifying game content before or while executing the game program, e.g. authoring tools specially adapted for game development or game-integrated level editor automatically by game devices or servers from real world data, e.g. measurement in live racing competition

Definitions

  • the present application relates to the field of animation production, in particular to a method, device, equipment and storage medium for generating walking animation of a virtual character.
  • the multi-legged mecha is characterized by a sense of weight and oppression, like an unstoppable mobile fortress that advances steadily.
  • animation mixing technology is used to generate the walking animation of the multi-legged mecha.
  • the animation sequence of the walking posture and the standing posture will be played simultaneously during the transition period, and the playback weight ⁇ will be slowly transferred from the walking posture to the standing posture according to the transition process. So as to achieve the effect of smooth transition.
  • a method, device, device and storage medium for generating a walking animation of a virtual character are provided.
  • a method for generating a walking animation of a virtual character wherein each leg of the virtual character alternately performs a swing phase and a support phase during walking by a computer device, and the method includes:
  • Gait fusion is performed based on the position of the bone points of each leg in the swing stage to generate a walking animation of the virtual character.
  • a walking animation generation device of a virtual character each leg of the virtual character alternately performs a swing phase and a support phase during walking, and the device includes:
  • a prediction module configured to predict the foothold of each leg of the virtual character during the walking process according to the moving speed and moving direction of the virtual character
  • a calculation module configured to calculate the position of the foot of each leg in the swing phase according to the two adjacent footholds of each leg;
  • the IK module is used to perform inverse dynamics calculation based on the position of the foot of each leg in the swing phase, to obtain the position of the bone point of each leg in the swing phase;
  • the fusion module is used to perform gait fusion based on the position of the bone points of each leg in the swing stage, and generate the walking animation of the virtual character.
  • a computer device comprising: one or more processors and a memory storing computer-readable instructions, the computer-readable instructions being executed by the one or more A plurality of processors are loaded and executed to realize the above-mentioned method for generating the walking animation of the virtual character.
  • a computer-readable storage medium stores computer-readable instructions, and the computer-readable instructions are loaded and executed by one or more processors to implement the above-mentioned A method for generating walking animation of a virtual character.
  • a computer program product comprising computer readable instructions stored in a computer readable storage medium.
  • One or more processors of the computer device read the computer-readable instructions from the computer-readable storage medium, and one or more processors execute the computer-readable instructions, so that the computer device executes the walking animation of the virtual character provided by the above aspect generate method.
  • Fig. 1 shows a structural block diagram of a computer system provided by an embodiment
  • Figure 2 shows a schematic diagram of the analysis of the walking motion of a humanoid avatar provided by an embodiment
  • Fig. 3 shows a flowchart of a method for generating a walking animation of a virtual character provided by an embodiment
  • Fig. 4 shows a schematic diagram of skeleton points on different forms of mecha legs provided by an embodiment
  • Figure 5 shows a schematic diagram of the gait progress of different legs during gait fusion provided by an embodiment
  • Fig. 6 shows a schematic diagram of a method for generating a virtual character's walking animation provided by an embodiment
  • Fig. 7 shows the prediction schematic diagram of foothold provided by another embodiment
  • Figure 8 shows a data structure diagram of gait parameters provided by an embodiment
  • Fig. 9 shows a schematic diagram of a method for generating a virtual character's walking animation provided by an embodiment
  • Fig. 10 shows a schematic diagram of mixing different dynamic parameters into a transition animation provided by an embodiment
  • Fig. 11 shows a schematic diagram of a method for generating a virtual character's walking animation provided by an embodiment
  • Fig. 12 shows a schematic diagram of a swing-optimized leg swing curve provided by an embodiment
  • Fig. 13 shows a schematic diagram of a leg swing curve provided by an embodiment when a small obstacle is encountered
  • Fig. 14 shows a schematic diagram of a method for generating a virtual character's walking animation provided by an embodiment
  • Fig. 15 shows a schematic diagram of a method for generating a virtual character's walking animation provided by an embodiment
  • Fig. 16 shows a vibration model diagram of a skeleton of a virtual character provided by an embodiment during inertial vibration
  • Fig. 17 shows a vibration schematic diagram of sequential vibration of multi-level skeletal nodes provided by an embodiment
  • Fig. 18 shows a foothold correction diagram provided by an embodiment when a virtual character encounters an uneven ground
  • Fig. 19 shows a body correction diagram of a virtual character provided by an embodiment when encountering uneven ground
  • Fig. 20 shows a foot modification diagram of a virtual character provided by an embodiment when encountering uneven ground
  • Fig. 21 shows a body adjustment diagram of a virtual character provided by an embodiment when encountering a raised ground
  • Fig. 22 shows a structural block diagram of a virtual character walking animation generating device provided by an embodiment
  • Fig. 23 shows a structural block diagram of a computer device provided by an embodiment.
  • Virtual Environment is the virtual environment displayed (or provided) by the application when it is run on the terminal.
  • the virtual environment can be a simulation environment of the real world, a semi-simulation and semi-fictional environment, or a purely fictitious environment.
  • the virtual environment may be any one of a two-dimensional virtual environment, a 2.5-dimensional virtual environment and a three-dimensional virtual environment, which is not limited in this application. The following embodiments are described with an example that the virtual environment is a three-dimensional virtual environment.
  • the virtual environment can provide a fighting environment for virtual characters.
  • a fighting environment for virtual characters exemplary, in a battle royale game, at least one virtual character conducts a single-game battle in a virtual environment. etc.) to achieve the purpose of surviving in the virtual environment, when the life value of the virtual character in the virtual environment is zero, the life of the virtual character in the virtual environment ends, and the virtual character who successfully passes the route in the checkpoint is the winner.
  • Each client can control one or more virtual characters in the virtual environment.
  • Virtual character refers to the movable object in the virtual environment.
  • the movable object may be a virtual character, a virtual animal, a cartoon character, a virtual mech, etc., for example: a character, an animal, or a mech displayed in a three-dimensional virtual environment.
  • the virtual character is a three-dimensional model created based on animation skeleton technology.
  • Each virtual character has its own shape and volume in the three-dimensional virtual environment, and occupies a part of the space in the three-dimensional virtual environment.
  • the avatar is a humanoid avatar with two legs.
  • the avatar may be a multi-legged avatar with more than two legs, such as a multi-legged virtual mech.
  • Fig. 1 shows a structural block diagram of a computer system provided by an exemplary embodiment of the present application.
  • the computer system 100 includes: a first terminal 120 , a server 140 , a second terminal 160 and a third terminal 180 .
  • the first terminal 120 is installed and runs an application program supporting a virtual environment.
  • the application program can be any one of three-dimensional map program, horizontal version shooting, horizontal version adventure, horizontal version clearance, horizontal version strategy, virtual reality (Virtual Reality, VR) application, augmented reality (Augmented Reality, AR) program .
  • the first terminal 120 is a terminal used by the first user.
  • the first user uses the first terminal 120 to control the first avatar in the virtual environment to perform activities.
  • the activities include but are not limited to: adjusting body posture, walking, running, jumping, At least one of riding, driving, aiming, picking up, using throwing props, and attacking other virtual characters.
  • the first virtual character is a first virtual character, such as a simulated character object or an anime character object.
  • the first user can control the first virtual character to perform activities through UI controls on the virtual environment screen, and the first user can also control the first virtual character to perform activities by operating the input control device connected to the first terminal 120 .
  • the first terminal 120 is connected to the server 140 through a wireless network or a wired network.
  • the server 140 includes at least one of a server, multiple servers, a cloud computing platform, and a virtualization center.
  • the server 140 includes a processor 144 and a memory 142, wherein the number of processors 144 may be one or more; the memory 142 further includes a receiving module 1421, a control module 1422 and a sending module 1423, and the receiving module 1421 is used to Receive a request sent by the client, such as a request to detect the position of an enemy virtual character; the control module 1422 is used to control the rendering of the virtual environment picture; the sending module 1423 is used to send a response to the client, such as sending the third virtual character to the client Location.
  • the server 140 is used to provide background services for applications supporting the 3D virtual environment.
  • the server 140 undertakes the main calculation work, and the first terminal 120, the second terminal 160 and the third terminal 180 undertake the secondary calculation work; or, the server 140 undertakes the secondary calculation work, and the first terminal 120, the second terminal 160 and the third terminal 180 undertake the main computing work; or, the server 140, the first terminal 120, the second terminal 160 and the third terminal 180 adopt a distributed computing architecture to perform collaborative computing.
  • the second terminal 160 is installed and runs an application program supporting a virtual environment.
  • the second terminal 160 is a terminal used by the second user, and the second user uses the second terminal 160 to control the second virtual character in the virtual environment to perform activities.
  • the third terminal 180 is installed and runs an application program supporting a virtual environment.
  • the third terminal 180 is a terminal used by the third user, and the third user uses the third terminal 180 to control the third virtual character in the virtual environment to perform activities.
  • the first virtual character, the second virtual character and the third virtual character are in the same virtual environment.
  • the first virtual character and the second virtual character belong to different camps, and the second virtual character and the third virtual character belong to the same camp.
  • the first virtual character belongs to camp A, and the second virtual character and the third virtual character belong to camp B.
  • the application programs installed on the first terminal 120, the second terminal 160 and the third terminal 180 are the same, or the application programs installed on the three terminals are of the same type on different operating system platforms (Android or IOS) application.
  • the first terminal 120 may generally refer to one of the multiple terminals
  • the second terminal 160 may generally refer to one of the multiple terminals
  • the third terminal 180 may generally refer to one of the multiple terminals. In this embodiment, only the first terminal 120, the second terminal 160, and the third terminal 180 for illustration.
  • the device types of the first terminal 120, the second terminal 160 and the third terminal 180 are the same or different, and the device types include: smart phones, smart watches, smart TVs, tablet computers, e-book readers, MP3 players, MP4 players , at least one of a laptop computer and a desktop computer.
  • the following embodiments are described by taking a terminal including a smart phone as an example.
  • the number of the foregoing terminals may be more or less. For example, there may be only one terminal, or there may be dozens or hundreds of terminals, or more.
  • the embodiment of the present application does not limit the number of terminals and device types.
  • the walking animation is an animation for simulating the walking motion using n legs of the avatar, where n is an integer greater than 1.
  • walking motion is a continuous cycle in which each leg moves alternately.
  • Figure 2 shows a schematic diagram of a humanoid avatar during a walking cycle.
  • Leg movement is divided into a stance phase and a swing phase.
  • the feet will stick to the ground and use the static friction between the ground and the ground to push the body forward; while in the swing phase, the feet will move towards the direction the body will move forward, looking for a suitable foothold to prepare for the next support.
  • each leg will go through these two stages once, and in order to maintain the balance of the body, the supporting stages of each leg will be staggered from each other.
  • This application refers to the cooperation between the legs as gait (gait), and the time required to complete this cycle is the gait cycle.
  • This application proposes a technical solution for generating walking animations of virtual characters through programming, which can be used to generate walking animations adapted to the current state of motion under different motion states of virtual characters, so as to eliminate traditional animation production methods
  • the "sliding step" problem that occurs in is a technical solution for generating walking animations of virtual characters through programming, which can be used to generate walking animations adapted to the current state of motion under different motion states of virtual characters, so as to eliminate traditional animation production methods.
  • Fig. 3 shows a flowchart of a method for generating a walking animation of a virtual character according to an exemplary embodiment of the present application.
  • the method for generating a virtual character's walking animation can be executed by a computer device, such as at least one of computer devices such as a terminal and a server. This embodiment is described by taking the method executed by a terminal as an example.
  • the method includes:
  • Step 302 Predict the foothold of each leg of the virtual character according to the moving speed and moving direction of the virtual character
  • the virtual character moves at different speeds.
  • the motion state includes: at least one of walking, running, crawling, and the like.
  • the moving direction of the virtual character can be manually controlled by the user (player). In the case of different moving speeds and moving directions, there are differences in the walking animation of the virtual character.
  • the swing stage is essentially the movement process of the foot from the lifting point to the foothold point. As long as the positions of the footlift point and the foothold point are known, the position of the foot during the swing process can be continuously updated through interpolation.
  • the terminal predicts multiple footholds or foothold sequences of each leg of the virtual character according to the moving speed and moving direction of the virtual character. For the two adjacent footholds, the previous foothold is the lifting point corresponding to the next foothold.
  • the foothold sequence of each leg of the virtual character is predicted respectively.
  • the swing phases of at least two legs appear alternately.
  • the swing phases of the two legs of a humanoid virtual character appear alternately; for another example, in a crab mech with 8 legs, the swing phases of odd-numbered legs and even-numbered legs appear alternately.
  • Step 304 Calculate the position of the foot of each leg in the swing phase according to the two adjacent footholds of each leg;
  • the foot lift point and foothold point of the foot have been determined.
  • the position of the foot of each leg in the swing phase can be calculated based on the leg swing curve.
  • Step 306 Perform inverse dynamics calculation based on the position of the foot of each leg in the swing phase to obtain the position of the bone points of each leg in the swing phase;
  • each leg of the avatar There are multiple bone points on each leg of the avatar.
  • the bone points are usually located at the joints of the leg bones, as shown in Figure 4, in various leg structures, each leg can have 3-4 bone points.
  • the leg bone close to the torso is the parent bone
  • the leg bone close to the foot is the child bone.
  • FK Forward Kinematics
  • IK Inverse Kinematics
  • the orientation of the child bone is determined first, and then the orientation of the n-level parent bone on the inheritance chain is deduced in reverse, that is, the position of the foot is first determined, and then reversed.
  • the position of the lower leg and upper leg is derived.
  • Step 308 Perform gait fusion based on the position of the bone points of each leg in the swing phase, and generate a walking animation of the virtual character.
  • the swing phases in which there are at least two legs among the n legs of the virtual character appear alternately.
  • the gait cycle the duration of the swing phase + the duration of the support phase, since the gait progress of each leg may be different, the gait progress of each leg may be different.
  • the gait progress of each leg needs to be fused through gait management, so that the virtual character can reasonably use each leg to perform walking motion.
  • the gait cycle of the four legs is regarded as a circular progress bar, and they will respectively arrange the sections occupied by the support phase and the swing phase on the progress bar, and the entire gait progress is like a A pointer that advances the update of the gait progress of each leg at a uniform angular velocity.
  • the gait management process shown in Figure 5 can be represented by a set of gait parameters
  • the gait parameters include: gait cycle, starting time point of each leg, swing cycle, step midpoint, swing height midpoint at least one of .
  • the starting time point is the time of lifting the foot in the swing stage
  • the swing cycle is the duration of a swing stage
  • the midpoint of the step refers to the midpoint position in a support stage
  • the swing height refers to the swing of the foot in a single swing stage maximum height.
  • Each parameter in the gait parameters can be custom-set or custom-adjusted so that the action animation of the avatar meets design expectations.
  • the method provided by this embodiment by first calculating the foot movement of each leg according to the moving speed and direction of the virtual character, and then performing the gait fusion of each leg, can generate Walking animation with n legs. Regardless of the moving speed and moving direction of the virtual character, it can always be adapted to generate corresponding walking animation, and there will be no sliding problem caused by traditional animation mixing.
  • the method provided in this embodiment can be directly applied to avatars of different styles or forms.
  • it is no longer necessary to write corresponding motion animation logic for the motion of different avatars, and can Effectively improve animation generation efficiency.
  • Fig. 6 shows a flowchart of a method for generating a walking animation of a virtual character according to an exemplary embodiment of the present application. This embodiment is described by taking the method executed by the terminal as an example. The method includes:
  • Step 602 Predict the predicted moving trajectory of the virtual character on the map according to the moving speed and moving direction of the virtual character
  • the gait cycle is equal to the sum of the duration of the support phase and the swing phase of any leg, and the time ratio of the support phase and the swing phase in the entire gait cycle is also a Constant value k.
  • k can be configured as required.
  • T support is the duration of the support phase in a gait cycle
  • T swing is the duration of the swing phase in a gait cycle.
  • the posture of the avatar at the beginning and end of a gait cycle should be the same, so the displacement S of the foot is equivalent to the displacement S of the avatar itself. does not change, so all displacements of the foot occur during the swing phase.
  • the essence of the swing stage is the movement process of the foot from the lifting point to the foothold point, as long as the position of the footlift point and the foothold point can be known, it can be interpolated (periodic interpolation according to the frame interval of each frame) to continuously update the position of the foot during the swing.
  • the lifting point is known, and the next main problem is how to predict the position of the foothold.
  • the displacement of the virtual character it can be estimated directly by the moving speed of the virtual character, or it can be more accurately predicted by using the mobile system provided by the client (such as the game) itself (such as the Movement Component in Unreal Engine 4).
  • the virtual character is simulated several times at the current moving speed and moving direction with a small time step (such as 0.2 seconds), so as to obtain a predicted moving trajectory Traj .
  • the predicted moving trajectory is Multiple sampling points of P 0 -P 8 in FIG. 7 .
  • n is an integer.
  • P i is the i-th sampling point on the predicted trajectory.
  • the time step between two adjacent sampling points is a preset value.
  • Step 604 Taking the current posture of each leg of the avatar as the starting point of prediction, sampling the foothold of each leg on the predicted movement trajectory;
  • the gait cycle is equal to the duration T of the swing phase and the duration T of the support phase.
  • This step may include the following sub-steps:
  • the position along the predicted movement trajectory is determined as the body position of the virtual character when it lands.
  • the predicted length is equal to the product of the predicted duration and moving speed.
  • the foothold of the i-th leg of the avatar on the predicted movement trajectory is deduced.
  • i is a positive integer less than or equal to n
  • the relative position relationship is the relative position between the preconfigured virtual character's body and the i-th leg.
  • P represents the position of the torso of the avatar
  • F represents the position of the feet of the avatar.
  • the i-th leg of the avatar is in the t-th second after the start of the swing phase, if the remaining swing duration (T swing -t) is passed into the predicted movement trajectory for sampling, the i-th leg can be obtained
  • the position and orientation information of the virtual character when the feet of the user land on the ground.
  • the foothold point can be calculated. But this embodiment does not grasp the relative position at this time, but there is a similar information that can be known, which is the midpoint P of the stride of this leg.
  • the so-called step midpoint refers to the midpoint of the line connecting the start point and the foothold point.
  • the entire gait cycle is the cycle in which the feet move back and forth around the midpoint of the step.
  • the relative position between the midpoint of the step and the torso of the avatar will directly affect the posture performance of the avatar when walking, so this embodiment also uses the relative position between the midpoint of the step and the torso of the avatar as a configuration parameter F local , Preconfigured or tweaked by an animator.
  • the sampling time point of the foothold point can be pushed back by half the duration of the support stage.
  • the foot is just at the midpoint of the step, and the sample obtained in this embodiment is At this time, the position of the feet can be calculated based on the torso information of the virtual character. Since the absolute position of the foot does not change throughout the support phase, the calculated foot position at this time is the foothold to be predicted.
  • Step 606 Determine the leg swing curve based on the positions of two adjacent footholds
  • the leg swing curve is used to indicate the swing trajectory of the foot during the swing phase.
  • the leg swing curve is represented by a parabola 70, as shown in FIG. 7 .
  • the two endpoints of the parabola are the lifting point and the footing point respectively, and the height h of the parabola is also the highest swing height of the foot during the swing phase, which can also be pre-configured or adjusted by the animator.
  • Step 608 Perform interpolation calculation on the foot of each leg based on the leg swing curve, and calculate the position of the foot of each leg in the swing phase;
  • F t is the position of the foot of each leg on the leg swing curve at the tth second of the swing phase.
  • the step size of time t can be determined according to the frame interval of the display frame, for example, if 60 frames per second, the step size of t is 1/60 second.
  • Step 610 Perform inverse dynamics calculation based on the position of the foot of each leg in the swing phase to obtain the position of the bone points of each leg in the swing phase;
  • the virtual character is a multi-legged mech
  • IK Inverse Kinematics
  • CCDIK Cyclic Coordinate Decent Inverse Kinematics
  • FBRIK Forward and Backward Reaching Inverse Kinematics
  • Priority 1 Support any number of joints, providing a large space for the design of the leg structure.
  • Advantage 2 Supports the angle limit of joint rotation, and can realize the specific mechanical joint structure of the mecha.
  • FABRIK will perform better than CCDIK in the hoof-like leg structure. Therefore, for the multi-legged mech with a hoof-like leg structure, you can use The FABRIK algorithm calculates the position of the bone points of each leg of the multi-legged mecha during the swing phase.
  • Step 612 Obtain pre-configured gait parameters
  • Gait parameters are a set of parameters used in gait fusion. For the same virtual character, there are one or more groups of gait parameters, and the number of groups of gait parameters can be specifically determined according to the number of motion states or the number of moving directions of the virtual character.
  • different groups of gait parameters correspond to different motion states, for example, the sneaking state corresponds to the first group of gait parameters, the walking state corresponds to the second group of gait parameters, and the running state corresponds to the third group of gait parameters.
  • different sets of gait parameters correspond to different moving directions. For example, moving north corresponds to the first set of gait parameters, moving south corresponds to the second set of gait parameters, and moving east corresponds to the third set of gait parameters. Moving west corresponds to the fourth set of gait parameters.
  • the gait parameters include: gait cycle and foot parameter list.
  • the foot parameter list includes: at least one of swing start, swing period, swing height and step midpoint.
  • the swing start is the starting time point of the swing phase, that is, the time to lift the foot;
  • the swing period is the duration of one swing phase;
  • the swing height refers to the highest swing height of the foot in a single swing phase; The position of the midpoint in the support phase.
  • Step 614 Based on the gait parameters, gait fusion is performed on the position of the bone points of each leg in the swing phase to generate a walking animation of the virtual character.
  • the swing phases in which there are at least two legs among the n legs of the virtual character appear alternately.
  • the gait cycle the duration of the swing phase + the duration of the support phase, since the gait progress of each leg may be different, the gait progress of each leg may be different.
  • the gait progress of each leg needs to be fused through gait management, so that the virtual character can reasonably use each leg to perform walking motion.
  • the gait cycle of the four legs is regarded as a circular progress bar, and they will respectively arrange the sections occupied by the support phase and the swing phase on the progress bar, and the entire gait progress is like a A pointer that advances the update of the gait progress of each leg at a uniform angular velocity.
  • the gait management process shown in Figure 5 can be represented by a set of gait parameters, the gait parameters include: gait cycle (total duration), starting time point of each leg, swing cycle, mid-step at least one of point and swing height.
  • gait cycle total duration
  • starting time point of each leg starting time point of each leg
  • swing cycle starting time point of each leg
  • mid-step at least one of point and swing height.
  • each parameter in the gait parameters can be custom-set or custom-adjusted, so that the action animation of the virtual character meets design expectations.
  • the gait parameters include: the total duration of the gait cycle and the leg parameters of each leg in the gait cycle; within the total duration of the gait cycle, according to the leg parameters of each leg in the gait cycle
  • the parameter performs gait fusion on the position of the bone points of each leg in the swing phase, and generates the walking animation of each leg of the virtual character.
  • the terminal displays the walking animation of each leg of the virtual character.
  • the above calculation process can be calculated in real time frame by frame, or the calculation results of many frames can be pre-calculated and cached, and displayed according to the cached calculation results. This embodiment does not limit it.
  • the method provided by this embodiment by first calculating the foot movement of each leg according to the moving speed and direction of the virtual character, and then performing the gait fusion of each leg, can generate Walking animation with n legs. Regardless of the moving speed and moving direction of the virtual character, it can always be adapted to generate corresponding walking animation, and there will be no sliding problem caused by traditional animation mixing. Moreover, in the specific application process, taking the virtual character of the game as an example, the movement of the virtual character can be quickly adjusted through simple parameter configuration, and the gameplay can be quickly verified in the game.
  • the sneak state corresponds to the first group of gait parameters
  • the walking state corresponds to the second group of gait parameters
  • the running state corresponds to the third group of gait parameters.
  • the gait parameters include a first (set of) gait parameters in a first movement modality and a second (set of) gait parameters in a second movement modality. As shown in Figure 9, the above method also includes:
  • Step 616 Interpolate the first gait parameter and the second gait parameter to obtain the first mixed gait parameter
  • the interpolation may be implemented based on the animation display frame rate of the virtual environment where the virtual character is located.
  • the number of interpolations is determined based on the duration and frame rate of the transition animation from the first motion form to the second motion form, and the first gait parameter A and the second gait parameter B are interpolated according to the number of differences processing to obtain the first mixed gait parameters.
  • the first gait parameter A and the second gait parameter B can be n*m Sub-interpolation to obtain the first mixed gait parameters corresponding to each frame.
  • the first mixed gait parameter (1- ⁇ )*first gait parameter A+ ⁇ *second gait parameter B, and the value range of ⁇ is from 0 to 1.
  • is divided into n*m times, gradually increasing from 0 to 1. That is, the first mixed gait parameters include n*m groups of gait parameters, showing a gradual change process from the first motion form to the second motion form.
  • the degree of gradual change in different motion states may be different, for example, the stealth state corresponds to the first degree of gradual change, the state of walking corresponds to the second degree of gradual change, the state of running corresponds to the third degree of gradual change, and so on.
  • Step 618 Based on the first blended gait parameters, gait fusion is performed on the position of the bone points of each leg in the swing phase, and a transition animation of the avatar switching from the first motion form to the second motion form is generated.
  • the terminal displays the first walking animation in the first motion form, and the first walking animation is generated based on the first motion parameter (group); after the transition animation, the terminal displays the first walking animation in the second motion form.
  • the second walking animation is generated based on the second gait parameters (groups).
  • the method provided in this embodiment realizes the smooth transition effect between different motion states through the one-dimensional fusion of different groups of gait parameters, so that the virtual character displayed on the terminal can be in different motion states.
  • it presents a smoother and smoother movement change.
  • the gait parameters include a third gait parameter (group) under the first moving direction and a fourth gait parameter (group) under the second moving direction; as shown in FIG. 11 , the Methods also include:
  • Step 620 Interpolate the third gait parameter and the fourth gait parameter to obtain a second mixed gait parameter
  • the third gait parameter C and the fourth gait parameter D can be two-dimensionally interpolated , to obtain the second hybrid gait parameter corresponding to the third moving direction.
  • the third moving direction is a moving direction between the first moving direction and the second moving direction.
  • the gait parameter of the virtual character is the fifth gait parameter O when the virtual character is different in place.
  • the calculation process of the second mixed gait parameters is as follows:
  • current speed in the first direction of movement/maximum speed in the first direction of movement
  • current speed of the second moving direction/maximum speed of the second moving direction
  • the first intermediate gait parameter C' (1- ⁇ )*O+ ⁇ *C;
  • the second intermediate gait parameter D' (1- ⁇ )*O+ ⁇ *D;
  • Second mixed gait parameter (1- ⁇ )*C'+ ⁇ *D'.
  • the first weight ⁇ is equal to the current speed of the first moving direction divided by the maximum speed of the first moving direction
  • the third weight is calculated as ⁇ /( ⁇ + ⁇ ); the first intermediate gait parameter and the second intermediate gait parameter are mixed by using the third weight to obtain a second mixed gait parameter.
  • Step 622 Perform gait fusion on the position of the skeleton point of each leg in the swing phase based on the second blended gait parameters, and generate a walking animation of each leg of the avatar in the third moving direction.
  • the terminal Before the transition animation, the terminal displays the walking animation in the first moving direction, which is generated based on the third gait parameter (group); after the transition animation, the terminal displays the walking animation in the second moving direction
  • the walking animation in the second moving direction is generated based on the fourth gait parameter (group).
  • the third moving direction is located between the first moving direction and the second moving direction, based on the third moving direction, a smooth transition from the first moving direction to the second moving direction can be realized.
  • the method provided in this embodiment realizes the smooth transition effect between different motion states through the two-dimensional fusion of different groups of gait parameters, so that the virtual character displayed on the terminal can be in different motion states.
  • it presents a smoother and smoother movement change.
  • the mixing dimension can also be increased like animation.
  • the movement of virtual characters in different directions - forward, translation, and backward actions will use different animation performances.
  • Animators will create moving animation sequences in 4 or 8 directions, and perform two-dimensional animation mixing through the animation mixing space .
  • Gait blending can also follow the same principle, the animator configures a corresponding set of gait parameters for each direction of movement.
  • the terminal will mix the gait parameters in two dimensions according to the moving direction and speed of the virtual character.
  • the interpolation process is improved, and a time-based curve is introduced for the interpolation ⁇ coefficient to control.
  • a curve that first accelerates and then decelerates can be used to determine the ⁇ coefficient of the interpolation, as shown in the left figure (1) of Figure 12, that is, at the tth second of the leg swing stage, it is determined that the foot is in the horizontal direction
  • the position is: F foot lift point + ⁇ *(F foothold point - F foot lift point ); and the swing height in the vertical direction can be added to a re-lift curve before landing and then quickly fall, as shown in the right of Figure 12 Figure (2), that is, at the tth second of the leg swing stage, determine the position of the foot in the vertical direction as h corresponding to the time t.
  • the combination of these changes will make the whole leg swing look more powerful.
  • this embodiment may record the motion data of the bones of the feet in the walking animation created by the animator, so as to generate corresponding leg swing curves. It is also possible for the animator to manually edit the leg swing curve directly. Some game engines provide a curve editor, and the animator can easily operate on it.
  • the leg swing curve should also be adjusted according to the obstacles. an offset.
  • determine the spline curve based on the positions of the two adjacent footholds and the highest point of the obstacle; superimpose the spline curve and the leg swing curve to obtain the updated leg swing curve.
  • a spline curve is a smooth curve passing through a series of given points. The given point is the highest point of two adjacent footholds and obstacles.
  • the length of the swing leg is taken as the length and the width of the foot
  • a horizontal capsule 1320 is constructed as a radius, and a collision detection is performed on the capsule 1320 from top to bottom to obtain all collision bumps on the ground. Because only those convex points that will block the leg swing curve need to be considered, all the convex points whose height is lower than the leg swing curve can be filtered out first, and a spline curve is generated by using the remaining convex points, and superimposed on the original leg swing curve , you can get a new route, so that the virtual mecha can step over these obstacles.
  • the above-mentioned embodiment illustrates that the walking animation of the virtual character is generated in a purely procedural way, and basically correct performance effects can be obtained through this method. But being right isn't enough for a good game. Every gesture of a virtual character is a carrier to express the personality of the virtual character. Take the large multi-group mech mentioned in the embodiment of the present application as an example, whether it is bulky or flexible, it should be shown by its walking action. Therefore, in the following content, the main consideration of the embodiment of the present application is how to make the animation of the character more vivid.
  • the above method further includes:
  • Step 624 Obtain the torso animation of the avatar.
  • the animator will still produce a certain motion animation for the avatar as usual, and the motion animation includes: the torso animation corresponding to the body part and the walking animation corresponding to the legs.
  • the walking animation in the motion animation produced by the animator is removed, and the remaining animation part is the torso animation of the virtual character.
  • Step 626 Fusion the torso animation of the virtual character with the walking animation of each leg to obtain the overall moving animation of the virtual character.
  • the animator-made torso animation was fused with the procedurally calculated walk animation.
  • Most game engines provide corresponding animation toolchains. Taking Unreal Engine 4 as an example, in the animation blueprint, based on the torso animation, the calculated walking animation can be imported, and finally the overall moving animation of the virtual character can be output.
  • the body animation needs to be in sync with the gait cycle of the walk animation. Since the gait cycle in the game may change dynamically, this embodiment will scale the torso animation in real time to ensure that the length of the torso animation is consistent with the gait cycle, and directly use the gait progress as the playback progress of the torso animation.
  • the animation duration of the torso animation of the virtual character is scaled according to the gait cycle to obtain the scaled torso animation.
  • the animation duration of the scaled torso animation is equal to the duration of the gait cycle.
  • the method provided in this embodiment can make the torso and legs of the avatar have animation effects adapted to the walking process by fusing the torso animation of the avatar with the walking animation of each leg.
  • the visual performance of the movement is more vivid and realistic.
  • the above method further includes:
  • Step 628 If there are elastic parts on the body of the avatar, determine at least two levels of bone nodes corresponding to the elastic parts in the skeletal tree of the avatar;
  • the elastic component is a component that can generate inertial swing with the direction of speed change during the start-stop or turning process of the virtual character.
  • the bone tree of the virtual character is a tree established based on the importance of each bone in the virtual character. In one example, among at least two levels of bone nodes, the level of the bone nodes near the center of the body is higher than that of the bone nodes near the ends of the body.
  • Step 630 start from the root node of at least two levels of bone nodes, use the upper level bone node as the origin, and the lower level bone node as the vibrator to perform vibration calculation of the three-dimensional vibration model, determine the bone update position of the lower level bone node, Until the updated bone update position of the elastic component is obtained.
  • the time t S required for the vibrator to enter a stable state and the damping ratio ⁇ are parameters that can be understood intuitively. They are used as configuration parameters to allow the animator to control the performance of the system.
  • the natural frequency ⁇ 0 can be obtained by the above formula. After substituting ⁇ and ⁇ 0 into formula (1), the relationship between position, velocity and acceleration is obtained, and then the vibration process is integrated by the particle motion simulation (Verlet) method with a fixed time step ⁇ t to update the position of the vibrator:
  • a three-dimensional vibration model is obtained, and finally this model is applied to the character skeleton.
  • this model For each pair of parent and child bones, it can be regarded as a three-dimensional vibration model with the parent bone as the origin and the child bone as the vibrator.
  • the bone tree that needs to be affected by inertia in the skeleton start from the root node and calculate step by step to the leaf nodes, so that the bone used as the vibrator will become the vibration origin of the next-level bone after updating its position, so that the next-level
  • the vibration calculation of the bones produces a joint effect, forming a progressive inertia effect, as shown in Figure 17.
  • the terminal calculates the support vector of each leg of the virtual character, and the support vector is used to indicate the inclination of the foothold of the current leg relative to the torso of the virtual character; based on the support vectors of each leg, the posture angle of the torso of the virtual character is calculated; based on The attitude angle compensates for the inclination of the avatar's torso.
  • the attitude angle includes yaw angle yaw, pitch angle pitch and roll angle roll.
  • Figure 20 shows the sagittal angle of view when the avatar is standing in an inclined posture. Starting from the ground position O where the torso of the avatar is located, it is connected to the position F where the feet are located to obtain After the plane where it is located, draw a vertical line from the support point H of the torso to intersect the plane to obtain the intersection point N, is the support vector of this leg relative to the torso.
  • the convex terrain shown in FIG. 21 will appear.
  • the avatar stands on the top, in order to keep the feet on the ground, it will form an arched posture of the body, as if being pushed up by invisible things. Therefore, it is necessary to correct the height of the torso, obtain the average height difference between each foot F and the body position O of the avatar in the current state, and then obtain the correction value of the torso height, and then apply this value to the body of the avatar
  • the skeleton corrects the torso to a reasonable height, such as raising the height difference That is, when the virtual character is above the convex ground, calculate the average height difference between the footholds of each leg of the virtual character and the apex of the convex ground; altitude compensation.
  • the torso height of the virtual character standing on the convex terrain is more in line with the performance of the mecha in the real world.
  • Using the above method fundamentally solves the "sliding step" problem caused by animation mixing, retains the high-quality performance of the pre-made animation sequence to the greatest extent, and can also easily insert the terrain during the calculation process of the program. Adaptation and the corresponding physics simulation, combining the advantages of both animation sequences and procedural calculations.
  • Fig. 22 shows a block diagram of an apparatus for generating a virtual character's walking animation provided by an exemplary embodiment of the present application.
  • the device adopts hardware or a combination of software and hardware and is applied to the terminal. Each leg of the virtual character alternately performs the swing phase and the support phase during the walking process.
  • the device includes:
  • a prediction module 220 configured to predict the foothold of each leg of the virtual character during the walking process according to the moving speed and moving direction of the virtual character;
  • a calculation module 222 configured to calculate the position of the foot of each leg in the swing phase according to the two adjacent footholds of each leg;
  • the IK module 224 is configured to perform inverse dynamics calculation based on the position of the foot of each leg in the swing phase, to obtain the position of the bone point of each leg in the swing phase;
  • the fusion module 226 is configured to perform gait fusion based on the position of the bone points of each leg in the swing stage, and generate the walking animation of the virtual character.
  • the fusion module 226 is configured to obtain preconfigured gait parameters; based on the gait parameters, perform Gait fusion, generating the walking animation of the virtual character.
  • the gait parameters include: a gait cycle and leg parameters of each leg in the gait cycle; the fusion module 226 is configured to In the gait cycle, according to the leg parameters of each leg in the gait cycle, perform gait fusion on the position of the bone point of each leg in the swing stage to generate the walking of the virtual character animation;
  • leg parameters include at least one of the time point of raising the foot, the duration of the swing phase, and the midpoint of the stride in the support phase.
  • the gait parameters include a first gait parameter in a first movement form and a second gait parameter in a second movement form;
  • the device also includes:
  • the transition module 228 is configured to interpolate the first gait parameter and the second gait parameter to obtain a first mixed gait parameter; based on the first mixed gait parameter, the skeleton of each leg Perform gait fusion at the position of the swing stage, and generate a transition animation in which each leg of the avatar switches from the first motion form to the second motion form.
  • the gait parameters include a third gait parameter in the first moving direction and a fourth gait parameter in the second moving direction;
  • the device also includes:
  • the transition module 228 is configured to interpolate the third gait parameter and the fourth gait parameter to obtain a second mixed gait parameter; based on the second mixed gait parameter, the bones of each leg are Perform gait fusion at the position of the swing stage to generate a walking animation of each leg of the virtual character in the third moving direction;
  • the third moving direction is a moving direction between the first moving direction and the second moving direction.
  • the predicting the foothold of each leg of the virtual character according to the moving speed and moving direction of the virtual character includes:
  • the virtual character includes n legs, and the current posture of each leg of the virtual character is used as the starting point of prediction, and each leg is sampled on the predicted movement trajectory.
  • Footholds for the legs including:
  • the current posture of the i-th leg of the virtual character is the t second state of the swing phase
  • the sum of the remaining duration of the swing phase and half of the duration of the support phase is calculated as the predicted duration
  • the position along the predicted movement trajectory of the predicted length is determined as the body position of the virtual character when it lands, so The predicted length is equal to the product of the predicted duration and the moving speed;
  • i is a positive integer not greater than n
  • the relative positional relationship is the preconfigured relative position between the body of the virtual character and the ith leg.
  • the calculation module 222 is configured to determine a leg swing curve based on the positions of two adjacent footholds, and the leg swing curve is used to indicate that the foot is in the A swing trajectory in the swing phase: performing interpolation calculation on the foot of each leg based on the leg swing curve, and calculating the position of the foot of each leg in the swing phase.
  • the IK module 224 is configured to perform CCDIK calculations based on the two adjacent foothold points of each leg to obtain the or, perform FABRIK calculation according to the two adjacent footholds of each leg to obtain the position of the bone point of each leg in the swing phase.
  • the fusion module 226 is configured to acquire the torso animation of the virtual character; fuse the torso animation of the virtual character with the walking animation of each leg to obtain the Describe the overall moving animation of the avatar.
  • the fusion module 226 is configured to scale the torso animation of the virtual character according to the gait cycle to obtain the scaled torso animation; combine the scaled torso animation with The walking animation of each leg is fused to obtain the overall moving animation of the virtual character.
  • the calculation module 222 is further configured to determine that the elastic components correspond to at least two levels of skeletal nodes; starting from the root node in the at least two levels of skeletal nodes, the upper level of bone nodes is the origin and the lower level of bone nodes is the vibrator to perform vibration calculation of the three-dimensional vibration model to determine the next The bone update position of the first-level bone node is updated until the bone update position of the elastic component is obtained.
  • the prediction module 220 is further configured to calculate the vertical direction of the foothold on the uneven ground when the ground where the foothold is located is uneven.
  • the second projection point is used as the updated foothold.
  • the prediction module 220 is further configured to deflect the posture of the foot when the foot is on the ground according to the updated normal direction of the ground where the foothold is located.
  • the fusion module 226 is also used to calculate the support vector of each leg of the virtual character, and the support vector is used to indicate that the foothold of the current leg is relative to the virtual The inclination of the torso of the character; calculating the posture angle of the torso of the virtual character based on the support vectors of the legs; performing tilt compensation on the torso of the virtual character based on the posture angle.
  • the fusion module 226 is also used to calculate the relationship between the feet of each leg of the virtual character and the convex ground when the virtual character is above the convex ground.
  • the average height difference between the vertices of the shaped ground; according to the average height difference, the height of the torso of the virtual character is compensated.
  • Fig. 23 shows a structural block diagram of a computer device 2300 provided by an exemplary embodiment of the present application.
  • the computer device 2300 can be a portable mobile terminal, such as: smart phone, tablet computer, MP3 player (Moving Picture Experts Group Audio Layer III, moving picture expert compression standard audio level 3), MP4 (Moving Picture Experts Group Audio Layer IV, Motion Picture Expert compresses standard audio levels 4) Players, laptops or desktops.
  • the computer device 2300 may also be called user equipment, portable terminal, laptop terminal, desktop terminal, and other names.
  • a computer device 2300 includes: a processor 2301 and a memory 2302 .
  • the processor 2301 may include one or more processing cores, such as a 4-core processor, an 8-core processor, and the like.
  • Processor 2301 can adopt at least one hardware form in DSP (Digital Signal Processing, digital signal processing), FPGA (Field-Programmable Gate Array, field programmable gate array), PLA (Programmable Logic Array, programmable logic array) accomplish.
  • Processor 2301 may also include a main processor and a coprocessor, and the main processor is a processor for processing data in a wake-up state, also known as a CPU (Central Processing Unit, central processing unit); the coprocessor is Low-power processor for processing data in standby state.
  • CPU Central Processing Unit, central processing unit
  • the coprocessor is Low-power processor for processing data in standby state.
  • the processor 2301 may be integrated with a GPU (Graphics Processing Unit, image processor), and the GPU is used for rendering and drawing the content that needs to be displayed on the display screen.
  • the processor 2301 may also include an AI (Artificial Intelligence, artificial intelligence) processor, where the AI processor is used to process computing operations related to machine learning.
  • AI Artificial Intelligence, artificial intelligence
  • Memory 2302 may include one or more computer-readable storage media, which may be non-transitory.
  • the memory 2302 may also include high-speed random access memory, and non-volatile memory, such as one or more magnetic disk storage devices and flash memory storage devices.
  • the non-transitory computer-readable storage medium in the memory 2302 is used to store at least one instruction, and the at least one instruction is used to be executed by the processor 2301 to implement the extra-domain network provided by the method embodiments in this application Acceleration methods for resources.
  • the computer device 2300 may optionally further include: a peripheral device interface 2303 and at least one peripheral device.
  • the processor 2301, the memory 2302, and the peripheral device interface 2303 may be connected through buses or signal lines.
  • Each peripheral device can be connected to the peripheral device interface 2303 through a bus, a signal line or a circuit board.
  • the peripheral device may include: at least one of a radio frequency circuit 2304 , a display screen 2305 , a camera component 2306 , an audio circuit 2307 and a power supply 2308 .
  • computing device 2300 also includes one or more sensors 2310 .
  • the one or more sensors 2310 include, but are not limited to: an acceleration sensor 2311 , a gyro sensor 2312 , a pressure sensor 2313 , an optical sensor 2314 and a proximity sensor 2315 .
  • FIG. 23 does not constitute a limitation to the computer device 2300, and may include more or less components than shown in the figure, or combine some components, or adopt a different arrangement of components.
  • the present application also provides a computer-readable storage medium, wherein at least one instruction, at least one program, code set or instruction set is stored in the storage medium, and the at least one instruction, the at least one program, the code set or The instruction set is loaded and executed by the processor to implement the method for generating the walking animation of the virtual character provided by the above method embodiments.
  • the present application provides a computer program product or computer program, the computer program product or computer program includes computer readable instructions, and the computer readable instructions are stored in a computer readable storage medium.
  • the processor of the computer device reads the computer-readable instructions from the computer-readable storage medium, and the processor executes the computer-readable instructions, so that the computer device executes the method for generating a virtual character's walking animation provided by the above method embodiments.
  • the program can be stored in a computer-readable storage medium.
  • the above-mentioned The storage medium mentioned may be a read-only memory, a magnetic disk or an optical disk, and the like.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Theoretical Computer Science (AREA)
  • Human Computer Interaction (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Processing Or Creating Images (AREA)

Abstract

本申请公开了一种虚拟角色的行走动画生成方法、装置、设备及存储介质,属于动画制作领域。所述方法包括:根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点(302);根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置(304);基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置(306);基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画(308)。

Description

虚拟角色的行走动画生成方法、装置、设备及存储介质
相关申请的交叉引用
本申请要求于2021年11月19日提交中国专利局,申请号为2021113743619,申请名称为“虚拟角色的行走动画生成方法、装置、设备及存储介质”的中国专利申请、以及于2021年12月28日提交中国专利局,申请号为2021116287887,申请名称为“虚拟角色的行走动画生成方法、装置、设备及存储介质”的中国专利申请的优先权,其全部内容通过引用结合在本申请中。
技术领域
本申请涉及动画制作领域,特别涉及一种虚拟角色的行走动画生成方法、装置、设备及存储介质。
背景技术
在写实对战风格的游戏中,经常会出现多足机甲类的虚拟角色。多足机甲的特点是极具重量感和压迫感,就像一座稳定推进不可阻挡的移动堡垒。
相关技术中使用动画混合技术来生成多足机甲的行走动画。对于多足机甲的每一个需要混合的骨骼,分别获取它在源动画姿态和目标动画姿态下的变换矩阵,以一个随着时间推移从0到1变化的权重值α,通过插值的方式将其混合得到一个新的变换矩阵。例如,多足机甲从行走姿态转变到站立姿态时,会在过渡期间内同时播放行走姿态和站立姿态的动画序列,并根据过渡的进程将播放权重α慢慢从行走姿态转移向站立姿态,从而达到平滑过渡的效果。
但由于虚拟角色的移动速度和移动方向是保持变化的,在某些情况下,比如多足机甲的支撑腿在两个动画序列中的位置相距比较远,用户就会很明显地看到这条支撑腿贴着地面“滑行”了一段距离,这种不会在现实世界中发生的违和现象即为“滑步”现象。
发明内容
根据本申请提供的各种实施例,提供了一种虚拟角色的行走动画生成方法、装置、设备及存储介质。
根据本申请的一方面,提供了一种虚拟角色的行走动画生成方法,由计算机设备执行所述虚拟角色的每条腿在行走过程中交替执行摆动阶段和支撑阶段,所述方法包括:
根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点;
根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置;
基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置;及
基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
根据本申请的另一方面,提供了一种虚拟角色的行走动画生成装置,所述虚拟角色的每条腿在行走过程中交替执行摆动阶段和支撑阶段,所述装置包括:
预测模块,用于根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点;
计算模块,用于根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置;
IK模块,用于基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置;及
融合模块,用于基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
根据本申请的一个方面,提供了一种计算机设备,所述计算机设备包括:一个或多个处理器和存储器,所述存储器存储有计算机可读指令,所述计算机可读指令由所述一个或多个处理器加载并执行以实现如上所述的虚拟角色的行走动画生成方法。
根据本申请的另一方面,提供了一种计算机可读存储介质,所述存储介质存储有计算机可读指令,所述计算机可读指令由一个或多个处理器加载并执行以实现如上所述的虚拟角色的行走动画生成方法。
根据本申请的另一方面,提供了一种计算机程序产品,所述计算机程序产品包括计算机可读指令,该计算机可读指令存储在计算机可读存储介质中。计算机设备的一个或多个处理器从计算机可读存储介质读取该计算机可读指令,一个或多个处理器执行该计算机可读指令,使得该计算机设备执行上述方面提供的虚拟角色的行走动画生成方法。
本申请的一个或多个实施例的细节在下面的附图和描述中提出。本申请的其它特征、目的和优点将从说明书、附图以及权利要求书变得明显。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1示出了一个实施例提供的计算机系统的结构框图;
图2示出了一个实施例提供的人形虚拟角色的行走运动的分析示意图;
图3示出了一个实施例提供的虚拟角色的行走动画生成方法的流程图;
图4示出了一个实施例提供的不同形态的机甲腿上的骨骼点示意图;
图5示出了一个实施例提供的不同腿在步态融合时的步态进度示意图;
图6示出了一个实施例提供的虚拟角色的行走动画生成方法的示意图;
图7示出了另一个实施例提供的落脚点的预测原理图;
图8示出了一个实施例提供的步态参数的数据结构图;
图9示出了一个实施例提供的虚拟角色的行走动画生成方法的示意图;
图10示出了一个实施例提供的将不同步态参数混合为过渡动画的示意图;
图11示出了一个实施例提供的虚拟角色的行走动画生成方法的示意图;
图12示出了一个实施例提供的具有摆动优化的摆腿曲线的示意图;
图13示出了一个实施例提供的在遇到小型障碍物时的摆腿曲线的示意图;
图14示出了一个实施例提供的虚拟角色的行走动画生成方法的示意图;
图15示出了一个实施例提供的虚拟角色的行走动画生成方法的示意图;
图16示出了一个实施例提供的虚拟角色的骨骼在惯性振动时的振动模型图;
图17示出了一个实施例提供的多级骨骼节点依次振动的振动示意图;
图18示出了一个实施例提供的虚拟角色遇到非平整地面时的落脚点修正图;
图19示出了一个实施例提供的虚拟角色在遇到非平整地面时的身体修正图;
图20示出了一个实施例提供的虚拟角色在遇到非平整地面时的脚部修正图;
图21示出了一个实施例提供的虚拟角色在遇到凸起地面时的身体调整图;
图22示出了一个实施例提供的虚拟角色的行走动画生成装置的结构框图;
图23示出了一个实施例提供的计算机设备的结构框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本申请相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本申请的一些方面相一致的装置和方法的例子。应当理解的是,在本文中提及的“若干个”是指一个或者多个,“多个”是指两个或两个以上。
首先,对本申请实施例中涉及的名词进行简单介绍:
虚拟环境:是应用程序在终端上运行时显示(或提供)的虚拟环境。该虚拟环境可以是对真实世界的仿真环境,也可以是半仿真半虚构的环境,还可以是纯虚构的环境。虚拟环境可以是二维虚拟环境、2.5维虚拟环境和三维虚拟环境中的任意一种,本申请对此不加以限定。下述实施例以虚拟环境是三维虚拟环境来举例说明。
可选的,该虚拟环境可以提供虚拟角色的对战环境。示例性的,在大逃杀类型游戏中,至少一个虚拟角色在虚拟环境中进行单局对战,虚拟角色通过躲避敌方单位发起的攻击和虚拟环境中存在的危险(比如,毒气圈、沼泽地等)来达到在虚拟环境中存活的目的,当虚拟角色在虚拟环境中的生命值为零时,虚拟角色在虚拟环境中的生命结束,最后顺利通过关卡内的路线的虚拟角色是获胜方。每一个客户端可以控制虚拟环境中的一个或多个虚拟角色。
虚拟角色:是指虚拟环境中的可活动对象。该可活动对象可以是虚拟人物、虚拟动物、 动漫人物、虚拟机甲等,比如:在三维虚拟环境中显示的人物、动物、机甲。可选地,虚拟角色是基于动画骨骼技术创建的三维立体模型。每个虚拟角色在三维虚拟环境中具有自身的形状和体积,占据三维虚拟环境中的一部分空间。在一些实施例中,虚拟角色是腿数量为2的人形虚拟角色。在另一些实施例中,虚拟角色可以是腿数量大于2的多足虚拟角色,比如多足虚拟机甲。
图1示出了本申请一个示例性实施例提供的计算机系统的结构框图。该计算机系统100包括:第一终端120、服务器140、第二终端160和第三终端180。
第一终端120安装和运行有支持虚拟环境的应用程序。该应用程序可以是三维地图程序、横版射击、横版冒险、横版过关、横版策略、虚拟现实(Virtual Reality,VR)应用程序、增强现实(Augmented Reality,AR)程序中的任意一种。第一终端120是第一用户使用的终端,第一用户使用第一终端120控制位于虚拟环境中的第一虚拟角色进行活动,该活动包括但不限于:调整身体姿态、行走、奔跑、跳跃、骑行、驾驶、瞄准、拾取、使用投掷类道具、攻击其他虚拟角色中的至少一种。示例性的,第一虚拟角色是第一虚拟人物,比如仿真人物对象或动漫人物对象。示例性的,第一用户可以通过虚拟环境画面上的UI控件来控制第一虚拟角色进行活动,第一用户也可以通过操作与第一终端120连接的输入控制设备来控制第一虚拟角色进行活动。
第一终端120通过无线网络或有线网络与服务器140相连。
服务器140包括一台服务器、多台服务器、云计算平台和虚拟化中心中的至少一种。示例性的,服务器140包括处理器144和存储器142,其中,处理器144的数量可以为1个或多个;存储器142又包括接收模块1421、控制模块1422和发送模块1423,接收模块1421用于接收客户端发送的请求,如侦查敌方虚拟角色的位置请求;控制模块1422用于控制虚拟环境画面的渲染;发送模块1423用于向客户端发送响应,如向客户端发送第三虚拟角色的位置。服务器140用于为支持三维虚拟环境的应用程序提供后台服务。可选地,服务器140承担主要计算工作,第一终端120、第二终端160和第三终端180承担次要计算工作;或者,服务器140承担次要计算工作,第一终端120、第二终端160和第三终端180承担主要计算工作;或者,服务器140、第一终端120、第二终端160和第三终端180四者之间采用分布式计算架构进行协同计算。
第二终端160安装和运行有支持虚拟环境的应用程序。第二终端160是第二用户使用的终端,第二用户使用第二终端160控制位于虚拟环境中的第二虚拟角色进行活动。第三终端180安装和运行有支持虚拟环境的应用程序。第三终端180是第三用户使用的终端,第三用户使用第三终端180控制位于虚拟环境中的第三虚拟角色进行活动。
可选地,第一虚拟角色、第二虚拟角色和第三虚拟角色处于同一虚拟环境中。第一虚拟角色和第二虚拟角色属于不同阵营,第二虚拟角色和第三虚拟角色属于同一阵营,例如,第一虚拟角色属于阵营A,第二虚拟角色和第三虚拟角色属于B。
可选地,第一终端120、第二终端160和第三终端180上安装的应用程序是相同的, 或三个终端上安装的应用程序是不同操作系统平台(安卓或IOS)上的同一类型应用程序。第一终端120可以泛指多个终端中的一个,第二终端160可以泛指多个终端中的一个,第三终端180可以泛指多个终端中的一个,本实施例仅以第一终端120、第二终端160和第三终端180来举例说明。第一终端120、第二终端160和第三终端180的设备类型相同或不同,该设备类型包括:智能手机、智能手表、智能电视、平板电脑、电子书阅读器、MP3播放器、MP4播放器、膝上型便携计算机和台式计算机中的至少一种。以下实施例以终端包括智能手机来举例说明。
本领域技术人员可以知晓,上述终端的数量可以更多或更少。比如上述终端可以仅为一个,或者上述终端为几十个或几百个,或者更多数量。本申请实施例对终端的数量和设备类型不加以限定。
行走动画是用于模拟使用虚拟角色的n条腿进行行走运动的动画,n为大于1的整数。简单来讲,行走运动就是每条腿交替运动的不断循环,图2示出了人形的虚拟角色在步行循环时的示意图。腿的运动会分为支撑阶段(stance phase)和摆动阶段(swing phase)。在支撑阶段,脚部会贴合地面,借助与地面之间的静摩擦力来推动身体前进;而在摆动阶段,脚部会迈向身体将要前进的方向,寻找合适的落脚点为下一次支撑做准备。在一个行走循环中,每一条腿都会经历一次这两个阶段,并且为了保持身体的平衡,各条腿的支撑阶段会相互错开,本申请将这种各条腿之间的协作称为步态(gait),而完成这个循环所需要的时间,就是步态周期。
本申请提出了一种采用程序化生成虚拟角色的行走动画的技术方案,能够在虚拟角色的不同运动状态下,采用程序化生成与当前运动状态所适配的行走动画,以消除传统动画制作方式中出现的“滑步”问题。
图3示出了本申请一个示意性实施例示出的虚拟角色的行走动画生成方法的流程图。虚拟角色的行走动画生成方法可以由计算机设备执行,如终端和服务器等计算机设备中的至少一种,本实施例以该方法由终端执行来举例说明。该方法包括:
步骤302:根据虚拟角色的移动速度和移动方向,预测虚拟角色的每条腿的落脚点;
在不同的运动状态下,虚拟角色的移动速度不同。运动状态包括:行走、跑动、匍匐前进等情况中的至少一种。虚拟角色的移动方向可以由用户(玩家)手动控制。在不同的移动速度和移动方向的情况下,虚拟角色的行走动画也是存在差异的。
现实生活中的人类在行走时,是通过双脚蹬踩地面来推动身体的前进,也即“行走”导致“移动”。而在虚拟世界中恰好相反,虚拟角色的移动通常是由移动系统来直接控制,为了让虚拟角色看起来是在“行走”而非“滑行”,才为虚拟角色加入了行走动画,也即“移动”导致“行走”。在制作行走动画时,通常都会基于虚拟角色在游戏中的移动速度来量身打造,这样才能让虚拟角色的行走动画符合现实生活中的人类的行走方式。“脚步”匹配“移动”是运动动画的基础目标。
由于脚在支撑阶段的位置是不会发生变化的,因此对脚步运动的计算就主要集中在摆 动阶段。摆动阶段本质上就是脚从抬脚点到落脚点的运动过程,只要能知道抬脚点和落脚点的位置,就可以通过插值的方式来不断更新脚部在摆动过程中的位置。
终端根据虚拟角色的移动速度和移动方向,预测虚拟角色的每条腿的多个落脚点或落脚点序列。针对相邻的2个落脚点,在前的落脚点是后一个落脚点对应的抬脚点。
假设虚拟角色有n条腿,n为大于1的整数,则分别预测虚拟角色的每条腿的落脚点序列。其中,至少两条腿的摆动阶段是交替出现的。比如,人形的虚拟角色的2条腿的摆动阶段是交替出现的;又比如,具有8条腿的螃蟹机甲中,奇数腿和偶数腿的摆动阶段是交替出现的。
步骤304:根据每条腿的相邻两个落脚点计算每条腿的脚部在摆动阶段中的位置;
针对一次摆动阶段,在每条腿的相邻两个落脚点确定的情况下,脚部的抬脚点和落脚点已被确定。在摆动阶段的抬脚点和落脚点已知的情况下,基于摆腿曲线能够计算到每条腿的脚部在摆动阶段中的位置。
步骤306:基于每条腿的脚部在摆动阶段中的位置进行反向动力学计算,得到每条腿的骨骼点在摆动阶段的位置;
在虚拟角色的每条腿上存在多个骨骼点。骨骼点通常位于腿部骨骼的关节处,如图4所示,在各种各样的腿部结构中,每条腿可以有3-4个骨骼点。其中,靠近躯干的腿部骨骼为父骨骼,靠近脚部的腿部骨骼为子骨骼。
在正向动力学(Forward Kinematics,FK)中,由父骨骼的方位和子骨骼的相对变换得到子骨骼的方位,也即先确定大腿的位置,再基于大腿的运动确定小腿和脚部的位置。而在反向动力学(Inverse Kinematics,IK)中,则是先确定子骨骼的方位,反向推导出其继承链上n级父骨骼的方位,也即先确定出脚部的位置,再反向推导出小腿和大腿的位置。
步骤308:基于每条腿的骨骼点在摆动阶段的位置进行步态融合,生成虚拟角色的行走动画。
在虚拟角色的n条腿中存在至少两条腿的摆动阶段是交替出现的。设步态周期=摆动阶段的时长+支撑阶段的时长,由于各条腿的步态进度可能不同,因此各个腿的步态进度可能不同。
在计算得到每条腿的骨骼点在摆动阶段的位置后,需要通过步态管理将各条腿的步态进度进行步态融合,使得虚拟角色能够合理调用各条腿进行行走运动。如图5所示,将4条腿的步态循环看做是一条环形的进度条,他们会各自在进度条上安排支撑阶段和摆动阶段所占的段落,而整个步态进度就像一根指针,该指针以统一的角速度来推进各条腿的步态进度的更新。
示意性的,图5所示的步态管理过程可采用一组步态参数来表示,步态参数包括:步态周期、每一条腿的起步时间点、摆动周期、步伐中点、摆动高度中的至少一种。其中,起步时间点是摆动阶段的抬脚时间;摆动周期是一次摆动阶段的时长;步伐中点是指一次 支撑阶段中的中点位置;摆动高度是指脚部在单次摆动阶段时的摆动最高高度。步态参数中的每个参数均可以自定义设置或自定义调节,以使得虚拟角色的行动动画符合设计预期。
基于步态管理对每条腿的骨骼点在摆动阶段的位置进行程序化融合,生成n条腿的行走动画。
综上所述,本实施例提供的方法,通过先根据虚拟角色的移动速度和移动方向进行各条腿的脚部运动计算,再进行各条腿的步态融合,能够基于程序化形式来生成n条腿的行走动画。不论虚拟角色处于何种移动速度和移动方向,总是能适配生成相应的行走动画,不会出现传统的动画混合所导致的滑步问题。
并且,本实施例提供的方法能直接适用于不同风格或不同形态的虚拟角色,在具有不同虚拟角色的动画生成过程中,不再需要为不同的虚拟角色的运动编写对应的运动动画逻辑,能够有效提高动画生成效率。
图6示出了本申请一个示意性实施例示出的虚拟角色的行走动画生成方法的流程图。本实施例以该方法由终端执行来举例说明。该方法包括:
步骤602:根据虚拟角色的移动速度和移动方向,预测虚拟角色在地图中的预测移动轨迹;
当虚拟角色处于稳定的步态中时,步态周期就等于任意一条腿的支撑阶段和摆动阶段的时长之和,而支撑阶段和摆动阶段在整个步态周期中所占的时间比例,也是一个常量值k。其中,k可以根据需要自行配置。
T 支撑=T·k
T 摆动=T·(1-k)
其中,T 支撑是一个步态周期中支撑阶段的时长,T 摆动是一个步态周期中摆动阶段的时长。而虚拟角色在一个步态循环的起点和终点所呈现的姿势应该是相同的,因此脚部的位移S 摆动就等同于虚拟角色本身的位移S 身体,由于在支撑阶段中脚部的绝对位置并不发生改变,因此脚部的所有位移都是在摆动阶段所产生的。
S 支撑=0
S 摆动=S 身体
由于摆动阶段的本质就是脚部从抬脚点到落脚点的运动过程,只要能知道抬脚点和落脚点的位置,就可以通过插值的方式(按照每帧的帧间隔时长来周期性插值)来不断更新脚在摆动过程中的位置。抬脚点是已知的,接下来的主要问题就是如何来预测落脚点的位置。
对于虚拟角色的位移,可以直接通过虚拟角色的移动速度进行估算,也可以利用客户端(比如游戏)本身提供的移动系统(如虚幻引擎4中的Movement Component)来进行更精确预测。示意性的,以微小的时间步长(如0.2秒)将虚拟角色以当前的移动速度和移动方向进行数次模拟移动,从而得到一条预测移动轨迹T raj,示意性的,该预测移动轨迹上的多个采样点如图7中的P 0-P 8
Traj={P 0,P 1,P 2…P n}
其中,n为整数。P i为预测移动轨迹上的第i个采样点。两个相邻的采样点之间的时间步长为预设值。
步骤604:以虚拟角色的每条腿的当前姿态为预测起点,在预测移动轨迹上采样出每条腿的落脚点;
结合参考图7,假设虚拟角色包括n条腿,步态周期等于摆动阶段的时长T 摆动和支撑阶段的时长T 支撑。本步骤可以包括如下子步骤:
在虚拟角色的第i条腿的当前姿态为摆动阶段的第t秒状态的情况下,计算摆动阶段的剩余时长和半个支撑阶段的时长之和为预测时长。
其中,摆动阶段的剩余时长为(T 摆动-t),半个支撑阶段的时长为1/2*T 支撑,则预测时长t'=(T 摆动-t)+1/2*T 支撑
以虚拟角色的当前姿态在预测移动轨迹上的位置为起点,将沿预测移动轨迹上前进预测长度的位置,确定为虚拟角色在落脚时的身体位置,预测长度等于预测时长和移动速度的乘积。
Figure PCTCN2022127073-appb-000001
P 步伐中点=Traj(t′)
F 落脚点=P 步伐中点+F local
基于虚拟角色在落脚时的身体位置以及相对位置关系,推算出虚拟角色的第i条腿在预测移动轨迹上的落脚点。
其中,i为小于或等于n的正整数,相对位置关系是预配置的虚拟角色的身体与第i条腿之间的相对位置。在上述公式中,P代表虚拟角色躯干的位置,F代表虚拟角色脚部的位置。
也即,假设针对虚拟角色的第i条腿处于摆动阶段开始后的第t秒,如果将剩余的摆动时长(T 摆动-t)传入预测移动轨迹进行采样,即可得到在第i条腿的脚部在落地时,虚拟角色所在的位置及朝向信息。只要能知道在脚部落地时,虚拟角色的脚部和躯干的相对位置,就可以推算出落脚点。但本实施例并没有掌握此时的相对位置,但有一个类似的信息是可以得知的,就是这条腿的步伐中点P 步伐中点。所谓步伐中点,就是指起脚点和落脚点连线的中点,当以虚拟角色躯干为参考系时,可以看到整个步态循环就是脚部围绕这个步伐中点进行前后运动的循环。从动画层面看,步伐中点与虚拟角色躯干的相对位置会直接影响虚拟角色在行走时的姿态表现,因此本实施例也将步伐中点与虚拟角色躯干的相对位置作为一个配置参数F local,由动画师预先配置或调整。
因此,本实施例可以将落脚点的采样时间点再往后推半个支撑阶段的时长,在这个推迟后的采样时间点上,脚部正好处于步伐中点的位置上,本实施例采样得到此时的虚拟角色躯干信息后就可以推算出脚部的位置。由于整个支撑阶段的脚部的绝对位置都不会发生变化,此时计算得到的脚部位置即为想要预测的落脚点。
步骤606:基于相邻两个落脚点的位置确定摆腿曲线;
摆腿曲线用于指示脚部在摆动阶段的摆动轨迹。在通常情况下,摆腿曲线采用抛物线70来表示,如图7所示。抛物线的两个端点分别为抬脚点和落脚点,抛物线高度h也即脚部在摆动阶段的最高摆动高度,该最高摆动高度也可以由动画师预先配置或调节。
步骤608:基于摆腿曲线对每条腿的脚部进行插值计算,计算得到每条腿的脚部在摆动阶段的位置;
Figure PCTCN2022127073-appb-000002
其中,F t是每条腿的脚部在摆动阶段的第t秒时的位于摆腿曲线上的位置。示意性的,时间t的步长可以按照显示帧的帧间隔来确定,比如每秒60帧,则t的步长为1/60秒。
步骤610:基于每条腿的脚部在摆动阶段中的位置进行反向动力学计算,得到每条腿的骨骼点在摆动阶段的位置;
在虚拟角色为多足机甲的情况下,可能为多足机甲设计各种各样的腿部结构,常用于人类角色的两步反向动力学(Inverse Kinematics,IK)并不适合多足机甲,对于多足机甲,可以采用循环坐标下降反向动力学(Cyclic Coordinate Decent Inverse Kinematics,CCDIK)或前向和后向到达反向动力学(Forward and Backward Reaching Inverse Kinematics,FABRIK)算法进行计算。也即,根据每条腿的脚部在摆动阶段中的位置进行CCDIK计算,得到每条腿的骨骼点在摆动阶段的位置;或,根据每条腿的脚部在摆动阶段中的位置进行FABRIK计算,得到每条腿的骨骼点在摆动阶段的位置。CCDIK算法和FABRIK算法都至少具备以下的优点:
优先1:支持任意多的关节,为腿部结构设计提供了较大的发挥空间。
优点2:支持关节旋转的角度限制,可以实现机甲特定的机械关节结构。
优点3:性能较好,可以满足游戏实时运算的需要。
经过实验对比,在虚拟角色为多足机甲的情况下,FABRIK在仿蹄形的腿部结构上表现会优于CCDIK,因此,对于腿部结构为仿蹄形的多足机甲,可以采用FABRIK算法计算多足机甲每条腿的骨骼点在摆动阶段的位置。
步骤612:获取预配置的步态参数;
步态参数为步态融合中使用的一组参数。针对同一个虚拟角色,步态参数为一组或多组,步态参数的组数具体可以根据虚拟角色的运动状态的数量或是移动方向的数量等来确定。
示意性的,不同组的步态参数对应不同的运动状态,比如潜行状态对应第一组步态参数,步行状态对应第二组步态参数,奔跑状态对应第三组步态参数。
示意性的,不同组的步态参数对应不同的移动方向,比如向北移动对应第一组步态参数,向南移动对应第二组步态参数,向东移动对应第三组步态参数,向西移动对应第四组步态参数。
本实施例中,步态参数为一组来举例说明。如图8所示,步态参数包括:步态周期和 脚部参数列表。可选地,脚部参数列表包括:摆动开始、摆动周期、摆动高度和步伐中点中的至少一种。其中,摆动开始是摆动阶段的起步时间点,也即抬脚时间;摆动周期是一次摆动阶段的时长;摆动高度是指脚部在单次摆动阶段时的摆动最高高度;步伐中点是指一次支撑阶段中的中点位置。
步骤614:基于步态参数对每条腿的骨骼点在摆动阶段的位置进行步态融合,生成虚拟角色的行走动画。
在虚拟角色的n条腿中存在至少两条腿的摆动阶段是交替出现的。设步态周期=摆动阶段的时长+支撑阶段的时长,由于各条腿的步态进度可能不同,因此各个腿的步态进度可能不同。
在计算得到每条腿的骨骼点在摆动阶段的位置后,需要通过步态管理将各条腿的步态进度进行步态融合,使得虚拟角色能够合理调用各条腿进行行走运动。如图5所示,将4条腿的步态循环看做是一条环形的进度条,他们会各自在进度条上安排支撑阶段和摆动阶段所占的段落,而整个步态进度就像一根指针,该指针以统一的角速度来推进各条腿的步态进度的更新。
示意性的,图5所示的步态管理过程可采用一组步态参数来表示,步态参数包括:步态周期(的总时长)、每一条腿的起步时间点、摆动周期、步伐中点、摆动高度中的至少一种。其中,步态参数中的每个参数均可以自定义设置或自定义调节,以使得虚拟角色的行动动画符合设计预期。
示意性的,步态参数包括:步态周期的总时长和每条腿在步态周期内的腿部参数;在步态周期的总时长内,按照每条腿在步态周期内的腿部参数对每条腿的骨骼点在摆动阶段的位置进行步态融合,生成虚拟角色的各条腿的行走动画。
终端显示虚拟角色的各条腿的行走动画。示意性的,上述计算过程可以按照逐帧实时计算,也可以预先计算好多帧的计算结果进行缓存,按照缓存的计算结果进行显示。本实施例对此不加以限定。
综上所述,本实施例提供的方法,通过先根据虚拟角色的移动速度和移动方向进行各条腿的脚部运动计算,再进行各条腿的步态融合,能够基于程序化形式来生成n条腿的行走动画。不论虚拟角色处于何种移动速度和移动方向,总是能适配生成相应的行走动画,不会出现传统的动画混合所导致的滑步问题。并且,在具体的应用过程中,以游戏虚拟角色为例,通过简单的参数配置快速地对虚拟角色的运动进行调整,迅速在游戏中进行玩法验证。
由于不同组的步态参数对应不同的运动状态,比如潜行状态对应第一组步态参数,步行状态对应第二组步态参数,奔跑状态对应第三组步态参数。在一些实施例中,步态参数包括在第一运动形态下的第一步态参数(组)和在第二运动形态下的第二步态参数(组)。如图9所述,上述方法还包括:
步骤616:将第一步态参数和第二步态参数进行插值,得到第一混合步态参数;
可选的,插值可以基于虚拟角色所在虚拟环境的动画显示帧率实现。在一些实施例中,基于从第一运动形态切换至第二运动形态的过渡动画的时长和帧率确定插值次数,按照差值次数对第一步态参数A和第二步态参数B进行插值处理,得到第一混合步态参数。
假设从第一运动形态切换至第二运动形态的过渡动画的时长为n秒,每秒的帧数为m帧,则可以将第一步态参数A和第二步态参数B进行n*m次插值,得到与每帧对应的第一混合步态参数。
如图10所示,在第i次插值时,第一混合步态参数=(1-α)*第一步态参数A+α*第二步态参数B,α的取值范围为0到1。α分为n*m次,逐渐从0增加到1。也即,第一混合步态参数包括n*m组步态参数,展示了从第一运动形态切换至第二运动形态的渐变过程。其中,不同的运动状态的渐变程度可以不同,例如潜行状态对应第一渐变程度,步行状态对应第二渐变程度,奔跑状态对应第三渐变程度等。
步骤618:基于第一混合步态参数对每条腿的骨骼点在摆动阶段的位置进行步态融合,生成虚拟角色从第一运动形态切换至第二运动形态的过渡动画。
在过渡动画之前,终端显示第一运动形态下的第一行走动画,该第一行走动画是基于第一步态参数(组)生成的;在过渡动画之后,终端显示第二运动形态下的第二行走动画,该第二行走动画是基于第二步态参数(组)生成的。
综上所述,本实施例提供的方法,通过不同组的步态参数之间的一维维度融合,实现了不同运动状态之间的平滑过渡效果,使得终端所显示的虚拟角色在不同运动状态切换时,呈现较为流畅和顺滑的动作变化。
由于不同组的步态参数对应不同的移动方向,比如向北移动对应第一组步态参数,向南移动对应第二组步态参数,向东移动对应第三组步态参数,向西移动对应第四组步态参数。在一些实施例中,步态参数包括在第一移动方向下的第三步态参数(组)和在第二移动方向下的第四步态参数(组);如图11所示,所述方法还包括:
步骤620:将第三步态参数和第四步态参数进行插值,得到第二混合步态参数;
假设从第一运动形态切换至第二运动形态的过渡动画的时长为n秒,每秒的帧数为m帧,则可以将第三步态参数C和第四步态参数D进行二维插值,得到与第三移动方向对应的第二混合步态参数。
其中,第三移动方向是位于第一移动方向和第二移动方向之间的移动方向。
示意性的,设虚拟角色在原地不同时的步态参数为第五步态参数O。第二混合步态参数的计算过程如下:
α=第一移动方向的当前速度/第一移动方向的最大速度;
β=第二移动方向的当前速度/第二移动方向的最大速度;
第一中间步态参数C'=(1-α)*O+α*C;
第二中间步态参数D'=(1-β)*O+β*D;
设γ=β/(α+β),最后得到:
第二混合步态参数=(1-γ)*C'+γ*D'。
也即,第一权重α等于第一移动方向的当前速度除以第一移动方向的最大速度,第二权重β/等于第二移动方向的当前速度除以第二移动方向的最大速度。采用第一权重对第三步态参数和第五步态参数进行融合,得到第一中间步态参数;采用第二权重对第四步态参数和第五步态参数进行融合,得到第二中间步态参数。计算第三权重为β/(α+β);采用第三权重对第一中间步态参数和第二中间步态参数进行混合,得到第二混合步态参数。
步骤622:基于第二混合步态参数对每条腿的骨骼点在摆动阶段的位置进行步态融合,生成虚拟角色的每条腿在第三移动方向的行走动画。
在过渡动画之前,终端显示第一移动方向下的行走动画,该第一移动方向下的行走动画是基于第三步态参数(组)生成的;在过渡动画之后,终端显示第二移动方向下的行走动画,该第二移动方向下的行走动画是基于第四步态参数(组)生成的。第三移动方向位于第一移动方向和第二移动方向之间,基于第三移动方向可以实现从第一移动方向到第二移动方向的平滑过渡。
综上所述,本实施例提供的方法,通过不同组的步态参数之间的二维维度融合,实现了不同运动状态之间的平滑过渡效果,使得终端所显示的虚拟角色在不同运动状态切换时,呈现较为流畅和顺滑的动作变化。
也即,除了图9所示的这种一维的混合,也可以像动画一样提升混合的维度。例如虚拟角色在不同方向上的移动——前进、平移、后退动作,通常游戏会采用不同的动画表现,动画师会制作4或8个方向的移动动画序列,通过动画混合空间进行二维动画混合。步态混合也可以遵循同样的原理,动画师为各个移动方向配置对应的步态参数集。在客户端的运行过程中,终端会根据虚拟角色的移动方向及速度,对步态参数进行二维维度的混合。
由于直接使用抛物线作为摆腿曲线得到的表现较为呆板。为了解决这个问题,在一些实施例中,对插值的过程进行了改进,对于插值的α系数引入了一条基于时间的曲线进行控制。比如在水平方向上,可以用一条先加速再减速的曲线来确定插值的α系数,如图12的左图(1),也即在摆腿阶段的第t秒,确定脚部在水平方向上的位置为:F 抬脚点+α*(F 落脚点-F 抬脚点);而在垂直方向上的摆动高度,可以在落地前增加一段重新抬升的曲线再迅速落下,如图12的右图(2),也即在摆腿阶段的第t秒,确定脚部在垂直方向上的位置为与时刻t对应的h。这些的变化综合起来会使整个摆腿动作显得更有力量感。
在另一些实施例中,本实施例可以在动画师制作的行走动画中,对脚部骨骼的运动数据进行记录,以生成对应的摆腿曲线。也可以让动画师来直接手动编辑这条摆腿曲线,一些游戏引擎中提供了曲线编辑器,动画师可以很方便地在上面进行操作。
在另一些实施例中,身形庞大的机甲在行进时,会迈过那些比较矮小的障碍物,为了避免摆腿路线中所产生的三维模型穿插,根据障碍物对摆腿曲线也要做一个偏移。在虚拟角色的身体下方存在障碍物的情况下,基于相邻两个落脚点的位置和障碍物的最高点确定样条曲线;将样条曲线与摆腿曲线进行叠加,得到更新后的摆腿曲线。样条曲线是经过一 系列给定点的光滑曲线,给定点即为相邻两个落脚点和障碍物的最高点,示意性的,如图13所示,以摆腿距离作为长度,脚部宽度作为半径来构造一个水平方向的胶囊体1320,将这个胶囊体1320从上往下做一次碰撞检测,获得地面上所有的碰撞凸点。因为只需要考虑那些会阻挡摆腿曲线的凸点,所有高度低于摆腿曲线的凸点可以先过滤掉,利用剩下的凸点生成一条样条曲线,并与原本的摆腿曲线进行叠加,就可以得到一条新的路线,让虚拟机甲可以迈过这些障碍物。
上述实施例说明了由纯程序化的方式来生成虚拟角色的行走动画,通过这种方法可以得到基本正确的表现效果。但作为一个优质的游戏而言,仅仅正确是远远不够的。一个虚拟角色的举手投足,都是表现这个虚拟角色的个性特征的载体。以本申请实施例提及的大型多组机甲为例,它是笨重的、还是灵活的,正是要通过它的行走动作来表现出来的。因此在接下来的内容中,本申请实施例主要考虑的事情就是如何让角色的动画显得更加生动。在一些实施例中,如图14所示,上述方法还包括:
步骤624:获取虚拟角色的躯干动画。
如果不考虑“滑步”的问题,预制作的动画序列无疑是最佳的表现手段,动画师可以通过3ds Max或Maya等动画制作工具,将他们所有的想法都表达出来。虽然上述实施例是通过程序化的方式来生成动画序列,但如果能把动画序列结合进来,无疑会对最终的表现效果有巨大提升,以使得虚拟角色的行走动作所表现出来的动画更加生动。
因此,动画师仍然会照常地为虚拟角色制作某一运动形态下的运动动画,该运动动画包括:对应身体部分的躯干动画和对应腿部的行走动画。本实施例中,将动画师制作的运动动画中的行走动画进行移除,剩余得到的动画部分即为虚拟角色的躯干动画。
步骤626:将虚拟角色的躯干动画与每条腿的行走动画进行融合,得到虚拟角色的整体移动动画。
然后,将动画师制作的躯干动画与程序计算的行走动画进行融合。大部分游戏引擎都提供了相应的动画工具链。以虚幻引擎4为例,可以在动画蓝图中,在躯干动画的基础上,传入计算好的行走动画,最后输出虚拟角色的整体移动动画。
躯干动画需要与行走动画的步态周期保持同步。由于游戏中的步态周期可能动态发生变化,本实施例会实时地将躯干动画进行缩放,确保躯干动画的长度与步态周期保持一致,并直接将步态进度作为躯干动画的播放进度。
示意性的,将虚拟角色的躯干动画的动画时长按照步态周期进行缩放,得到缩放后的躯干动画。其中,缩放后的躯干动画的动画时长等于步态周期的时长。将缩放后的躯干动画与每条腿的行走动画进行融合,得到虚拟角色的整体移动动画。
综上所述,本实施例提供的方法,通过将虚拟角色的躯干动画与每条腿的行走动画进行融合,能够使得虚拟角色的躯干和腿部均有与行走过程适配的动画效果,整体的运动视觉表现更为生动和逼真。
除了尽可能地还原动画序列的效果,还可以为虚拟角色添加一些体现惯性的物理模拟 来进一步增加表现的真实感,比如虚拟角色在启停或转向的过程中,身体上的一些部位(比如触角、线缆、武器、挂件等)会随着速度变化的方向产生惯性摆动。在一些实施例中,如图15所示,上述方法还包括:
步骤628:在虚拟角色的身体上存在弹性部件的情况下,确定弹性部件在虚拟角色的骨骼树中对应的至少两级骨骼节点;
弹性部件是虚拟角色在启停或转向的过程中,可以随着速度变化的方向产生惯性摆动的部件,虚拟角色的骨骼树是基于虚拟角色中的各个骨骼的重要性所建立的树。在一个示例中,在至少两级骨骼节点中,靠近身体中心的骨骼节点的层级高于靠近身体末端的骨骼节点的层级。
步骤630:从至少两级的骨骼节点中的根节点开始,以上一级骨骼节点为原点、下一级骨骼节点为振子进行三维振动模型的振动计算,确定下一级骨骼节点的骨骼更新位置,直至更新得到弹性部件的骨骼更新位置。
对于某一根骨骼而言,在受到惯性影响时,该骨骼会绕着父骨骼朝惯性方向转动,与此同时该骨骼会受到一个回归力把它拉回原本的朝向。如图16的左图所示。
在这个振动模型中,将正上方视为最终所要到达的稳定朝向。当前骨骼与父骨骼之间的距离固定为L,当前骨骼在水平方向上的投影视为振子,当前骨骼围绕父骨骼摆动的过程就是它投影所对应的振子进行振动的过程。设定振子本身的质量为m,振动系统的劲度系数为k,阻尼系数为c。假设振子当前的位置为x,根据牛顿第二定律,得到此时的力平衡方程为:
Figure PCTCN2022127073-appb-000003
其中,
Figure PCTCN2022127073-appb-000004
代表振子的当前速度,
Figure PCTCN2022127073-appb-000005
代表振子的加速度。然后定义参量ω 0为系统的固有频率,ζ为阻尼比,满足方程:
Figure PCTCN2022127073-appb-000006
代入前面的方程,得到公式(1):
Figure PCTCN2022127073-appb-000007
振子会来回摆动,且振幅越来越小,最后无限趋近于平衡。设定初始振幅为
Figure PCTCN2022127073-appb-000008
随着时间推移,振幅A(t)满足方程:
Figure PCTCN2022127073-appb-000009
变化后得到:
Figure PCTCN2022127073-appb-000010
设定
Figure PCTCN2022127073-appb-000011
来表示振幅在t时刻相对于初始振幅的比例,可以界定当这个比例缩小到一定程度时,振子进入稳定状态,而此刻的时间点记为t s,得到公式(2):
Figure PCTCN2022127073-appb-000012
振子进入稳定状态所需的时间t S以及阻尼比ζ是能比较直观理解的参数,将它们作为配置参数来让动画师控制系统的表现效果。固有频率ω 0可以通过上面的公式来求得。将ζ和ω 0代入公式(1)后得到位置、速度与加速度之间的关系,再以固定的时间步长Δt通过粒子运动模拟(Verlet)方法对振动过程进行积分,来更新振子的位置:
Figure PCTCN2022127073-appb-000013
Figure PCTCN2022127073-appb-000014
到这里完成了振动模型的计算,接下来要将这个振动模型三维化。对于三维空间中的骨骼,将它在X轴与Y轴上的投影都作为振子,各自沿其所在轴向进行振动,如图16的右图所示。
分别在X轴与Y轴上完成振动计算得到x(t+Δt)与y(t+Δt),在XY平面上所构成的向量V XY=[x(t+Δt),y(t+Δt),0],其长度记为L XY=|V XY|,由此可以得到骨骼所在的位置向量V为:
Figure PCTCN2022127073-appb-000015
完成上述计算步骤后,便得到了一个三维的振动模型,最后将这一模型应用于角色骨架上。对于每一对父子骨骼,都可以视作一个以父骨骼为原点、子骨骼为振子的三维振动模型。在骨架中选择需要受惯性影响的骨骼树后,从根节点开始,逐级向叶子节点进行计算,这样被作为振子的骨骼更新位置后又成为下一级骨骼的振动原点,从而对下一级骨骼的振动计算产生连带影响,形成逐级递进的惯性效果,如图17所示。
采用这种简化后的振动模型能够在较少的计算量的情况下,在用户视觉上获得较为逼真的惯性振动表现。
上述实施例都是基于平地的行走运动表现,而虚拟世界中会有各种蜿蜒起伏的地形,接下来就要考虑地形对行走运动的影响。
以非平地的落脚点修正为例,如图18所示,首先来让脚部的落角点能正确地落在凹凸不平的地表上。从之前所计算的平地的落脚点F` 落脚点出发,在垂直方向上找到一个贴地点G,将贴地点G与抬脚点F进行连线。假设平地上所选的落脚点应该是摆腿所能到达的最大距离,简称摆腿距离。因此还要用摆腿距离在新的连线上截取一个参考点,然后重新 对参考点做一次贴地,得到新的落脚点F 落脚点。也即,在落脚点F` 落脚点所在的地面为非平整地面的情况下,计算落脚点F` 落脚点在非平整地面上沿垂直方向的第一投影点G;在落脚点F` 落脚点和第一投影点G的连线上,基于摆腿距离截取出参考点;将参考点在非平整地面上沿垂直方向的第二投影点,作为更新后的落脚点F 落脚点。采用这种落脚点修正技术,能够使得脚部的落角点能正确地落在凹凸不平的地表上。
另外,如图19所示,还需要根据当前落脚点的地面的法线方向,对脚部做一个旋转。由于脚部是有一定厚度的,要连带拉动脚部骨骼F的位置偏移,在将落脚点位置作用于动画时,不能遗漏这一段偏移。也即,根据更新后的落脚点(即当前落脚点)所在的地面的法线方向,对脚部在落脚时的姿态进行偏转,使得脚部的脚掌平面与当前落脚点的地面的法线方向垂直。
对于腿比较多的虚拟角色,每条腿对躯干的支撑点(即腿根部)之间有一定距离,就需要考虑各条腿站在不同高度时所带动的身体倾斜。终端计算虚拟角色的各条腿的支撑向量,支撑向量用于指示当前腿的落脚点相对于虚拟角色的躯干的倾斜度;基于各条腿的支撑向量,计算虚拟角色的躯干的姿态角;基于姿态角对虚拟角色的躯干进行倾斜补偿。其中,姿态角包括偏航角yaw、俯仰角pitch和横滚角roll。
图20中展示了虚拟角色以倾斜姿态站立时的矢面视角,从虚拟角色躯干所在的地面位置O点出发,向脚部所在的位置F做连接,获得
Figure PCTCN2022127073-appb-000016
所在的平面后,再从躯干的支撑点H引一条垂线与平面相交得到交点N,
Figure PCTCN2022127073-appb-000017
即为这条腿相对躯干的支撑向量。
对虚拟角色的每一条腿都进行同样的计算,将所得到的所有腿的支撑向量分别进行前后和左右的分组,根据所有前腿和所有后腿的支撑向量计算躯干的姿态角Pitch,根据所有左腿和右腿的支撑向量计算躯干的姿态角Roll。
在一些实施例中,会出现图21中这种凸面地形,虚拟角色站在顶上的时候,为了保持脚能着地,会形成一个身体拱起的姿势,好像被看不见的东西顶起来一样。因此还需要对躯干的高度进行修正,获取当前状态下每只脚F与虚拟角色的身体位置O的高度差进行平均,就可以得到躯干高度的修正值,然后将这个值作用于虚拟角色的身体骨骼将躯干修正到合理高度,比如升高高度差
Figure PCTCN2022127073-appb-000018
也即,在虚拟角色处于凸型地面上方的情况下,计算虚拟角色的各条腿的落脚点与所述凸型地面的顶点之间的平均高度差;按照平均高度差将虚拟角色的躯干的高度进行升高补偿。这样,虚拟角色站在凸面地形上的躯干高度更符合真实世界中的机甲表现。采用上述方法,从根本上解决了动画混合所带来的的“滑步”问题,在最大程度上保留了预制作动画序列的优质表现,在程序计算的过程中也能方便地插入对地形的适应以及相应的物理模拟,兼得动画序列与程序计算两者的优势。
图22示出了本申请一个示例性实施例提供的虚拟角色的行走动画生成装置的框图。该装置采用硬件或者软硬件的结合应用于终端中,所述虚拟角色的每条腿在行走过程中交替执行摆动阶段和支撑阶段,该装置包括:
预测模块220,用于根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点;
计算模块222,用于根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置;
IK模块224,用于基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置;
融合模块226,用于基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
在本实施例的一个可选设计中,所述融合模块226,用于获取预配置的步态参数;基于所述步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
在本实施例的一个可选设计中,所述步态参数包括:步态周期和所述每条腿在所述步态周期内的腿部参数;所述融合模块226,用于在所述步态周期内,按照所述每条腿在所述步态周期内的腿部参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画;
其中,所述腿部参数包括抬脚时间点、所述摆动阶段的时长、所述支撑阶段的步伐中点中的至少一种。
在本实施例的一个可选设计中,所述步态参数包括在第一运动形态下的第一步态参数和在第二运动形态下的第二步态参数;
所述装置还包括:
过渡模块228,用于将所述第一步态参数和所述第二步态参数进行插值,得到第一混合步态参数;基于所述第一混合步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的每条腿从所述第一运动形态切换至所述第二运动形态的过渡动画。
在本实施例的一个可选设计中,所述步态参数包括在第一移动方向下的第三步态参数和在第二移动方向下的第四步态参数;
所述装置还包括:
过渡模块228,用于将所述第三步态参数和所述第四步态参数进行插值,得到第二混合步态参数;基于所述第二混合步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的每条腿在第三移动方向的行走动画;
其中,所述第三移动方向是位于所述第一移动方向和所述第二移动方向之间的移动方向。
在本实施例的一个可选设计中,所述根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿的落脚点,包括:
根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色在地图中的预测移动轨 迹;
以所述虚拟角色的每条腿的当前姿态为预测起点,在所述预测移动轨迹上采样出所述每条腿的落脚点。
在本实施例的一个可选设计中,所述虚拟角色包括n条腿,所述以所述虚拟角色的每条腿的当前姿态为预测起点,在所述预测移动轨迹上采样出所述每条腿的落脚点,包括:
在所述虚拟角色的第i条腿的当前姿态为所述摆动阶段的第t秒状态的情况下,计算所述摆动阶段的剩余时长和半个所述支撑阶段的时长之和为预测时长;
以所述虚拟角色的当前姿态在所述预测移动轨迹上的位置为起点,将沿所述预测移动轨迹上前进所述预测长度的位置,确定为所述虚拟角色在落脚时的身体位置,所述预测长度等于所述预测时长和所述移动速度的乘积;
基于所述虚拟角色在落脚时的身体位置以及相对位置关系,推算出所述虚拟角色的第i条腿在所述预测移动轨迹上的落脚点;
其中,i为不大于n的正整数,所述相对位置关系是预配置的所述虚拟角色的身体与所述第i条腿之间的相对位置。
在本实施例的一个可选设计中,所述计算模块222,用于基于相邻两个所述落脚点的位置确定摆腿曲线,所述摆腿曲线用于指示所述脚部在所述摆动阶段的摆动轨迹;基于所述摆腿曲线对所述每条腿的脚部进行插值计算,计算得到所述每条腿的脚部在所述摆动阶段的位置。
在本实施例的一个可选设计中,所述IK模块224,用于根据所述每条腿的相邻两个所述落脚点进行CCDIK计算,得到所述每条腿的骨骼点在摆动阶段的位置;或,根据所述每条腿的相邻两个所述落脚点进行FABRIK计算,得到所述每条腿的骨骼点在摆动阶段的位置。
在本实施例的一个可选设计中,所述融合模块226,用于获取所述虚拟角色的躯干动画;将所述虚拟角色的躯干动画与所述每条腿的行走动画进行融合,得到所述虚拟角色的整体移动动画。
在本实施例的一个可选设计中,所述融合模块226,用于将所述虚拟角色的躯干动画按照步态周期进行缩放,得到缩放后的躯干动画;将所述缩放后的躯干动画与所述每条腿的行走动画进行融合,得到所述虚拟角色的整体移动动画。
在本实施例的一个可选设计中,所述计算模块222,还用于在所述虚拟角色的身体上存在弹性部件的情况下,确定所述弹性部件在所述虚拟角色的骨骼树中对应的至少两级骨骼节点;从所述至少两级的骨骼节点中的根节点开始,以上一级骨骼节点为原点、下一级骨骼节点为振子进行三维振动模型的振动计算,确定所述下一级骨骼节点的骨骼更新位置,直至更新得到所述弹性部件的骨骼更新位置。
在本实施例的一个可选设计中,所述预测模块220,还用于在所述落脚点所在的地面为非平整地面的情况下,计算所述落脚点在所述非平整地面上沿垂直方向的第一投影点; 在所述落脚点和所述第一投影点的连线上,基于摆腿距离截取出参考点;将所述参考点在所述非平整地面上沿垂直方向的第二投影点,作为更新后的落脚点。
在本实施例的一个可选设计中,所述预测模块220,还用于根据所述更新后的落脚点所在地面的法线方向,对所述脚部在落脚时的姿态进行偏转。
在本实施例的一个可选设计中,所述融合模块226,还用于计算所述虚拟角色的各条腿的支撑向量,所述支撑向量用于指示当前腿的落脚点相对于所述虚拟角色的躯干的倾斜度;基于所述各条腿的支撑向量,计算所述虚拟角色的躯干的姿态角;基于所述姿态角对所述虚拟角色的躯干进行倾斜补偿。
在本实施例的一个可选设计中,所述融合模块226,还用于在所述虚拟角色处于凸型地面上方的情况下,计算所述虚拟角色的各条腿的落脚点与所述凸型地面的顶点之间的平均高度差;按照所述平均高度差将所述虚拟角色的躯干的高度进行升高补偿。
图23示出了本申请一个示例性实施例提供的计算机设备2300的结构框图。该计算机设备2300可以是便携式移动终端,比如:智能手机、平板电脑、MP3播放器(Moving Picture Experts Group Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(Moving Picture Experts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、笔记本电脑或台式电脑。计算机设备2300还可能被称为用户设备、便携式终端、膝上型终端、台式终端等其他名称。
通常,计算机设备2300包括有:处理器2301和存储器2302。
处理器2301可以包括一个或多个处理核心,比如4核心处理器、8核心处理器等。处理器2301可以采用DSP(Digital Signal Processing,数字信号处理)、FPGA(Field-Programmable Gate Array,现场可编程门阵列)、PLA(Programmable Logic Array,可编程逻辑阵列)中的至少一种硬件形式来实现。处理器2301也可以包括主处理器和协处理器,主处理器是用于对在唤醒状态下的数据进行处理的处理器,也称CPU(Central Processing Unit,中央处理器);协处理器是用于对在待机状态下的数据进行处理的低功耗处理器。在一些实施例中,处理器2301可以集成有GPU(Graphics Processing Unit,图像处理器),GPU用于负责显示屏所需要显示的内容的渲染和绘制。一些实施例中,处理器2301还可以包括AI(Artificial Intelligence,人工智能)处理器,该AI处理器用于处理有关机器学习的计算操作。
存储器2302可以包括一个或多个计算机可读存储介质,该计算机可读存储介质可以是非暂态的。存储器2302还可包括高速随机存取存储器,以及非易失性存储器,比如一个或多个磁盘存储设备、闪存存储设备。在一些实施例中,存储器2302中的非暂态的计算机可读存储介质用于存储至少一个指令,该至少一个指令用于被处理器2301所执行以实现本申请中方法实施例提供的域外网络资源的加速方法。
在一些实施例中,计算机设备2300还可选包括有:外围设备接口2303和至少一个外围设备。处理器2301、存储器2302和外围设备接口2303之间可以通过总线或信号线相 连。各个外围设备可以通过总线、信号线或电路板与外围设备接口2303相连。示例地,外围设备可以包括:射频电路2304、显示屏2305、摄像头组件2306、音频电路2307和电源2308中的至少一种。
在一些实施例中,计算机设备2300还包括有一个或多个传感器2310。该一个或多个传感器2310包括但不限于:加速度传感器2311、陀螺仪传感器2312、压力传感器2313、光学传感器2314以及接近传感器2315。
本领域技术人员可以理解,图23中示出的结构并不构成对计算机设备2300的限定,可以包括比图示更多或更少的组件,或者组合某些组件,或者采用不同的组件布置。
本申请还提供一种计算机可读存储介质,所述存储介质中存储有至少一条指令、至少一段程序、代码集或指令集,所述至少一条指令、所述至少一段程序、所述代码集或指令集由处理器加载并执行以实现上述方法实施例提供的虚拟角色的行走动画生成方法。
本申请提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机可读指令,该计算机可读指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质读取该计算机可读指令,处理器执行该计算机可读指令,使得该计算机设备执行上述方法实施例提供的虚拟角色的行走动画生成方法。
上述本申请实施例序号仅仅为了描述,不代表实施例的优劣。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本申请的可选实施例,并不用以限制本申请,凡在本申请的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本申请的保护范围之内。

Claims (21)

  1. 一种虚拟角色的行走动画生成方法,其特征在于,由计算机设备执行,所述虚拟角色的每条腿在行走过程中交替执行摆动阶段和支撑阶段,所述方法包括:
    根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点;
    根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置;
    基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置;及
    基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
  2. 根据权利要求1所述的方法,其特征在于,所述基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画,包括:
    获取预配置的步态参数;及
    基于所述步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
  3. 根据权利要求2所述的方法,其特征在于,所述步态参数包括:步态周期和所述每条腿在所述步态周期内的腿部参数;
    所述基于所述步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画,包括:
    在所述步态周期内,按照所述每条腿在所述步态周期内的腿部参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画;
    其中,所述步态周期是所述摆动阶段和所述支撑阶段的交替周期,腿部参数包括抬脚时间点、所述摆动阶段的时长、所述支撑阶段的步伐中点中的至少一种。
  4. 根据权利要求3所述的方法,其特征在于,所述步态参数包括在第一运动形态下的第一步态参数和在第二运动形态下的第二步态参数;
    所述方法还包括:
    将所述第一步态参数和所述第二步态参数进行插值,得到第一混合步态参数;及
    基于所述第一混合步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的每条腿从所述第一运动形态切换至所述第二运动形态的过渡动画。
  5. 根据权利要求3所述的方法,其特征在于,所述步态参数包括在第一移动方向下的第三步态参数和在第二移动方向下的第四步态参数;
    所述方法还包括:
    将所述第三步态参数和所述第四步态参数进行插值,得到第二混合步态参数;及
    基于所述第二混合步态参数对所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的每条腿在第三移动方向的行走动画;
    其中,所述第三移动方向是位于所述第一移动方向和所述第二移动方向之间的移动方向。
  6. 根据权利要求1至5任一所述的方法,其特征在于,所述根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿的落脚点,包括:
    根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色在地图中的预测移动轨迹;及
    以所述虚拟角色的每条腿的当前姿态为预测起点,在所述预测移动轨迹上采样出所述每条腿的落脚点。
  7. 根据权利要求6所述的方法,其特征在于,所述虚拟角色包括n条腿,所述以所述虚拟角色的每条腿的当前姿态为预测起点,在所述预测移动轨迹上采样出所述每条腿的落脚点,包括:
    在所述虚拟角色的第i条腿的当前姿态为所述摆动阶段的第t秒状态的情况下,计算所述摆动阶段的剩余时长和半个所述支撑阶段的时长之和为预测时长;
    以所述虚拟角色的当前姿态在所述预测移动轨迹上的位置为起点,将沿所述预测移动轨迹上前进所述预测长度的位置,确定为所述虚拟角色在落脚时的身体位置,所述预测长度等于所述预测时长和所述移动速度的乘积;及
    基于所述虚拟角色在落脚时的身体位置以及相对位置关系,推算出所述虚拟角色的第i条腿在所述预测移动轨迹上的落脚点;
    其中,i为不大于n的正整数,所述相对位置关系是预配置的所述虚拟角色的身体与所述第i条腿之间的相对位置。
  8. 根据权利要求6所述的方法,其特征在于,所述方法还包括:
    在所述落脚点所在的地面为非平整地面的情况下,计算所述落脚点在所述非平整地面上沿垂直方向的第一投影点;
    在所述落脚点和所述第一投影点的连线上,基于摆腿距离截取出参考点;及
    将所述参考点在所述非平整地面上沿垂直方向的第二投影点,作为更新后的落脚点。
  9. 根据权利要求8所述的方法,其特征在于,所述方法还包括:
    根据所述更新后的落脚点所在地面的法线方向,对所述脚部在落脚时的姿态进行偏转。
  10. 根据权利要求1至5任一所述的方法,其特征在于,所述根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置,包括:
    基于相邻两个所述落脚点的位置确定摆腿曲线,所述摆腿曲线用于指示所述脚部在所述摆动阶段的摆动轨迹;及
    基于所述摆腿曲线对所述每条腿的脚部进行插值计算,计算得到所述每条腿的脚部在所述摆动阶段的位置。
  11. 根据权利要求8所述的方法,其特征在于,所述方法包括:
    在所述虚拟角色的身体下方存在障碍物的情况下,基于相邻两个所述落脚点的位置和所述障碍物的最高点确定样条曲线;及
    将所述样条曲线与所述摆腿曲线进行叠加,得到更新后的摆腿曲线。
  12. 根据权利要求1至5任一所述的方法,其特征在于,所述基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置,包括:
    根据所述每条腿的相邻两个所述落脚点进行循环坐标下降反向动力学CCDIK计算,得到所述每条腿的骨骼点在摆动阶段的位置;
    或,
    根据所述每条腿的相邻两个所述落脚点进行前向和后向到达反向动力学FABIK计算,得到所述每条腿的骨骼点在摆动阶段的位置。
  13. 根据权利要求1至5任一所述的方法,其特征在于,所述方法还包括:
    获取所述虚拟角色的躯干动画,所述躯干动画是所述虚拟角色的身体在行走过程中的动画;及
    将所述虚拟角色的躯干动画与所述虚拟角色的行走动画进行融合,得到所述虚拟角色的整体移动动画。
  14. 根据权利要求13所述的方法,其特征在于,所述将所述虚拟角色的躯干动画与所述虚拟角色的行走动画进行融合,得到所述虚拟角色的整体移动动画,包括:
    将所述虚拟角色的躯干动画的时长按照步态周期的时长进行缩放,得到缩放后的躯干动画;所述步态周期是所述摆动阶段和所述支撑阶段的交替周期;及
    将所述缩放后的躯干动画与所述虚拟角色的行走动画进行融合,得到所述虚拟角色的整体移动动画。
  15. 根据权利要求1至5任一所述的方法,其特征在于,所述方法还包括:
    在所述虚拟角色的身体上存在弹性部件的情况下,确定所述弹性部件在所述虚拟角色的骨骼树中对应的至少两级骨骼节点;及
    从所述至少两级的骨骼节点中的根节点开始,以上一级骨骼节点为原点、下一级骨骼节点为振子进行三维振动模型的振动计算,确定所述下一级骨骼节点的骨骼更新位置,直至更新得到所述弹性部件的骨骼更新位置。
  16. 根据权利要求1至5任一所述的方法,其特征在于,所述方法还包括:
    计算所述虚拟角色的各条腿的支撑向量,所述支撑向量用于指示当前腿的落脚点相对于所述虚拟角色的躯干的倾斜度;
    基于所述各条腿的支撑向量,计算所述虚拟角色的躯干的姿态角;及
    基于所述姿态角对所述虚拟角色的躯干进行倾斜补偿。
  17. 根据权利要求1至5任一所述的方法,其特征在于,所述方法还包括:
    在所述虚拟角色处于凸型地面上方的情况下,计算所述虚拟角色的各条腿的落脚点与所述凸型地面的顶点之间的平均高度差;及
    按照所述平均高度差将所述虚拟角色的躯干的高度进行升高补偿。
  18. 一种虚拟角色的行走动画生成装置,其特征在于,所述虚拟角色的每条腿在行走过程中交替执行摆动阶段和支撑阶段,所述装置包括:
    预测模块,用于根据所述虚拟角色的移动速度和移动方向,预测所述虚拟角色的每条腿在所述行走过程中的落脚点;
    计算模块,用于根据所述每条腿的相邻两个所述落脚点,计算所述每条腿的脚部在所述摆动阶段中的位置;
    IK模块,用于基于所述每条腿的脚部在所述摆动阶段中的位置进行反向动力学计算,得到所述每条腿的骨骼点在所述摆动阶段的位置;及
    融合模块,用于基于所述每条腿的骨骼点在所述摆动阶段的位置进行步态融合,生成所述虚拟角色的行走动画。
  19. 一种计算机设备,其特征在于,所述计算机设备包括:一个或多个处理器和存储器,所述存储器存储有计算机可读指令,所述计算机可读指令由所述处理器加载并执行以实现如权利要求1至17任一所述的虚拟角色的行走动画生成方法。
  20. 一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有计算机可读指令,所述计算机可读指令由一个或多个处理器加载并执行以实现如权利要求1至17任一所述的虚拟角色的行走动画生成方法。
  21. 一种计算机程序产品,其特征在于,所述计算机程序产品包括计算机可读指令,所述计算机可读指令存储在计算机可读存储介质中,计算机设备的一个或多个处理器从所述计算机可读存储介质读取所述计算机可读指令,所述一个或多个处理器执行所述计算机可读指令,使得所述计算机设备执行以实现如权利要求1至17任一所述的虚拟角色的行走动画生成方法。
PCT/CN2022/127073 2021-11-19 2022-10-24 虚拟角色的行走动画生成方法、装置、设备及存储介质 WO2023088041A1 (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US18/338,330 US20230334744A1 (en) 2021-11-19 2023-06-20 Method and apparatus for generating walk animation of virtual role, device and storage medium

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
CN202111374361 2021-11-19
CN202111374361.9 2021-11-19
CN202111628788.7 2021-12-28
CN202111628788.7A CN114283229A (zh) 2021-11-19 2021-12-28 虚拟角色的行走动画生成方法、装置、设备及存储介质

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US18/338,330 Continuation US20230334744A1 (en) 2021-11-19 2023-06-20 Method and apparatus for generating walk animation of virtual role, device and storage medium

Publications (1)

Publication Number Publication Date
WO2023088041A1 true WO2023088041A1 (zh) 2023-05-25

Family

ID=80877719

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/CN2022/127073 WO2023088041A1 (zh) 2021-11-19 2022-10-24 虚拟角色的行走动画生成方法、装置、设备及存储介质

Country Status (3)

Country Link
US (1) US20230334744A1 (zh)
CN (1) CN114283229A (zh)
WO (1) WO2023088041A1 (zh)

Families Citing this family (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114283229A (zh) * 2021-11-19 2022-04-05 腾讯科技(深圳)有限公司 虚拟角色的行走动画生成方法、装置、设备及存储介质
US20230306667A1 (en) * 2022-03-22 2023-09-28 Disney Enterprises, Inc. Procedural animation engine and editor for sample-based design of stylized walking gaits for bipedal robots
US20230310998A1 (en) * 2022-03-31 2023-10-05 Electronic Arts Inc. Learning character motion alignment with periodic autoencoders
CN115761074B (zh) * 2022-11-18 2023-05-12 北京优酷科技有限公司 动画数据处理方法、装置、电子设备及介质
CN115797513B (zh) * 2023-02-01 2023-05-09 腾讯科技(深圳)有限公司 一种动画处理方法、装置、设备、存储介质及程序产品
CN116764225B (zh) * 2023-06-09 2024-08-27 广州三七极梦网络技术有限公司 一种高效寻路的处理方法、装置、设备及介质
CN117173382B (zh) * 2023-10-27 2024-01-26 南京维赛客网络科技有限公司 Vr交互中的虚拟数字人体态矫正方法、系统及存储介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103514622A (zh) * 2012-06-29 2014-01-15 甲尚股份有限公司 虚拟角色的步态自动适应地形的系统及方法
CN105608309A (zh) * 2015-12-11 2016-05-25 杭州南江机器人股份有限公司 一种双足机器人步行规划和控制方法
CN110728739A (zh) * 2019-09-30 2020-01-24 杭州师范大学 一种基于视频流的虚拟人控制与交互方法
CN111311714A (zh) * 2020-03-31 2020-06-19 北京慧夜科技有限公司 一种三维动画的姿态预测方法和系统
CN112348931A (zh) * 2020-11-06 2021-02-09 网易(杭州)网络有限公司 脚部反向运动控制方法、装置、设备及存储介质
WO2021045082A1 (ja) * 2019-09-05 2021-03-11 国立大学法人東京工業大学 仮想的なキャラクターの動作を画面上に表現する方法
CN113318439A (zh) * 2021-06-17 2021-08-31 网易(杭州)网络有限公司 起步动画的处理方法、装置、处理器和电子装置
CN114283229A (zh) * 2021-11-19 2022-04-05 腾讯科技(深圳)有限公司 虚拟角色的行走动画生成方法、装置、设备及存储介质

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103514622A (zh) * 2012-06-29 2014-01-15 甲尚股份有限公司 虚拟角色的步态自动适应地形的系统及方法
CN105608309A (zh) * 2015-12-11 2016-05-25 杭州南江机器人股份有限公司 一种双足机器人步行规划和控制方法
WO2021045082A1 (ja) * 2019-09-05 2021-03-11 国立大学法人東京工業大学 仮想的なキャラクターの動作を画面上に表現する方法
CN110728739A (zh) * 2019-09-30 2020-01-24 杭州师范大学 一种基于视频流的虚拟人控制与交互方法
CN111311714A (zh) * 2020-03-31 2020-06-19 北京慧夜科技有限公司 一种三维动画的姿态预测方法和系统
CN112348931A (zh) * 2020-11-06 2021-02-09 网易(杭州)网络有限公司 脚部反向运动控制方法、装置、设备及存储介质
CN113318439A (zh) * 2021-06-17 2021-08-31 网易(杭州)网络有限公司 起步动画的处理方法、装置、处理器和电子装置
CN114283229A (zh) * 2021-11-19 2022-04-05 腾讯科技(深圳)有限公司 虚拟角色的行走动画生成方法、装置、设备及存储介质

Also Published As

Publication number Publication date
US20230334744A1 (en) 2023-10-19
CN114283229A (zh) 2022-04-05

Similar Documents

Publication Publication Date Title
WO2023088041A1 (zh) 虚拟角色的行走动画生成方法、装置、设备及存储介质
KR102645536B1 (ko) 애니메이션 처리 방법 및 장치, 컴퓨터 저장 매체 그리고 전자 디바이스
JP7061238B2 (ja) 異種のターゲットアニメーションデータを使用してキャラクタをトレーニングする強化学習
CN111659115B (zh) 虚拟角色控制方法、装置、计算机设备和存储介质
CN101916324B (zh) 用于动画的依赖图评估的系统和方法
CN112001989B (zh) 虚拟对象的控制方法及装置、存储介质、电子装置
US8860732B2 (en) System and method for robust physically-plausible character animation
KR102103939B1 (ko) 머리 회전을 갖는 아바타 얼굴 표정 애니메이션
CN111714880B (zh) 画面的显示方法和装置、存储介质、电子装置
CN108771866B (zh) 虚拟现实中的虚拟对象控制方法及装置
US11409276B2 (en) Method and system for controlling robots within in an interactive arena and generating a virtual overlayed
US11238667B2 (en) Modification of animated characters
US11783523B2 (en) Animation control method and apparatus, storage medium, and electronic device
US11816772B2 (en) System for customizing in-game character animations by players
CN110935172A (zh) 虚拟对象处理方法、装置、系统及其存储介质
CN104867171A (zh) 一种三维角色的过渡动画生成方法
CN113209618B (zh) 虚拟角色的控制方法、装置、设备及介质
CN111968204B (zh) 一种骨骼模型的运动展示方法和装置
US20140285513A1 (en) Animation of a virtual object
CN113041616A (zh) 游戏中控制跳字显示的方法、装置、电子设备及存储介质
US9111391B2 (en) Image generating device, image generating method, and non-transitory information storage medium
JP3973995B2 (ja) アニメーション作成システム
JP2012247953A (ja) プログラム、情報記憶媒体、情報処理システム及び情報処理方法
US12073511B2 (en) Simulation of rigid bodies
JP5784985B2 (ja) プログラム、情報記憶媒体、情報処理システム及び情報処理方法

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 22894578

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE