1. Field of the Invention
The present invention relates to a game control technique, and in particular, to a game apparatus, a game control method, a game control program, and a management server, which provide the ability to control a game that is played by a plurality of players competing against one another.
2. Description of the Related Art
Currently, computer golf games where gamers play by controlling a particular character or characters are gaining popularity. Even in the real world, golf is a popular sport that is played by many people of all ages.
For a plurality of players to play a game of golf at the same time, the players must each hit a ball one by one, taking turns, just as they do in the real world, thus requiring much more time when compared with one player playing the game alone. Furthermore, the larger the number of players playing a game at the same time, the longer the waiting time between hits becomes. This may cause players to be discouraged from maintaining their interest in the game.
The present invention has been developed in view of these problems. It is therefore a general purpose of the invention to provide a game control technique which can improve the quality of the entertainment provided.
One embodiment of the present invention relates to a game control program product. The game control program product implements, on a computer, a controlling function which receives an input instruction from a player to control a character or an object; a generating and displaying function which generates and displays a game image which includes the character or object; an acquiring function which acquires information about a character or an object being controlled by another player; and a displaying function which displays the character or object being controlled by the other player on the game image. The game control program is characterized in that when the position of the character or object being controlled by the other player meets a predetermined condition such that the player's progression through a game is interrupted by the character or object controlled by the other player being displayed on the game image, the displaying function causes the character or object being controlled by the other player to be not displayed at all, or to be displayed in a translucent manner.
Another embodiment of the present invention relates to a management server. The management server includes: a participant registration section which registers a plurality of game apparatuses running a game and participating in a tournament in which the game apparatuses play the game in parallel in order to compete against one another; a data receive section which receives, from a game apparatus participating in the tournament, information that is indicative of a position of a character or an object in the game that is being played by the game apparatus; and a data transmit section which transmits the information received from the game apparatus to another game apparatus that meets a predetermined condition from among the plurality of game apparatuses participating in the same tournament.
Arbitrary combinations of the aforementioned constituting elements, and any implementations of the invention in the form of methods, apparatuses, and systems may also be practiced as additional modes of the present invention.
Embodiments will now be described, by way of example only, with reference to the accompanying drawings which are meant to be exemplary, not limiting, and wherein like elements are numbered alike in several figures, in which:
The invention will now be described by reference to the preferred embodiments. This does not intend to limit the scope of the present invention, but to exemplify the invention.
A game system according to an embodiment provides a game in which a plurality of players compete against one another in real time. By way of example, this embodiment will be explained with reference to the game of golf.
In general, when a plurality of players play golf, each player hits their ball from a tee in turn in decreasing order of their scores obtained from the previous hole. Each player then hits their ball for the second and subsequent times in decreasing order based on the distance from their ball to the cup. This type of computer games in which a plurality of players each hit their ball in turn, just as in a real-world golf competition, may allow the gamers to feel as if they are competing against one another on a real golf course. However, each player has to wait for a considerable period of time until the other players have finished hitting their balls. This would require a longer time for the game to be played when compared with a game played by one player only.
In the present embodiment, each player is allowed to hit his ball just as if he/she were playing the game alone, irrespective of whether another player or players were also playing. This embodiment also allows a player to check how another player is playing the game, for example, by displaying in a game image the character controlled by the other player or the path of the ball struck by the other player. This allows each player to proceed through the game independently, thereby shortening the time required to play the game without any loss of feeling that the player is competing against another player in real time. It is also possible to provide a novel feeling that could never be experienced in a real-world golf competition, for example, in that a plurality of players can be playing on the same course at the same time and a player may hit his/her ball while a ball struck by another player that is flying through the air is being displayed.
Furthermore, since a player can check another player's shot in the game image, the player can hits his/her ball while checking another player's strategy. For example, when another player's ball lies near the player's ball on a green, the player can wait until the other player putts his/her ball, and then putts after having checked the path of the other player's ball. Conversely, the player can also putt first to put pressure on the other player. It is possible to undertake such a strategy irrespective of the order of putting determined by the distance from the cup rule.
The communication section 80 controls communications with the game apparatuses 16 via the Internet 12. The management table 82 stores data required to manage a tournament in which a plurality of game apparatuses 16 participate in order to compete against one another.
The control section 90 includes a participant registration section 91, a data receive section 92, a data transmit section 93, a tournament management section 94, and a ranking management section 95. The participant registration section 91 registers a plurality of game apparatuses 16 that are running a game and that are participating in a tournament where the game apparatuses are playing the game in parallel in order to compete against one another. The participant registration section 91 may use a web page or the like to register the game apparatuses 16 that are going to participate in a tournament. In this case, the management server 14 is configured to function as a web server. Upon registration of a game apparatus 16 that is going to participate in a tournament, the participant registration section 91 acquires the player ID, the player name, the friend list of the player of the game apparatus 16, and the IP address of the game apparatus 16 to be registered with the management table 82. Information about players may be pre-stored in a user database (not shown) or the like. In the present case, the participant registration section 91 may use the player ID to retrieve information stored in the user database, thereby acquiring information associated with the player name and the friend list or the like.
The data receive section 92 receives, from a game apparatus 16 that has participated in a tournament, information indicative of the position of a character or an object in a game that is being played by the game apparatus 16. The data receive section 92 receives data which each game apparatus 16 needs in order to display, in the game image of its own device, the character or object of the game being played by another game apparatus 16. In the present embodiment, the eight game image frames of information detailed below are received from each game apparatus 16.
The absolute coordinates of the position of a ball in the game world (being the first frame).
The absolute coordinates of the position of a character in the game world (in the first frame this will be only X and Z).
The difference in the position of a ball between the current and previous frames (in the second and subsequent frames this will be seven frames in total).
The difference in the position of a character between the current and previous frames (in the second and subsequent frames this will be seven frames in total, but with only X and Z).
The motion number which indicates the motion of a character (for example, Hitting: 1, Putting: 2, and Scattering lawn for determining a wind direction: 3).
The character motion frame number or the ordinal number of the frame which indicates, for example, a hitting, putting, or lawn scattering motion.
The angle in which a character is oriented.
The flag of information on a character: the type of a club owned by the character (Wood, Iron, Putter), or whether a left-handed swing is taken (perhaps because a ball cannot be addressed with a right-handed swing due to an obstacle such as a tree). The information, such as the type of club set or the costume of a character, which is not changed during the play on a course, is transmitted only once at the start of the course.
The flag indicative of the status of a character: for example, during a stand-by state before a ball is hit, during a swing, during the flight of a ball, during a stationary condition of a ball, during a triumphant pose being struck upon completion of a hole, and during viewing a score card after a hole has been completed.
The data receive section 92 may record these pieces of information on the management table 82.
The data transmit section 93 transmits the information received from the game apparatus 16 to a game apparatus 16 that meets a predetermined condition from among the plurality of game apparatuses 16 participating in the same tournament.
The tournament management section 94 manages the progress of a tournament. In the present embodiment, in order to progress through a tournament quickly, there is a time limit provided for each hole so that a player who cannot complete the hole within the allocated time limit will be disqualified. The management server 14 may manage the time limit. However, in the present embodiment, each game apparatus 16 manages the time limit in order to inform the management server 14 that a player was not able to complete the hole within the allocated time limit. Upon receipt of the notice of a disqualified player, the tournament management section 94 stores “−1”, which indicates that the relevant player was disqualified, in the ranking column 210 of the management table 82 associated with that player. The data transmit section 93 does not transmit the information on the other game apparatuses 16 to the game apparatus 16 of the disqualified player. The tournament management section 94 may give a benefit to a player who completed a hole earlier than the other players, for example, a bonus point or a capability of hitting a ball with a special effect.
The ranking management section 95 manages the ranking of the players participating in the tournament. The ranking management section 95 acquires from each game apparatus 16 the score for each hole for the players who completed the hole, and then updates the score column 208 of the management table 82 as well as computing the ranking based on the score to update the ranking column 210.
The data transmit section 93 may transmit, to each game apparatus 16, the information received from the game apparatuses 16 of a predetermined number of higher ranking players selected from among those participating in the tournament. This allows each player to progress through a game while checking the play of higher ranking players. The data transmit section 93 may extract a predetermined number of players having a ranking close to that of a data receiving game apparatus 16, and then transmit the information received from the game apparatus 16 of an extracted player to the receiving game apparatus 16. This allows each player to progress through a game while checking on the screen the play of a player having a ranking close to his/her own. The data transmit section 93 may also transmit the information received from the game apparatus 16 of a gamer that the player of a data receiving game apparatus 16 has registered on his/her friend list. As described above, even in the case of a large number of players participating in a tournament, an appropriate number of players are extracted in order to transmit information that is indicative of the status of the game being played by the extracted players. It is thus possible to display the status of the other game apparatuses 16 without improperly increasing the processing load of each game apparatus 16.
Upon receipt of information from a game apparatus 16, the data transmit section 93 may immediately transmit the information to another game apparatus 16. Alternatively, the data transmit section 93 may collect information from all the game apparatuses 16 whose information is to be transmitted to the other game apparatus 16 and then transmit the pieces of information thereto at a time.
The communication section 64 controls communications with the management server 14 via the Internet 12. The input receive section 30 receives a control signal supplied from the controller 20 being controlled by a player. The control section 40 reads and executes a golf game program stored in the recording medium 62. Based on a control input provided by a player and received by the input receive section 30, the control section 40 allows the golf game to progress while controlling the motion of a player's character that acts as a golf player in the game world. The parameter hold section 60 holds those parameters which are required in order to progress through a golf game. The image creation section 66 creates an image for a game which is controlled by the control section 40 and allows the display device 68 to display the image.
The shot control section 41 controls shots taken by the player's characters. The shot control section 41 includes a camera control section 42, a power decision section 44, and an impact decision section 45.
In a game image 100, an image is rendered in order to show the geographical features of a course where the player's character is playing, and an image viewed behind the player's character is also displayed. In this image, the player manipulates the controller 20 to determine the power and impact of the shot, and then allows the player's character to hit the ball.
The camera control section 42 controls the view point position and line of sight of a camera when the image creation section 66 creates a game image. In order to create a game image that appears when the player's character hits a ball, the camera control section 42 provides initial settings such that the view point is located behind the player's character and the line of sight is set to look at the player's character. The player can change the view point position and the line of sight by manipulating the controller 20 in order to check the geographical features of the hole or determine the direction and distance of the shot. As will be described later, the camera control section 42 changes the view point position and the line of sight of the camera according to a control input from the player, and then informs the image creation section 66 of the changes.
The power decision section 44 determines the power of the shot taken by the player's character. When a control input assigned an instruction to start a shot is received from the controller 20, the power decision section 44 causes the image creation section 66 to create an image for displaying the player's character making a backswing motion in order to hit the ball, and then causes the display device 68 to display the image. The player manipulates the controller 20 in order to provide a control input that is assigned an instruction to determine the power of the shot, with the degree of the progression of the backswing motion made by the player's character being employed as a measure. The power decision section 44 determines the power of the shot according to the degree of progression of the motion made by the player's character for the shot at the point in time at which the control input used to determine the power was received. The power decision section 44 informs a trajectory computing section 50 of the determined power.
When a game image in which the player's character hits the ball is displayed, the camera control section 42 instructs the image creation section 66 to change the view point position or the line of sight used for creating an image according to an input instruction from the player. For example, depending on the geographical features or the condition of an obstacle around the ball, the backswing motion of the player's character may be difficult to view. In this case, the player may not be able to easily determine when to provide the control input for determining the power to be used. Thus, the camera control section 42 changes the view point position or the line of sight of the camera, so that the backswing motion of the player's character can be easily viewed.
The camera control section 42 may automatically move the view point position of the camera to a position at which the backswing motion of the player's character can be easily viewed. In particular, when the player's character is putting, a slight backswing motion may be made so that the move of the putter cannot be recognized well when viewed from behind the player's character. Thus, the camera control section 42 may change the view point position of the camera to one side of the player's character.
The impact decision section 45 determines the impact of the shot taken by the player's character. After the power decision section 44 has determined the power of the shot, the impact decision section 45 causes the image creation section 66 to create an image in which the player's character is making a downswing motion, and causes the display device 68 to display the image. With respect to the timing at which the player's character makes a downswing motion in order to strike the ball, the player uses the controller 20 to provide a control input to which an instruction to determine the impact is assigned. The impact decision section 45 determines the impact of the shot according to the time difference between the point in time at which the player's character made a downswing motion to strike the ball and the point in time at which the control input to determine the impact was received. The impact decision section 45 informs the trajectory computing section 50 of the determined impact. In the present case, the control input that is received earlier than the instant at which the impact becomes 100% may be denoted with a minus sign and the control input that is received after that instant may be denoted with a plus sign, thereby expressing whether the timing of the control input was late or early.
As an aid to a measure for adjusting the timing, the impact decision section 45 causes the image creation section 66 to create an image which includes a graphical object and causes the display device 68 to display the image. In this instance, the graphical object contracts with time and becomes smallest at the point in time at which the player's character strikes the ball, i.e., at the point in time at which the ball can be struck with the highest impact. The player can also employ the contracting graphical object as an additional measure to provide to the control input in order to determine the impact of the shot. The impact decision section 45 may also display a graphical object having the position of the ball at its center or at its center of gravity, thereby allowing the object to contract to the position of the ball as if it converges thereto. This allows the player to provide control while checking both the player's character making a downswing motion and the contraction of the graphical object, thus implementing a user interface with improved controllability.
By way of example, the impact decision section 45 may determine the impact as follows. That is, the impact at the point in time at which the player's character strikes the ball, i.e., at the point in time at which the time difference is zero, may be defined as a 100% impact. The impact at the point in time at which the time difference is at a predetermined upper limit may be defined as a predetermined lower limit impact. Then, the impact at the point in time at which the control input was received may be determined by proportionally dividing the range between the 100% impact and the lower limit impact. As will be described later, the trajectory computing section 50 corrects the distance of flight or the direction of a ball in a manner such that the lower the value of the impact determined by the impact decision section 45, the greater the deviation from the target landing point of the ball becomes. The time difference may exceed the predetermined upper limit without receiving a control input after the player's character makes a downswing motion past the ball. In this case, the impact decision section 45 may determine that the swing was just a practice swing, so that no shot is made, or alternatively, may automatically set the impact to a predetermined lower limit to make a shot.
As yet another example, the impact decision section 45 may employ a gauge to be displayed as a measure for adjusting the timing at which the player provides a control input. In this instance, the gauge indicates the position of a graphical object which moves with time horizontally, vertically, or along a given straight line or curved line. The gauge also indicates the position of a graphical object which shows the maximum impact. Furthermore, the impact decision section 45 may determine the impact and power of a shot depending on the angle, speed, and pressure at which the analog stick on the controller 20 is manipulated. The trajectory computing section 50 physically computes the trajectory of a struck ball based on the power and impact of the shot determined by the shot control section 41, the lie of a ball, and external factors such as wind or geographical features.
The trajectory computing section 50 reads from the parameter hold section 60 the initial velocity and the loft angle which were pre-defined for the club used for the shot. After having read the initial velocity, the trajectory computing section 50 adjusts the initial velocity or the loft angle in accordance with the power determined by the power decision section 44, the impact determined by the impact decision section 45, an attribute value such as a physical strength set for each player's character, and the lie of the ball. For example, the initial velocity may be multiplied by the percent value of the power and the impact so that a higher power or impact may cause a greater initial velocity. Furthermore, the flight direction or the speed of the ball may be adjusted so that a smaller value of the impact will cause the ball to be further deviated from the target landing point. For example, the orbit of the ball may be curved rightward as a slice ball when a control input was received earlier than the point where the impact becomes 100%, whereas the ball may be curved leftward as a hook ball when the input was received after the point where the impact becomes 100%. Furthermore, when the impact is less than or equal to the predetermined lower limit, the shot may be regarded as a mishit, so that the trajectory is computed with an extremely low initial velocity. For a ball in the rough or in a bunker, the initial velocity may be defined so as to be lower than that in the fairway. Furthermore, a lower initial velocity may be defined for a ball when it contacts with more steeply inclined ground. When the player provides a control input to change the initial velocity or loft angle during a shot, the initial velocity or loft angle may be further adjusted by taking the influence of the change into account.
Once the initial velocity and loft angle are determined, the trajectory computing section 50 computes the position of the ball for each frame while adjusting the speed of the ball depending on the force acting thereon. The trajectory computing section 50 adds the velocity of the ball to that of the ball on the coordinates of its current position frame by frame in order to compute the coordinates of the position of the ball in the subsequent frame. The acceleration of gravity, lift, wind force, and air resistance are added to the velocity of the ball frame by frame. According to a physical law, the acceleration of gravity of 9.8 m/sec/sec is exerted on the ball in a downward direction. The lift is exerted on the ball in an upward direction in proportion to its velocity. The wind force may be made constant in direction and magnitude at any point in the course or may be varied depending on the location. The air resistance is exerted in a direction that is opposite to the direction of the travel of ball and takes on a value proportional to its speed. In this manner, the trajectory of the ball is computed in consideration of the direction and velocity of the wind, thereby demonstrating the difficulty with which the ball is hit while taking the effects of wind into account just as can be experienced when playing golf in the real world. It is thus possible to realize a more realistic golf game.
When the ball collides with something, its horizontal and vertical velocities are adjusted using those friction coefficients and restitution coefficients which are predefined for the attribute of each surface with which the ball collides. The friction coefficient and the restitution coefficient may be defined to have different values depending on the fairway, rough, or bunker, collided with. Furthermore, as a demonstrative effect, the trajectory computing section 50 may compute the trajectory in a special manner regardless of the physical law. This may provide variation to a golf game, thereby making the game more fun.
A score management section 51 manages the score of a player's character. When the player's character completes a hole, the score management section 51 records the score of the hole in the parameter hold section 60. Furthermore, the score management section 51 displays a score board until the player's character starts the tee shot for the next hole after having completed the current hole. As described above, in the present embodiment, each hole is provided with a time limit. Thus, the score management section 51 uses a timer to measure the time that elapses from the start of the play of a hole and displays the remaining time in the image. When the player cannot complete the hole within the time limit, the score management section 51 terminates the game, and then informs the management server 14 of the termination.
A data transmit section 46 creates and transmits transmitted data to the management server 14 in order to inform another game apparatus 16 of the status of the game on the own device. As described above, the transmitted data includes, for example, information indicative of the position of a character and the position of a ball. The data transmit section 46 transmits eight game image frames of data at a time to the management server 14 every eight frames.
A data receive section 47 receives information about the status of another game apparatus 16 from the management server 14 and then stores the information in the parameter hold section 60.
Based on the information received by the data receive section 47, a competitor display section 48 displays, in the game image of the own device, the status of the game apparatus 16 of a competitor. The competitor display section 48 displays the character or object being controlled by another player in the game image.
The position of the character or object being controlled by another player may meet a predetermined condition such that the player's progression through a game is interrupted by the character or object controlled by another player being displayed in a game image. In this case, the competitor display section 48 allows the character or object being controlled by another player to be not displayed at all. This predetermined condition may include at least one of the following conditions regarding where the character or ball of another player is located: within a predetermined range from the view point position of a camera at which a game image is created; within a predetermined range from the character or ball being controlled by the player; in between the view point position of the camera and the character or ball; within a predetermined range from a target position to which the player is trying to move the character or from a target position to which the player is trying to hit the ball; in between the target position and the character or ball; and in a direction in which the character or ball moves. In such a case, the competitor's character or ball may overlap the character or ball of the own device, stay in the direction of the shot or the cup, or overlap a moving image serving as a measure for determining the power or impact or another measure, thereby likely interrupting the player's control. For this reason, the competitor's character and ball are not displayed at all. In such a case, the competitor display section 48 may also increase the transparency of the competitor's character and ball so that they are translucent when displayed. The competitor display section 48 may make the competitor's character and ball able to be displayed in a translucent manner when they do not meet the aforementioned condition. In this case, the character and ball which meet the aforementioned condition may be further increased in transparency, thereby becoming more transparent when being displayed.
The competitor display section 48 may wait until the data receive section 47 acquires a predetermined number of game image frames of information, for example, 24 frames of information, and then display the character or ball being controlled by another player in a game image. As described above, the data receive section 47 receives 8 frames of data from the management server 14 every 8 frames; however, a delay may occur depending on the state of communications. When the received 8 frames of data are displayed and the next data cannot be received due to a delay, the image may become still, resulting in an undesired lack of motion. Accordingly, the competitor display section 48 waits until 24 frames of data are accumulated, and then reflects them in the display. As such, when the next data is received while 24 frames of data are being displayed, the character and ball of another player can be smoothly displayed without interrupting their motion. An actual delay in communication may cause a decrease in the remaining amount of data. Even in this case, when an image is changed for switching a view point position or at the time a hole is completed, it may be acceptable to wait until 24 frames of data are accumulated. There are shooting games or fighting games in which the players have to progress through the game while checking the status of a competitor in real time. Unlike these games, players playing golf or bowling games can proceed through the games by themselves without checking the status of a competitor. In the latter games, the status of a competitor does not need to be displayed strictly in real time. It is thus possible to accumulate and then display an approximate amount of data corresponding to an expected period of delay time, thereby providing a smooth display of motion.
Note that the shot control section 41 and the trajectory computing section 50 control the motion or movement of a character and ball irrespective of the character and ball being controlled by another player. As described above, a golf game or bowling game allows a player to progress through it by himself/herself irrespective of the status of a competitor. Thus, the shot control section 41 receives a player's control over a shot by the player's character irrespective of the status of a competitor. Furthermore, even when the competitor's character or ball is present in a trajectory, the trajectory computing section 50 does not make a collision decision but rather computes the trajectory as if the character or ball is not present therein. This allows a player to progress through the game irrespective of a competitor even though the status of the competitor is being displayed. It is thus possible to eliminate the time required to wait for a shot to be completed, thereby allowing the player to proceed quickly through the game. It is also possible to simplify the calculation of trajectories, thereby reducing the processing load.
Depending on the position of a ball computed by the trajectory computing section 50, the image creation section 66 sets the view point position of the camera and the line of sight so that the ball is included in the image. Then, the image creation section 66 creates an image which indicates a ball in flight, and displays the image on the display device 68. At this time, the competitor's character and ball located by the competitor display section 48 in the game world are also rendered for display.
The competitor display section 48 informs the image creation section 66 of the following information in order to locate a character in the game world. The information includes the coordinates that are indicative of the position of a competitor's character which does not meet the condition for no display, the angle at which the character is oriented, the type of a club owned, and information as to whether a left-handed swing is being made. Furthermore, when a character is making a motion, the competitor display section 48 informs the image creation section 66 of the motion number and the number of motion frames of the motion. Moreover, the competitor display section 48 informs the image creation section 66 of the coordinates which indicate the position of a competitor's ball. Based on data on the type and costume of a character, the image creation section 66 acquires shape data for the character from the recording medium 62 for rendering. The image creation section 66 also acquires ball shape data for rendering. In this manner, the competitor's character and ball are displayed in a game image.
In the present embodiment, a shot and trajectory provided by the competitor's character are not computed by acquiring information on an input instruction entered at the competitor's game apparatus 16; instead information required for rendering is acquired only to carry out rendering. Thus, even in the presence of multiple players competing against one another at the same time, it is possible to prevent an increase in processing load and implement real-time display in a game image. In case of a delay in communication, such data as required to compute the trajectory of a ball in conjunction with, for example, a velocity vector may be transmitted and received between the game apparatuses 16.
In the foregoing, the present invention has been described in accordance with an embodiment. The embodiment was provided by way of example only. It should thus be understood by those skilled in the art that various modifications may be made to each component thereof and/or to a combination of each of the process steps, and those modified examples also fall within the scope of the present invention.
The technique described in accordance with the embodiment is applicable not only to golf but also to games such as racing or bowling games in which one player can play independently, or where multiple players can play to compete against one another without always having to display the status of a competitor in real time.
In the embodiment, data related to the status of players playing the same game is transmitted and received between the players via a management server. However, the data may be transmitted and received not via the management server but rather directly between the game apparatuses. Furthermore, the present invention is also applicable to a case where one game apparatus is used for a plurality of players in order to compete against one another with the screen divided in order to display multiple game images, there being one each player.
Number | Date | Country | Kind |
---|---|---|---|
JP2007-114893 | Apr 2007 | JP | national |