JP2019017483A - Information processing method, device, and program for causing computer to execute the information processing method - Google Patents

Information processing method, device, and program for causing computer to execute the information processing method Download PDF

Info

Publication number
JP2019017483A
JP2019017483A JP2017136319A JP2017136319A JP2019017483A JP 2019017483 A JP2019017483 A JP 2019017483A JP 2017136319 A JP2017136319 A JP 2017136319A JP 2017136319 A JP2017136319 A JP 2017136319A JP 2019017483 A JP2019017483 A JP 2019017483A
Authority
JP
Japan
Prior art keywords
user
virtual space
movable object
computer
view image
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
JP2017136319A
Other languages
Japanese (ja)
Other versions
JP6946084B2 (en
Inventor
健志 加田
Kenji Kada
健志 加田
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Colopl Inc
Original Assignee
Colopl Inc
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 Colopl Inc filed Critical Colopl Inc
Priority to JP2017136319A priority Critical patent/JP6946084B2/en
Publication of JP2019017483A publication Critical patent/JP2019017483A/en
Application granted granted Critical
Publication of JP6946084B2 publication Critical patent/JP6946084B2/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Processing Or Creating Images (AREA)

Abstract

To improve entertainment properties of a virtual experience in a virtual space.SOLUTION: An information processing method executed by a first computer to provide a virtual space to a first user through a head mounted device includes: a step for generating motion data indicating a movement when the movement of a movable object from a first character object corresponding to the first user is detected; a step for generating a first view image based on virtual space data and the motion data, and causing a display part to display the first view image; and a step for, by transmitting the motion data to one or more second computers corresponding to one or more second users, causing each of the one or more second computers to display a second view image synchronized with the first view image based on the motion data.SELECTED DRAWING: Figure 15

Description

本開示は、情報処理方法、装置、および当該情報処理方法をコンピュータに実行させるためのプログラムに関する。   The present disclosure relates to an information processing method, an apparatus, and a program for causing a computer to execute the information processing method.

特許文献1は、二人のユーザが仮想ボールを前後に投げ、各ユーザが仮想世界への他方のユーザの影響を観察できるシステムを開示している。   Patent Document 1 discloses a system in which two users can throw a virtual ball back and forth and each user can observe the influence of the other user on the virtual world.

特表2014−513367号公報Special table 2014-513367 gazette

仮想ボールのような可動オブジェクトが登場する仮想空間では、ユーザ操作に応じて動く該可動オブジェクトの演出が当該仮想空間のエンタテイメント性に影響し得る。   In a virtual space where a movable object such as a virtual ball appears, the effect of the movable object that moves in response to a user operation can affect the entertainment properties of the virtual space.

そこで、本開示は、仮想空間における仮想体験のエンタテイメント性を向上させ得る情報処理方法、装置、および当該情報処理方法をコンピュータに実行させるためのプログラムを提供することを目的とする。   Therefore, an object of the present disclosure is to provide an information processing method and apparatus capable of improving the entertainment property of a virtual experience in a virtual space, and a program for causing a computer to execute the information processing method.

本開示が示す一態様によれば、表示部を備えるヘッドマウントデバイスを介して第1ユーザに仮想空間を提供するために、該第1ユーザに対応する第1コンピュータによって実行される情報処理方法が提供される。この情報処理方法は、第1ユーザに対応する第1キャラクタオブジェクトに関連付けられた可動オブジェクトを含む仮想空間を規定する仮想空間データを生成するステップと、第1キャラクタオブジェクトからの可動オブジェクトの移動を検出した場合に、該移動を示す動作データを生成するステップと、仮想空間データと動作データとに基づいて第1視界画像を生成し、表示部に該第1視界画像を表示させるステップと、1以上の第2ユーザに対応する1以上の第2コンピュータに動作データを送信することで、該1以上の第2コンピュータのそれぞれに、第1視界画像と同期する第2視界画像を動作データに基づき表示させるステップとを含む。   According to an aspect of the present disclosure, an information processing method executed by a first computer corresponding to a first user in order to provide a virtual space to the first user via a head mounted device including a display unit. Provided. The information processing method includes generating virtual space data defining a virtual space including a movable object associated with a first character object corresponding to a first user, and detecting movement of the movable object from the first character object. And a step of generating motion data indicating the movement, a step of generating a first view image based on the virtual space data and the motion data, and displaying the first view image on a display unit; By transmitting the operation data to one or more second computers corresponding to the second user, the second view image synchronized with the first view image is displayed on each of the one or more second computers based on the operation data. And a step of causing.

本開示によれば、仮想空間における仮想体験のエンタテイメント性を向上させ得る情報処理方法、装置、および当該情報処理方法をコンピュータに実行させるためのプログラムを提供することができる。   According to the present disclosure, it is possible to provide an information processing method and apparatus that can improve the entertainment property of a virtual experience in a virtual space, and a program for causing a computer to execute the information processing method.

ある実施の形態に従うHMDシステム100の構成の概略を表す図である。It is a figure showing the outline of a structure of the HMD system 100 according to a certain embodiment. 一局面に従うコンピュータ200のハードウェア構成の一例を表すブロック図である。It is a block diagram showing an example of the hardware constitutions of the computer 200 according to one situation. ある実施の形態に従うHMD装置110に設定されるuvw視野座標系を概念的に表す図である。It is a figure which represents notionally the uvw visual field coordinate system set to the HMD apparatus 110 according to an embodiment. ある実施の形態に従う仮想空間2を表現する一態様を概念的に表す図である。It is a figure which represents notionally the one aspect | mode which represents the virtual space 2 according to a certain embodiment. ある実施の形態に従うHMD装置110を装着するユーザ190の頭部を上から表した図である。It is the figure showing the head of user 190 wearing HMD device 110 according to a certain embodiment from the top. 仮想空間2において視界領域23をX方向から見たYZ断面を表す図である。3 is a diagram illustrating a YZ cross section of a visual field region 23 viewed from the X direction in a virtual space 2. FIG. 仮想空間2において視界領域23をY方向から見たXZ断面を表す図である。3 is a diagram illustrating an XZ cross section of a visual field region 23 viewed from a Y direction in a virtual space 2. FIG. ある実施の形態に従うコントローラ160の概略構成を表す図である。It is a figure showing schematic structure of the controller 160 according to a certain embodiment. ある実施の形態に従うコンピュータ200をモジュール構成として表すブロック図である。FIG. 2 is a block diagram showing a computer 200 according to an embodiment as a module configuration. ある実施の形態に従うHMDシステム100Aが実行する処理を表すシーケンス図である。It is a sequence diagram showing the process which HMD system 100A according to a certain embodiment performs. ある実施の形態に従う仮想空間2の一例を模式的に表す図である。It is a figure which represents typically an example of the virtual space 2 according to a certain embodiment. ある実施の形態に従うHMD装置110により提供される視界画像の一例を表す図である。It is a figure showing an example of the visual field image provided by the HMD apparatus 110 according to an embodiment. ある実施の形態に従うHMD装置110により提供される視界画像の一例を表す図である。It is a figure showing an example of the visual field image provided by the HMD apparatus 110 according to an embodiment. ある実施の形態に従うメッシュ型ネットワークの一例を示す図である。It is a figure which shows an example of the mesh type network according to a certain embodiment. ある実施の形態に従う可動オブジェクト315の同期を表すシーケンス図である。It is a sequence diagram showing the synchronization of the movable object 315 according to an embodiment. ある実施の形態に従う可動オブジェクト315の同期を表すシーケンス図である。It is a sequence diagram showing the synchronization of the movable object 315 according to an embodiment. ある実施の形態に従うマスタ側での可動オブジェクト315の制御を表すフローチャートである。It is a flowchart showing control of the movable object 315 by the master side according to a certain embodiment. マスタとスレーブとの間での可動オブジェクト315の位置の差異の例を表す図である。It is a figure showing the example of the difference in the position of the movable object 315 between a master and a slave.

以下、図面を参照しつつ、本開示の実施の形態について説明する。以下の説明では、同一の部品には同一の符号を付してある。それらの名称および機能も同じである。したがって、それらについての詳細な説明は繰り返さない。   Hereinafter, embodiments of the present disclosure will be described with reference to the drawings. In the following description, the same parts are denoted by the same reference numerals. Their names and functions are also the same. Therefore, detailed description thereof will not be repeated.

[HMDシステムの構成]
図1を参照して、HMD(Head Mount Device)システム100の構成について説明する。図1は、ある実施の形態に従うHMDシステム100の構成の概略を表す図である。ある局面において、HMDシステム100は、家庭用のシステムとしてあるいは業務用のシステムとして提供される。
[Configuration of HMD system]
A configuration of an HMD (Head Mount Device) system 100 will be described with reference to FIG. FIG. 1 is a diagram representing an outline of a configuration of an HMD system 100 according to an embodiment. In one aspect, the HMD system 100 is provided as a home system or a business system.

HMDシステム100は、HMD装置110(ユーザ端末)と、HMDセンサ120と、コントローラ160と、コンピュータ200とを備える。HMD装置110は、ディスプレイ112と、カメラ116と、マイク118と、注視センサ140とを含む。コントローラ160は、モーションセンサ130を含み得る。   The HMD system 100 includes an HMD device 110 (user terminal), an HMD sensor 120, a controller 160, and a computer 200. The HMD device 110 includes a display 112, a camera 116, a microphone 118, and a gaze sensor 140. The controller 160 can include a motion sensor 130.

ある局面において、コンピュータ200は、インターネットその他のネットワーク19に接続可能であり、ネットワーク19に接続されているサーバ150その他のコンピュータと通信可能である。別の局面において、HMD装置110は、HMDセンサ120の代わりに、センサ114を含み得る。   In one aspect, the computer 200 can be connected to the Internet and other networks 19, and can communicate with the server 150 and other computers connected to the network 19. In another aspect, the HMD device 110 may include a sensor 114 instead of the HMD sensor 120.

HMD装置110は、ユーザの頭部に装着され、動作中に仮想空間をユーザに提供し得る。より具体的には、HMD装置110は、右目用の画像および左目用の画像をディスプレイ112にそれぞれ表示する。ユーザの各目がそれぞれの画像を視認すると、ユーザは、両目の視差に基づき当該画像を3次元の画像として認識し得る。   The HMD device 110 may be worn on the user's head and provide a virtual space to the user during operation. More specifically, the HMD device 110 displays a right-eye image and a left-eye image on the display 112, respectively. When each eye of the user visually recognizes each image, the user can recognize the image as a three-dimensional image based on the parallax of both eyes.

ディスプレイ112は、例えば、非透過型の表示装置として実現される。ある局面において、ディスプレイ112は、ユーザの両目の前方に位置するようにHMD装置110の本体に配置されている。したがって、ユーザは、ディスプレイ112に表示される3次元画像を視認すると、仮想空間に没入することができる。ある実施の形態において、仮想空間は、例えば、背景、ユーザが操作可能なオブジェクト、およびユーザが選択可能なメニューの画像等を含む。ある実施の形態において、ディスプレイ112は、所謂スマートフォンその他の情報表示端末が備える液晶ディスプレイまたは有機EL(Electro-Luminescence)ディスプレイとして実現され得る。ディスプレイ112は、HMD装置110の本体と一体に構成されてもよいし、別体として構成されてもよい。   The display 112 is realized as a non-transmissive display device, for example. In one aspect, the display 112 is disposed on the main body of the HMD device 110 so as to be positioned in front of both eyes of the user. Therefore, when the user visually recognizes the three-dimensional image displayed on the display 112, the user can be immersed in the virtual space. In one embodiment, the virtual space includes, for example, a background, an object that can be operated by the user, an image of a menu that can be selected by the user, and the like. In an embodiment, the display 112 may be realized as a liquid crystal display or an organic EL (Electro-Luminescence) display included in a so-called smartphone or other information display terminal. The display 112 may be configured integrally with the main body of the HMD device 110 or may be configured as a separate body.

ある局面において、ディスプレイ112は、右目用の画像を表示するためのサブディスプレイと、左目用の画像を表示するためのサブディスプレイとを含み得る。別の局面において、ディスプレイ112は、右目用の画像と左目用の画像とを一体として表示する構成であってもよい。この場合、ディスプレイ112は、高速シャッタを含む。高速シャッタは、画像がいずれか一方の目にのみ認識されるように、右目用の画像と左目用の画像とを交互に表示可能に作動する。   In one aspect, the display 112 may include a sub-display for displaying an image for the right eye and a sub-display for displaying an image for the left eye. In another aspect, the display 112 may be configured to display a right-eye image and a left-eye image together. In this case, the display 112 includes a high-speed shutter. The high-speed shutter operates so that an image for the right eye and an image for the left eye can be displayed alternately so that the image is recognized only by one of the eyes.

カメラ116は、HMD装置110を装着するユーザの顔画像を取得する。カメラ116によって取得された顔画像は、画像解析処理によってユーザの表情を検知するために使用され得る。カメラ116は、例えば、瞳の動き、まぶたの開閉、および眉毛の動き等を検知するために、HMD装置110本体に内蔵された赤外線カメラであってもよい。あるいは、カメラ116は、ユーザの口、頬、および顎等の動きを検知するために、図1に示されるようにHMD装置110の外側に配置された外付けカメラであってもよい。また、カメラ116は、上述した赤外線カメラおよび外付けカメラの両方によって構成されてもよい。   The camera 116 acquires a face image of the user wearing the HMD device 110. The face image acquired by the camera 116 can be used to detect the user's facial expression through image analysis processing. The camera 116 may be, for example, an infrared camera built in the main body of the HMD device 110 in order to detect pupil movement, eyelid opening / closing, eyebrow movement, and the like. Alternatively, the camera 116 may be an external camera disposed outside the HMD device 110 as shown in FIG. 1 in order to detect movements of the user's mouth, cheeks, and jaws. The camera 116 may be configured by both the infrared camera and the external camera described above.

マイク118は、ユーザが発した音声を取得する。マイク118によって取得された音声は、音声解析処理によってユーザの感情を検知するために使用され得る。当該音声は、仮想空間2に対して、音声による指示を与えるためにも使用され得る。また、当該音声は、ネットワーク19およびサーバ150等を介して、他のユーザが使用するHMDシステムに送られ、当該HMDシステムに接続されたスピーカ等から出力されてもよい。これにより、仮想空間を共有するユーザ間での会話(チャット)が実現される。   The microphone 118 acquires the voice uttered by the user. The voice acquired by the microphone 118 can be used to detect a user's emotion by voice analysis processing. The voice can also be used to give a voice instruction to the virtual space 2. Further, the sound may be sent to the HMD system used by another user via the network 19 and the server 150, and output from a speaker or the like connected to the HMD system. Thereby, the conversation (chat) between the users who share a virtual space is implement | achieved.

HMDセンサ120は、複数の光源(図示しない)を含む。各光源は例えば、赤外線を発するLED(Light Emitting Diode)により実現される。HMDセンサ120は、HMD装置110の動きを検出するためのポジショントラッキング機能を有する。HMDセンサ120は、この機能を用いて、現実空間内におけるHMD装置110の位置および傾きを検出する。   The HMD sensor 120 includes a plurality of light sources (not shown). Each light source is realized by, for example, an LED (Light Emitting Diode) that emits infrared rays. The HMD sensor 120 has a position tracking function for detecting the movement of the HMD device 110. The HMD sensor 120 detects the position and inclination of the HMD device 110 in the real space using this function.

なお、別の局面において、HMDセンサ120は、カメラにより実現されてもよい。この場合、HMDセンサ120は、カメラから出力されるHMD装置110の画像情報を用いて、画像解析処理を実行することにより、HMD装置110の位置および傾きを検出することができる。   In another aspect, HMD sensor 120 may be realized by a camera. In this case, the HMD sensor 120 can detect the position and inclination of the HMD device 110 by executing image analysis processing using image information of the HMD device 110 output from the camera.

別の局面において、HMD装置110は、位置検出器として、HMDセンサ120の代わりに、センサ114を備えてもよい。HMD装置110は、センサ114を用いて、HMD装置110自身の位置および傾きを検出し得る。例えば、センサ114が角速度センサ、地磁気センサ、加速度センサ、あるいはジャイロセンサ等である場合、HMD装置110は、HMDセンサ120の代わりに、これらの各センサのいずれかを用いて、自身の位置および傾きを検出し得る。一例として、センサ114が角速度センサである場合、角速度センサは、現実空間におけるHMD装置110の3軸周りの角速度を経時的に検出する。HMD装置110は、各角速度に基づいて、HMD装置110の3軸周りの角度の時間的変化を算出し、さらに、角度の時間的変化に基づいて、HMD装置110の傾きを算出する。また、HMD装置110は、透過型表示装置を備えていてもよい。この場合、当該透過型表示装置は、その透過率を調整することにより、一時的に非透過型の表示装置として構成可能であってもよい。また、視界画像は仮想空間を構成する画像の一部に、現実空間を提示する構成を含んでいてもよい。例えば、HMD装置110に搭載されたカメラで撮影した画像を視界画像の一部に重畳して表示させてもよいし、当該透過型表示装置の一部の透過率を高く設定することにより、視界画像の一部から現実空間を視認可能にしてもよい。   In another aspect, the HMD device 110 may include a sensor 114 instead of the HMD sensor 120 as a position detector. The HMD device 110 can detect the position and inclination of the HMD device 110 itself using the sensor 114. For example, when the sensor 114 is an angular velocity sensor, a geomagnetic sensor, an acceleration sensor, a gyro sensor, or the like, the HMD device 110 uses any one of these sensors instead of the HMD sensor 120 to detect its position and inclination. Can be detected. As an example, when the sensor 114 is an angular velocity sensor, the angular velocity sensor detects angular velocities around the three axes of the HMD device 110 in real space over time. The HMD device 110 calculates the temporal change of the angle around the three axes of the HMD device 110 based on each angular velocity, and further calculates the inclination of the HMD device 110 based on the temporal change of the angle. The HMD device 110 may include a transmissive display device. In this case, the transmissive display device may be temporarily configured as a non-transmissive display device by adjusting the transmittance. Further, the view field image may include a configuration for presenting the real space in a part of the image configuring the virtual space. For example, an image captured by a camera mounted on the HMD device 110 may be displayed so as to be superimposed on a part of the field-of-view image, or a part of the transmission-type display device may be set to have a high transmittance. The real space may be visible from a part of the image.

注視センサ140は、ユーザ190の右目および左目の視線が向けられる方向(視線方向)を検出する。当該方向の検出は、例えば、公知のアイトラッキング機能によって実現される。注視センサ140は、当該アイトラッキング機能を有するセンサにより実現される。ある局面において、注視センサ140は、右目用のセンサおよび左目用のセンサを含むことが好ましい。注視センサ140は、例えば、ユーザ190の右目および左目に赤外光を照射するとともに、照射光に対する角膜および虹彩からの反射光を受けることにより各眼球の回転角を検出するセンサであってもよい。注視センサ140は、検出した各回転角に基づいて、ユーザ190の視線方向を検知することができる。   The gaze sensor 140 detects a direction (gaze direction) in which the gaze of the right eye and the left eye of the user 190 is directed. The detection of the direction is realized by, for example, a known eye tracking function. The gaze sensor 140 is realized by a sensor having the eye tracking function. In one aspect, the gaze sensor 140 preferably includes a right eye sensor and a left eye sensor. The gaze sensor 140 may be, for example, a sensor that irradiates the right eye and the left eye of the user 190 with infrared light and detects the rotation angle of each eyeball by receiving reflected light from the cornea and iris with respect to the irradiated light. . The gaze sensor 140 can detect the line-of-sight direction of the user 190 based on each detected rotation angle.

サーバ150は、コンピュータ200にプログラムを送信し得る。別の局面において、サーバ150は、他のユーザによって使用されるHMD装置に仮想現実を提供するための他のコンピュータ200と通信し得る。例えば、アミューズメント施設において、複数のユーザが参加型のゲームを行う場合、各コンピュータ200は、各ユーザの動作に基づく信号を他のコンピュータ200と通信して、同じ仮想空間において複数のユーザが共通のゲームを楽しむことを可能にする。サーバ150は、一または複数のコンピュータ装置により構成され得る。サーバ150は、後述するコンピュータ200のハードウェア構成と同様のハードウェア構成(プロセッサ、メモリ、ストレージ等)を備え得る。   Server 150 may send a program to computer 200. In another aspect, the server 150 may communicate with other computers 200 for providing virtual reality to HMD devices used by other users. For example, when a plurality of users play a participatory game in an amusement facility, each computer 200 communicates a signal based on each user's operation with another computer 200, and a plurality of users are common in the same virtual space. Allows you to enjoy the game. The server 150 can be composed of one or more computer devices. The server 150 may have a hardware configuration (processor, memory, storage, etc.) similar to the hardware configuration of the computer 200 described later.

コントローラ160は、ユーザ190からコンピュータ200への命令の入力を受け付ける。ある局面において、コントローラ160は、ユーザ190によって把持可能に構成される。別の局面において、コントローラ160は、ユーザ190の身体あるいは衣類の一部に装着可能に構成される。別の局面において、コントローラ160は、コンピュータ200から送られる信号に基づいて、振動、音、光のうちの少なくともいずれかを出力するように構成されてもよい。別の局面において、コントローラ160は、仮想空間に配置されるオブジェクトの位置および動き等を制御するためにユーザ190によって与えられる操作を受け付ける。   The controller 160 receives input of commands from the user 190 to the computer 200. In one aspect, the controller 160 is configured to be gripped by the user 190. In another aspect, the controller 160 is configured to be attachable to the body of the user 190 or a part of clothing. In another aspect, the controller 160 may be configured to output at least one of vibration, sound, and light based on a signal sent from the computer 200. In another aspect, the controller 160 receives an operation given by the user 190 in order to control the position and movement of an object arranged in the virtual space.

モーションセンサ130は、ある局面において、ユーザの手に取り付けられて、ユーザの手の動きを検出する。例えば、モーションセンサ130は、手の回転速度、回転数等を検出する。検出された信号は、コンピュータ200に送られる。モーションセンサ130は、例えば、手袋型のコントローラ160に設けられている。ある実施の形態において、現実空間における安全のため、コントローラ160は、手袋型のようにユーザ190の手に装着されることにより容易に飛んで行かないものに装着されるのが望ましい。別の局面において、ユーザ190に装着されないセンサがユーザ190の手の動きを検出してもよい。例えば、ユーザ190を撮影するカメラの信号が、ユーザ190の動作を表す信号として、コンピュータ200に入力されてもよい。モーションセンサ130とコンピュータ200とは、有線により、または無線により互いに接続される。無線の場合、通信形態は特に限られず、例えば、Bluetooth(登録商標)その他の公知の通信手法が用いられる。   In one aspect, the motion sensor 130 is attached to the user's hand and detects the movement of the user's hand. For example, the motion sensor 130 detects the rotation speed, rotation speed, etc. of the hand. The detected signal is sent to the computer 200. The motion sensor 130 is provided in a glove-type controller 160, for example. In some embodiments, for safety in real space, it is desirable that the controller 160 be mounted on something that does not fly easily by being mounted on the hand of the user 190, such as a glove shape. In another aspect, a sensor that is not worn by the user 190 may detect the hand movement of the user 190. For example, a signal from a camera that captures the user 190 may be input to the computer 200 as a signal representing the operation of the user 190. The motion sensor 130 and the computer 200 are connected to each other by wire or wirelessly. In the case of wireless communication, the communication form is not particularly limited, and for example, Bluetooth (registered trademark) or other known communication methods are used.

[ハードウェア構成]
図2を参照して、本実施の形態に係るコンピュータ200について説明する。図2は、一局面に従うコンピュータ200のハードウェア構成の一例を表すブロック図である。コンピュータ200は、主たる構成要素として、プロセッサ10と、メモリ11と、ストレージ12と、入出力インターフェース13と、通信インターフェース14とを備える。各構成要素は、それぞれ、バス15に接続されている。
[Hardware configuration]
A computer 200 according to the present embodiment will be described with reference to FIG. FIG. 2 is a block diagram illustrating an example of a hardware configuration of computer 200 according to one aspect. The computer 200 includes a processor 10, a memory 11, a storage 12, an input / output interface 13, and a communication interface 14 as main components. Each component is connected to the bus 15.

プロセッサ10は、コンピュータ200に与えられる信号に基づいて、あるいは、予め定められた条件が成立したことに基づいて、メモリ11またはストレージ12に格納されているプログラムに含まれる一連の命令を実行する。ある局面において、プロセッサ10は、CPU(Central Processing Unit)、MPU(Micro Processor Unit)、FPGA(Field-Programmable Gate Array)その他のデバイスとして実現される。   The processor 10 executes a series of instructions included in the program stored in the memory 11 or the storage 12 based on a signal given to the computer 200 or based on the establishment of a predetermined condition. In one aspect, the processor 10 is realized as a CPU (Central Processing Unit), an MPU (Micro Processor Unit), an FPGA (Field-Programmable Gate Array), or other device.

メモリ11は、プログラムおよびデータを一時的に保存する。プログラムは、例えば、ストレージ12からロードされる。メモリ11に保存されるデータは、コンピュータ200に入力されたデータと、プロセッサ10によって生成されたデータとを含む。ある局面において、メモリ11は、RAM(Random Access Memory)その他の揮発性メモリとして実現される。   The memory 11 temporarily stores programs and data. The program is loaded from the storage 12, for example. Data stored in the memory 11 includes data input to the computer 200 and data generated by the processor 10. In one aspect, the memory 11 is realized as a RAM (Random Access Memory) or other volatile memory.

ストレージ12は、プログラムおよびデータを永続的に保持する。ストレージ12は、例えば、ROM(Read-Only Memory)、ハードディスク装置、フラッシュメモリ、その他の不揮発性記憶装置として実現される。ストレージ12に格納されるプログラムは、HMDシステム100において仮想空間を提供するためのプログラム、シミュレーションプログラム、ゲームプログラム、ユーザ認証プログラム、および他のコンピュータ200との通信を実現するためのプログラム等を含む。ストレージ12に格納されるデータは、仮想空間を規定するためのデータおよびオブジェクト等を含む。   The storage 12 holds programs and data permanently. The storage 12 is realized as, for example, a ROM (Read-Only Memory), a hard disk device, a flash memory, and other nonvolatile storage devices. The programs stored in the storage 12 include a program for providing a virtual space in the HMD system 100, a simulation program, a game program, a user authentication program, a program for realizing communication with another computer 200, and the like. The data stored in the storage 12 includes data and objects for defining the virtual space.

なお、別の局面において、ストレージ12は、メモリカードのように着脱可能な記憶装置として実現されてもよい。さらに別の局面において、コンピュータ200に内蔵されたストレージ12の代わりに、外部の記憶装置に保存されているプログラムおよびデータを使用する構成が使用されてもよい。このような構成によれば、例えば、アミューズメント施設のように複数のHMDシステム100が使用される場面において、プログラムおよびデータ等の更新を一括して行うことが可能になる。   In another aspect, the storage 12 may be realized as a removable storage device such as a memory card. In still another aspect, a configuration using a program and data stored in an external storage device may be used instead of the storage 12 built in the computer 200. According to such a configuration, for example, in a scene where a plurality of HMD systems 100 are used like an amusement facility, it is possible to update programs and data in a batch.

ある実施の形態において、入出力インターフェース13は、HMD装置110、HMDセンサ120またはモーションセンサ130との間で信号を通信する。ある局面において、入出力インターフェース13は、USB(Universal Serial Bus)インターフェース、DVI(Digital Visual Interface)、HDMI(登録商標)(High-Definition Multimedia Interface)その他の端子を用いて実現される。なお、入出力インターフェース13は上述のものに限られない。例えば、入出力インターフェース13は、Bluetooth(登録商標)等の無線通信インターフェースを含み得る。   In some embodiments, the input / output interface 13 communicates signals with the HMD device 110, the HMD sensor 120, or the motion sensor 130. In one aspect, the input / output interface 13 is realized using a USB (Universal Serial Bus) interface, a DVI (Digital Visual Interface), an HDMI (registered trademark) (High-Definition Multimedia Interface), or other terminals. The input / output interface 13 is not limited to the above. For example, the input / output interface 13 may include a wireless communication interface such as Bluetooth (registered trademark).

ある実施の形態において、入出力インターフェース13は、さらに、コントローラ160と通信し得る。例えば、入出力インターフェース13は、モーションセンサ130から出力された信号の入力を受ける。別の局面において、入出力インターフェース13は、プロセッサ10から出力された命令を、コントローラ160に送る。当該命令は、振動、音声出力、発光等をコントローラ160に指示する。コントローラ160は、当該命令を受信すると、その命令に応じて、振動、音声出力または発光のいずれかを実行する。   In certain embodiments, the input / output interface 13 may further communicate with the controller 160. For example, the input / output interface 13 receives an input of a signal output from the motion sensor 130. In another aspect, the input / output interface 13 sends an instruction output from the processor 10 to the controller 160. The command instructs the controller 160 to vibrate, output sound, emit light, and the like. When the controller 160 receives the command, the controller 160 executes vibration, sound output, or light emission according to the command.

通信インターフェース14は、ネットワーク19に接続されて、ネットワーク19に接続されている他のコンピュータ(例えば、サーバ150)と通信する。ある局面において、通信インターフェース14は、例えば、LAN(Local Area Network)その他の有線通信インターフェース、あるいは、WiFi(Wireless Fidelity)、Bluetooth(登録商標)、NFC(Near Field Communication)その他の無線通信インターフェースとして実現される。なお、通信インターフェース14は上述のものに限られない。   The communication interface 14 is connected to the network 19 and communicates with other computers (for example, the server 150) connected to the network 19. In one aspect, the communication interface 14 is realized as, for example, a local area network (LAN) or other wired communication interface, or a wireless communication interface such as WiFi (Wireless Fidelity), Bluetooth (registered trademark), NFC (Near Field Communication), or the like. Is done. The communication interface 14 is not limited to the above.

ある局面において、プロセッサ10は、ストレージ12にアクセスし、ストレージ12に格納されている1つ以上のプログラムをメモリ11にロードし、当該プログラムに含まれる一連の命令を実行する。当該1つ以上のプログラムは、コンピュータ200のオペレーティングシステム、仮想空間を提供するためのアプリケーションプログラム、コントローラ160を用いて仮想空間で実行可能なゲームソフトウェア等を含み得る。プロセッサ10は、入出力インターフェース13を介して、仮想空間を提供するための信号をHMD装置110に送る。HMD装置110は、その信号に基づいてディスプレイ112に映像を表示する。   In one aspect, the processor 10 accesses the storage 12, loads one or more programs stored in the storage 12 into the memory 11, and executes a series of instructions included in the program. The one or more programs may include an operating system of the computer 200, an application program for providing a virtual space, game software that can be executed in the virtual space using the controller 160, and the like. The processor 10 sends a signal for providing a virtual space to the HMD device 110 via the input / output interface 13. The HMD device 110 displays an image on the display 112 based on the signal.

サーバ150は、ネットワーク19を介してHMDシステム100の各々の制御装置と接続される。図2に示される例では、サーバ150は、HMDシステム100A,100B,100C,100Dを含む複数のHMDシステム100を互いに通信可能に接続する。これにより、共通の仮想空間を用いた仮想体験が各HMDシステムを使用するユーザに提供される。各HMDシステム100はいずれも同様の構成を備える。例えば、ユーザ190AのHMDシステム100AはHMD装置110Aおよびコンピュータ200Aを有する。ユーザ190BのHMDシステム100BはHMD装置110Bおよびコンピュータ200Bを有する。ユーザ190CのHMDシステム100CはHMD装置110Cおよびコンピュータ200Cを有する。ユーザ190DのHMDシステム100DはHMD装置110Dおよびコンピュータ200Dを有する。ただし、各HMDシステム100は、互いに異なる機種であってもよいし、互いに異なる性能(処理性能、およびユーザ動作の検知に関する検知性能等)を有してもよい。   The server 150 is connected to each control device of the HMD system 100 via the network 19. In the example shown in FIG. 2, the server 150 connects a plurality of HMD systems 100 including the HMD systems 100A, 100B, 100C, and 100D so that they can communicate with each other. Thereby, the virtual experience using a common virtual space is provided to the user who uses each HMD system. Each HMD system 100 has the same configuration. For example, the HMD system 100A of the user 190A has an HMD device 110A and a computer 200A. The HMD system 100B of the user 190B has an HMD device 110B and a computer 200B. The HMD system 100C of the user 190C has an HMD device 110C and a computer 200C. The HMD system 100D of the user 190D has an HMD device 110D and a computer 200D. However, each HMD system 100 may be a different model, or may have different performance (processing performance, detection performance related to detection of user action, etc.).

なお、図2に示される例では、コンピュータ200がHMD装置110の外部に設けられる構成が示されているが、別の局面において、コンピュータ200は、HMD装置110に内蔵されてもよい。一例として、ディスプレイ112を含む携帯型の情報通信端末(例えば、スマートフォン)がコンピュータ200として機能してもよい。図2では四つのHMDシステム100A〜100Dを示すが、HMDシステム100の台数は、複数であればいくつでもよい。   In the example illustrated in FIG. 2, the configuration in which the computer 200 is provided outside the HMD device 110 is illustrated. However, in another aspect, the computer 200 may be incorporated in the HMD device 110. As an example, a portable information communication terminal (for example, a smartphone) including the display 112 may function as the computer 200. Although four HMD systems 100A to 100D are shown in FIG. 2, the number of HMD systems 100 may be any number as long as it is plural.

また、コンピュータ200は、複数のHMD装置110に共通して用いられる構成であってもよい。このような構成によれば、例えば、複数のユーザに同一の仮想空間を提供することもできるので、各ユーザは同一の仮想空間で他のユーザと同一のアプリケーションを楽しむことができる。なお、このような場合、本実施形態における複数のHMDシステム100は、入出力インターフェース13により、コンピュータ200に直接接続されてもよい。また、本実施形態におけるサーバ150の各機能(例えば後述する同期処理等)は、コンピュータ200に実装されてもよい。   Further, the computer 200 may be configured to be used in common for the plurality of HMD devices 110. According to such a configuration, for example, the same virtual space can be provided to a plurality of users, so that each user can enjoy the same application as other users in the same virtual space. In such a case, the plurality of HMD systems 100 in this embodiment may be directly connected to the computer 200 by the input / output interface 13. In addition, each function (for example, synchronization processing described later) of the server 150 in the present embodiment may be implemented in the computer 200.

ある実施の形態において、HMDシステム100では、グローバル座標系が予め設定されている。グローバル座標系は、現実空間における鉛直方向、鉛直方向に直交する水平方向、ならびに、鉛直方向および水平方向の双方に直交する前後方向にそれぞれ平行な、3つの基準方向(軸)を有する。本実施の形態では、グローバル座標系は視点座標系の一つである。そこで、グローバル座標系における水平方向、鉛直方向(上下方向)、および前後方向は、それぞれ、x軸、y軸、z軸と規定される。より具体的には、グローバル座標系において、x軸は現実空間の水平方向に平行である。y軸は、現実空間の鉛直方向に平行である。z軸は現実空間の前後方向に平行である。   In an embodiment, in the HMD system 100, a global coordinate system is set in advance. The global coordinate system has three reference directions (axes) parallel to the vertical direction in the real space, the horizontal direction orthogonal to the vertical direction, and the front-rear direction orthogonal to both the vertical direction and the horizontal direction. In the present embodiment, the global coordinate system is one of the viewpoint coordinate systems. Therefore, the horizontal direction, the vertical direction (up-down direction), and the front-rear direction in the global coordinate system are defined as an x-axis, a y-axis, and a z-axis, respectively. More specifically, in the global coordinate system, the x axis is parallel to the horizontal direction of the real space. The y axis is parallel to the vertical direction of the real space. The z axis is parallel to the front-rear direction of the real space.

ある局面において、HMDセンサ120は、赤外線センサを含む。赤外線センサが、HMD装置110の各光源から発せられた赤外線をそれぞれ検出すると、HMD装置110の存在を検出する。HMDセンサ120は、さらに、各点の値(グローバル座標系における各座標値)に基づいて、HMD装置110を装着したユーザ190の動きに応じた、現実空間内におけるHMD装置110の位置および傾きを検出する。より詳しくは、HMDセンサ120は、経時的に検出された各値を用いて、HMD装置110の位置および傾きの時間的変化を検出できる。   In one aspect, HMD sensor 120 includes an infrared sensor. When the infrared sensor detects each infrared ray emitted from each light source of the HMD device 110, the presence of the HMD device 110 is detected. The HMD sensor 120 further determines the position and inclination of the HMD device 110 in the real space according to the movement of the user 190 wearing the HMD device 110 based on the value of each point (each coordinate value in the global coordinate system). To detect. More specifically, the HMD sensor 120 can detect temporal changes in the position and tilt of the HMD device 110 using each value detected over time.

グローバル座標系は現実空間の座標系と平行である。したがって、HMDセンサ120によって検出されたHMD装置110の各傾きは、グローバル座標系におけるHMD装置110の3軸周りの各傾きに相当する。HMDセンサ120は、グローバル座標系におけるHMD装置110の傾きに基づき、uvw視野座標系をHMD装置110に設定する。HMD装置110に設定されるuvw視野座標系は、HMD装置110を装着したユーザ190が仮想空間において物体を見る際の視点座標系に対応する。   The global coordinate system is parallel to the real space coordinate system. Therefore, each inclination of the HMD device 110 detected by the HMD sensor 120 corresponds to each inclination around the three axes of the HMD device 110 in the global coordinate system. The HMD sensor 120 sets the uvw visual field coordinate system to the HMD device 110 based on the inclination of the HMD device 110 in the global coordinate system. The uvw visual field coordinate system set in the HMD device 110 corresponds to a viewpoint coordinate system when the user 190 wearing the HMD device 110 views an object in the virtual space.

[uvw視野座標系]
図3を参照して、uvw視野座標系について説明する。図3は、ある実施の形態に従うHMD装置110に設定されるuvw視野座標系を概念的に表す図である。HMDセンサ120は、HMD装置110の起動時に、グローバル座標系におけるHMD装置110の位置および傾きを検出する。プロセッサ10は、検出された値に基づいて、uvw視野座標系をHMD装置110に設定する。
[Uvw visual field coordinate system]
The uvw visual field coordinate system will be described with reference to FIG. FIG. 3 is a diagram conceptually showing a uvw visual field coordinate system set in HMD device 110 according to an embodiment. The HMD sensor 120 detects the position and inclination of the HMD device 110 in the global coordinate system when the HMD device 110 is activated. The processor 10 sets the uvw visual field coordinate system in the HMD device 110 based on the detected value.

図3に示されるように、HMD装置110は、HMD装置110を装着したユーザの頭部を中心(原点)とした3次元のuvw視野座標系を設定する。より具体的には、HMD装置110は、グローバル座標系を規定する水平方向、鉛直方向、および前後方向(x軸、y軸、z軸)を、グローバル座標系内においてHMD装置110の各軸周りの傾きだけ各軸周りにそれぞれ傾けることによって新たに得られる3つの方向を、HMD装置110におけるuvw視野座標系のピッチ方向(u軸)、ヨー方向(v軸)、およびロール方向(w軸)として設定する。   As shown in FIG. 3, the HMD device 110 sets a three-dimensional uvw visual field coordinate system with the head (origin) of the user wearing the HMD device 110 as the center (origin). More specifically, the HMD device 110 uses the horizontal direction, the vertical direction, and the front-rear direction (x axis, y axis, z axis) that define the global coordinate system around each axis of the HMD device 110 in the global coordinate system. The three new directions obtained by inclining around the respective axes by the inclination of the pitch are the pitch direction (u-axis), yaw direction (v-axis), and roll direction (w-axis) of the uvw visual field coordinate system in the HMD device 110. Set as.

ある局面において、HMD装置110を装着したユーザ190が直立し、かつ、正面を視認している場合、プロセッサ10は、グローバル座標系に平行なuvw視野座標系をHMD装置110に設定する。この場合、グローバル座標系における水平方向(x軸)、鉛直方向(y軸)、および前後方向(z軸)は、HMD装置110におけるuvw視野座標系のピッチ方向(u軸)、ヨー方向(v軸)、およびロール方向(w軸)に一致する。   In one aspect, when the user 190 wearing the HMD device 110 stands upright and is viewing the front, the processor 10 sets the uvw visual field coordinate system parallel to the global coordinate system in the HMD device 110. In this case, the horizontal direction (x-axis), vertical direction (y-axis), and front-rear direction (z-axis) in the global coordinate system are the pitch direction (u-axis) and yaw direction (v Axis) and the roll direction (w-axis).

uvw視野座標系がHMD装置110に設定された後、HMDセンサ120は、HMD装置110の動きに基づいて、設定されたuvw視野座標系におけるHMD装置110の傾き(傾きの変化量)を検出できる。この場合、HMDセンサ120は、HMD装置110の傾きとして、uvw視野座標系におけるHMD装置110のピッチ角(θu)、ヨー角(θv)、およびロール角(θw)をそれぞれ検出する。ピッチ角(θu)は、uvw視野座標系におけるピッチ方向周りのHMD装置110の傾き角度を表す。ヨー角(θv)は、uvw視野座標系におけるヨー方向周りのHMD装置110の傾き角度を表す。ロール角(θw)は、uvw視野座標系におけるロール方向周りのHMD装置110の傾き角度を表す。   After the uvw visual field coordinate system is set in the HMD device 110, the HMD sensor 120 can detect the inclination of the HMD device 110 in the set uvw visual field coordinate system based on the movement of the HMD device 110. . In this case, the HMD sensor 120 detects the pitch angle (θu), yaw angle (θv), and roll angle (θw) of the HMD device 110 in the uvw visual field coordinate system as the inclination of the HMD device 110. The pitch angle (θu) represents the tilt angle of the HMD device 110 around the pitch direction in the uvw visual field coordinate system. The yaw angle (θv) represents the tilt angle of the HMD device 110 around the yaw direction in the uvw visual field coordinate system. The roll angle (θw) represents the tilt angle of the HMD device 110 around the roll direction in the uvw visual field coordinate system.

HMDセンサ120は、検出されたHMD装置110の傾き角度に基づいて、HMD装置110が動いた後のHMD装置110におけるuvw視野座標系を、HMD装置110に設定する。HMD装置110と、HMD装置110のuvw視野座標系との関係は、HMD装置110の位置および傾きに関わらず、常に一定である。HMD装置110の位置および傾きが変わると、当該位置および傾きの変化に連動して、グローバル座標系におけるHMD装置110のuvw視野座標系の位置および傾きが変化する。   Based on the detected tilt angle of the HMD device 110, the HMD sensor 120 sets the uvw visual field coordinate system in the HMD device 110 after the HMD device 110 has moved to the HMD device 110. The relationship between the HMD device 110 and the uvw visual field coordinate system of the HMD device 110 is always constant regardless of the position and inclination of the HMD device 110. When the position and inclination of the HMD device 110 change, the position and inclination of the uvw visual field coordinate system of the HMD device 110 in the global coordinate system change in conjunction with the change of the position and inclination.

ある局面において、HMDセンサ120は、赤外線センサからの出力に基づいて取得される赤外線の光強度および複数の点間の相対的な位置関係(例えば、各点間の距離など)に基づいて、HMD装置110の現実空間内における位置を、HMDセンサ120に対する相対位置として特定してもよい。また、プロセッサ10は、特定された相対位置に基づいて、現実空間内(グローバル座標系)におけるHMD装置110のuvw視野座標系の原点を決定してもよい。   In one aspect, the HMD sensor 120 is based on the infrared light intensity acquired based on the output from the infrared sensor and the relative positional relationship between a plurality of points (for example, the distance between the points). The position of the device 110 in the real space may be specified as a relative position with respect to the HMD sensor 120. Further, the processor 10 may determine the origin of the uvw visual field coordinate system of the HMD device 110 in the real space (global coordinate system) based on the specified relative position.

[仮想空間]
図4を参照して、仮想空間についてさらに説明する。図4は、ある実施の形態に従う仮想空間2を表現する一態様を概念的に表す図である。仮想空間2は、中心21の360度方向の全体を覆う全天球状の構造を有する。図4では、説明を複雑にしないために、仮想空間2のうちの上半分の天球が例示されている。仮想空間2では各メッシュが規定される。各メッシュの位置は、仮想空間2に規定されるXYZ座標系における座標値として予め規定されている。コンピュータ200は、仮想空間2に展開可能なコンテンツ(静止画、動画等)を構成する各部分画像を、仮想空間2において対応する各メッシュにそれぞれ対応付けて、ユーザによって視認可能な仮想空間画像22が展開される仮想空間2をユーザに提供する。
[Virtual space]
The virtual space will be further described with reference to FIG. FIG. 4 is a diagram conceptually showing one aspect of expressing virtual space 2 according to an embodiment. The virtual space 2 has a spherical structure that covers the entire 360 ° direction of the center 21. In FIG. 4, the upper half of the celestial sphere in the virtual space 2 is illustrated in order not to complicate the description. In the virtual space 2, each mesh is defined. The position of each mesh is defined in advance as coordinate values in the XYZ coordinate system defined in the virtual space 2. The computer 200 associates each partial image constituting content (still image, moving image, etc.) that can be developed in the virtual space 2 with each corresponding mesh in the virtual space 2, and the virtual space image 22 that can be visually recognized by the user. Is provided to the user.

ある局面において、仮想空間2では、中心21を原点とするXYZ座標系が規定される。XYZ座標系は、例えば、グローバル座標系に平行である。XYZ座標系は視点座標系の一種であるため、XYZ座標系における水平方向、鉛直方向(上下方向)、および前後方向は、それぞれX軸、Y軸、Z軸として規定される。したがって、XYZ座標系のX軸(水平方向)がグローバル座標系のx軸と平行であり、XYZ座標系のY軸(鉛直方向)がグローバル座標系のy軸と平行であり、XYZ座標系のZ軸(前後方向)がグローバル座標系のz軸と平行である。仮想空間2内の各位置は、XYZ座標系における座標値によって一意に特定される。   In one aspect, the virtual space 2 defines an XYZ coordinate system with the center 21 as the origin. The XYZ coordinate system is, for example, parallel to the global coordinate system. Since the XYZ coordinate system is a kind of viewpoint coordinate system, the horizontal direction, vertical direction (vertical direction), and front-rear direction in the XYZ coordinate system are defined as an X axis, a Y axis, and a Z axis, respectively. Therefore, the X axis (horizontal direction) of the XYZ coordinate system is parallel to the x axis of the global coordinate system, the Y axis (vertical direction) of the XYZ coordinate system is parallel to the y axis of the global coordinate system, and The Z axis (front-rear direction) is parallel to the z axis of the global coordinate system. Each position in the virtual space 2 is uniquely specified by a coordinate value in the XYZ coordinate system.

HMD装置110の起動時、すなわちHMD装置110の初期状態において、仮想カメラ1は、例えば仮想空間2の中心21に配置される。仮想カメラ1は、現実空間におけるHMD装置110の動きに連動して、仮想空間2を同様に移動する。これにより、現実空間におけるHMD装置110の位置および傾きの変化が、仮想空間2において同様に再現される。   When the HMD device 110 is activated, that is, in the initial state of the HMD device 110, the virtual camera 1 is disposed at the center 21 of the virtual space 2, for example. The virtual camera 1 similarly moves in the virtual space 2 in conjunction with the movement of the HMD device 110 in the real space. Thereby, changes in the position and inclination of the HMD device 110 in the real space are similarly reproduced in the virtual space 2.

仮想カメラ1には、HMD装置110の場合と同様に、uvw視野座標系が規定される。仮想空間2における仮想カメラ1のuvw視野座標系は、現実空間(グローバル座標系)におけるHMD装置110のuvw視野座標系に連動するように規定されている。したがって、HMD装置110の傾きが変化すると、それに応じて、仮想カメラ1の傾きも変化する。また、仮想カメラ1は、HMD装置110を装着したユーザの現実空間における移動に連動して、仮想空間2において移動することもできる。   As in the case of the HMD device 110, the uvw visual field coordinate system is defined for the virtual camera 1. The uvw visual field coordinate system of the virtual camera 1 in the virtual space 2 is defined so as to be linked to the uvw visual field coordinate system of the HMD device 110 in the real space (global coordinate system). Therefore, when the inclination of the HMD device 110 changes, the inclination of the virtual camera 1 also changes accordingly. The virtual camera 1 can also move in the virtual space 2 in conjunction with the movement of the user wearing the HMD device 110 in the real space.

仮想カメラ1の向きは、仮想カメラ1の位置および傾きに応じて決まるので、ユーザが仮想空間画像22を視認する際に基準となる視線(基準視線5)は、仮想カメラ1の向きに応じて決まる。コンピュータ200のプロセッサ10は、基準視線5に基づいて、仮想空間2における視界領域23を規定する。視界領域23は、仮想空間2のうち、HMD装置110を装着したユーザの視界に対応する。   Since the orientation of the virtual camera 1 is determined according to the position and inclination of the virtual camera 1, the reference line of sight (reference line of sight 5) when the user visually recognizes the virtual space image 22 depends on the orientation of the virtual camera 1. Determined. The processor 10 of the computer 200 defines the visual field region 23 in the virtual space 2 based on the reference line of sight 5. The view area 23 corresponds to the view of the user wearing the HMD device 110 in the virtual space 2.

注視センサ140によって検出されるユーザ190の視線方向は、ユーザ190が物体を視認する際の視点座標系における方向である。HMD装置110のuvw視野座標系は、ユーザ190がディスプレイ112を視認する際の視点座標系に等しい。また、仮想カメラ1のuvw視野座標系は、HMD装置110のuvw視野座標系に連動している。したがって、ある局面に従うHMDシステム100は、注視センサ140によって検出されたユーザ190の視線方向を、仮想カメラ1のuvw視野座標系におけるユーザの視線方向とみなすことができる。   The gaze direction of the user 190 detected by the gaze sensor 140 is a direction in the viewpoint coordinate system when the user 190 visually recognizes the object. The uvw visual field coordinate system of the HMD device 110 is equal to the viewpoint coordinate system when the user 190 visually recognizes the display 112. The uvw visual field coordinate system of the virtual camera 1 is linked to the uvw visual field coordinate system of the HMD device 110. Therefore, the HMD system 100 according to a certain aspect can regard the line-of-sight direction of the user 190 detected by the gaze sensor 140 as the line-of-sight direction of the user in the uvw visual field coordinate system of the virtual camera 1.

[ユーザの視線]
図5を参照して、ユーザの視線方向の決定について説明する。図5は、ある実施の形態に従うHMD装置110を装着するユーザ190の頭部を上から表した図である。
[User's line of sight]
With reference to FIG. 5, determination of the user's line-of-sight direction will be described. FIG. 5 is a diagram showing the head of user 190 wearing HMD device 110 according to an embodiment from above.

ある局面において、注視センサ140は、ユーザ190の右目および左目の各視線を検出する。ある局面において、ユーザ190が近くを見ている場合、注視センサ140は、視線R1およびL1を検出する。別の局面において、ユーザ190が遠くを見ている場合、注視センサ140は、視線R2およびL2を検出する。この場合、ロール方向wに対して視線R2およびL2がなす角度は、ロール方向wに対して視線R1およびL1がなす角度よりも小さい。注視センサ140は、検出結果をコンピュータ200に送信する。   In one aspect, gaze sensor 140 detects each line of sight of user 190's right eye and left eye. In a certain aspect, when the user 190 is looking near, the gaze sensor 140 detects the lines of sight R1 and L1. In another aspect, when the user 190 is looking far away, the gaze sensor 140 detects the lines of sight R2 and L2. In this case, the angle formed by the lines of sight R2 and L2 with respect to the roll direction w is smaller than the angle formed by the lines of sight R1 and L1 with respect to the roll direction w. The gaze sensor 140 transmits the detection result to the computer 200.

コンピュータ200が、視線の検出結果として、視線R1およびL1の検出値を注視センサ140から受信した場合には、その検出値に基づいて、視線R1およびL1の交点である注視点N1を特定する。一方、コンピュータ200は、視線R2およびL2の検出値を注視センサ140から受信した場合には、視線R2およびL2の交点を注視点として特定する。コンピュータ200は、特定した注視点N1の位置に基づき、ユーザ190の視線方向N0を特定する。コンピュータ200は、例えば、ユーザ190の右目Rと左目Lとを結ぶ直線の中点と、注視点N1とを通る直線の延びる方向を、視線方向N0として検出する。視線方向N0は、ユーザ190が両目により実際に視線を向けている方向である。また、視線方向N0は、視界領域23に対してユーザ190が実際に視線を向けている方向に相当する。   When the computer 200 receives the detection values of the lines of sight R1 and L1 from the gaze sensor 140 as the line-of-sight detection result, the computer 200 identifies the point of sight N1 that is the intersection of the lines of sight R1 and L1 based on the detection value. On the other hand, when the detected values of the lines of sight R2 and L2 are received from the gaze sensor 140, the computer 200 specifies the intersection of the lines of sight R2 and L2 as the point of sight. The computer 200 specifies the line-of-sight direction N0 of the user 190 based on the specified position of the gazing point N1. For example, the computer 200 detects the direction in which the straight line passing through the midpoint of the straight line connecting the right eye R and the left eye L of the user 190 and the gazing point N1 extends as the line-of-sight direction N0. The line-of-sight direction N0 is a direction in which the user 190 is actually pointing the line of sight with both eyes. The line-of-sight direction N0 corresponds to the direction in which the user 190 actually directs his / her line of sight with respect to the field-of-view area 23.

また、別の局面において、HMDシステム100は、テレビジョン放送受信チューナを備えてもよい。このような構成によれば、HMDシステム100は、仮想空間2においてテレビ番組を表示することができる。   In another aspect, HMD system 100 may include a television broadcast receiving tuner. According to such a configuration, the HMD system 100 can display a television program in the virtual space 2.

さらに別の局面において、HMDシステム100は、インターネットに接続するための通信回路、あるいは、電話回線に接続するための通話機能を備えていてもよい。   In still another aspect, the HMD system 100 may include a communication circuit for connecting to the Internet or a call function for connecting to a telephone line.

[視界領域]
図6および図7を参照して、視界領域23について説明する。図6は、仮想空間2において視界領域23をX方向から見たYZ断面を表す図である。図7は、仮想空間2において視界領域23をY方向から見たXZ断面を表す図である。
[Visibility area]
With reference to FIGS. 6 and 7, the visual field region 23 will be described. FIG. 6 is a diagram illustrating a YZ cross section of the visual field region 23 viewed from the X direction in the virtual space 2. FIG. 7 is a diagram illustrating an XZ cross section of the visual field region 23 viewed from the Y direction in the virtual space 2.

図6に示されるように、YZ断面における視界領域23は、領域24を含む。領域24は、仮想カメラ1の基準視線5と仮想空間2のYZ断面とによって定義される。プロセッサ10は、仮想空間2における基準視線5を中心として極角αを含む範囲を、領域24として規定する。   As shown in FIG. 6, the visual field region 23 in the YZ cross section includes a region 24. The region 24 is defined by the reference line of sight 5 of the virtual camera 1 and the YZ cross section of the virtual space 2. The processor 10 defines a range including the polar angle α around the reference line of sight 5 in the virtual space 2 as the region 24.

図7に示されるように、XZ断面における視界領域23は、領域25を含む。領域25は、基準視線5と仮想空間2のXZ断面とによって定義される。プロセッサ10は、仮想空間2における基準視線5を中心とした方位角βを含む範囲を、領域25として規定する。   As shown in FIG. 7, the visual field region 23 in the XZ cross section includes a region 25. The region 25 is defined by the reference line of sight 5 and the XZ cross section of the virtual space 2. The processor 10 defines a range including the azimuth angle β around the reference line of sight 5 in the virtual space 2 as a region 25.

ある局面において、HMDシステム100は、コンピュータ200からの信号に基づいて、視界画像をディスプレイ112に表示させることにより、ユーザ190に仮想空間を提供する。視界画像は、仮想空間画像22のうち視界領域23に重畳する部分に相当する。視界領域23内において仮想カメラ1と仮想空間画像22との間に後述する仮想オブジェクトが配置されている場合、視界画像には当該仮想オブジェクトが含まれる。すなわち、視界画像において、仮想空間画像22よりも手前側にある仮想オブジェクトが仮想空間画像22に重畳して表示される。ユーザ190が、頭に装着したHMD装置110を動かすと、その動きに連動して仮想カメラ1も動く。その結果、仮想空間2における視界領域23の位置が変化する。これにより、ディスプレイ112に表示される視界画像は、仮想空間画像22のうち、仮想空間2においてユーザが向いた方向の視界領域23に重畳する画像に更新される。ユーザは、仮想空間2における所望の方向を視認することができる。   In one aspect, the HMD system 100 provides a virtual space to the user 190 by causing the display 112 to display a view field image based on a signal from the computer 200. The visual field image corresponds to a portion of the virtual space image 22 that is superimposed on the visual field region 23. When a virtual object described later is arranged between the virtual camera 1 and the virtual space image 22 in the view field area 23, the view object image includes the virtual object. That is, in the view field image, the virtual object on the near side of the virtual space image 22 is displayed superimposed on the virtual space image 22. When the user 190 moves the HMD device 110 worn on the head, the virtual camera 1 also moves in conjunction with the movement. As a result, the position of the visual field area 23 in the virtual space 2 changes. As a result, the view image displayed on the display 112 is updated to an image that is superimposed on the view region 23 in the virtual space 2 in the direction in which the user faces in the virtual space image 22. The user can visually recognize a desired direction in the virtual space 2.

ユーザ190は、HMD装置110を装着している間、現実世界を視認することなく、仮想空間2に展開される仮想空間画像22のみを視認できる。そのため、HMDシステム100は、仮想空間2への高い没入感覚をユーザに与えることができる。   The user 190 can visually recognize only the virtual space image 22 developed in the virtual space 2 without visually recognizing the real world while wearing the HMD device 110. Therefore, the HMD system 100 can give the user a high sense of immersion in the virtual space 2.

ある局面において、プロセッサ10は、HMD装置110を装着したユーザ190の現実空間における移動に連動して、仮想空間2において仮想カメラ1を移動し得る。この場合、プロセッサ10は、仮想空間2における仮想カメラ1の位置および傾きに基づいて、HMD装置110のディスプレイ112に投影される画像領域(すなわち、仮想空間2における視界領域23)を特定する。すなわち、仮想カメラ1によって、仮想空間2におけるユーザ190の視野(視界)が定義される。   In one aspect, the processor 10 can move the virtual camera 1 in the virtual space 2 in conjunction with movement of the user 190 wearing the HMD device 110 in real space. In this case, the processor 10 specifies an image region (that is, a view field region 23 in the virtual space 2) projected on the display 112 of the HMD device 110 based on the position and inclination of the virtual camera 1 in the virtual space 2. That is, the visual field (view) of the user 190 in the virtual space 2 is defined by the virtual camera 1.

ある実施の形態に従うと、仮想カメラ1は、二つの仮想カメラ、すなわち、右目用の画像を提供するための仮想カメラと、左目用の画像を提供するための仮想カメラとを含むことが望ましい。また、ユーザ190が3次元の仮想空間2を認識できるように、適切な視差が、二つの仮想カメラに設定されていることが好ましい。本実施の形態においては、仮想カメラ1が二つの仮想カメラを含み、二つの仮想カメラのロール方向が合成されることによって生成されるロール方向(w)がHMD装置110のロール方向(w)に適合されるように構成されているものとして、本開示に係る技術思想を例示する。   According to an embodiment, the virtual camera 1 preferably includes two virtual cameras, that is, a virtual camera for providing an image for the right eye and a virtual camera for providing an image for the left eye. Moreover, it is preferable that appropriate parallax is set in the two virtual cameras so that the user 190 can recognize the three-dimensional virtual space 2. In the present embodiment, the virtual camera 1 includes two virtual cameras, and the roll direction (w) generated by combining the roll directions of the two virtual cameras is the roll direction (w) of the HMD device 110. The technical idea concerning this indication is illustrated as what is constituted so that it may be adapted.

[コントローラ]
図8を参照して、コントローラ160の一例について説明する。図8は、ある実施の形態に従うコントローラ160の概略構成を表す図である。
[controller]
An example of the controller 160 will be described with reference to FIG. FIG. 8 is a diagram showing a schematic configuration of controller 160 according to an embodiment.

図8の状態(A)に示されるように、ある局面において、コントローラ160は、右コントローラ160Rと左コントローラ(図示しない)とを含み得る。右コントローラ160Rは、ユーザ190の右手で操作される。左コントローラは、ユーザ190の左手で操作される。ある局面において、右コントローラ160Rと左コントローラとは、別個の装置として対称に構成される。したがって、ユーザ190は、右コントローラ160Rを把持した右手と、左コントローラを把持した左手とをそれぞれ自由に動かすことができる。別の局面において、コントローラ160は両手の操作を受け付ける一体型のコントローラであってもよい。以下、右コントローラ160Rについて説明する。   As shown in the state (A) of FIG. 8, in one aspect, the controller 160 may include a right controller 160R and a left controller (not shown). The right controller 160R is operated with the right hand of the user 190. The left controller is operated with the left hand of the user 190. In one aspect, the right controller 160R and the left controller are configured symmetrically as separate devices. Therefore, the user 190 can freely move the right hand holding the right controller 160R and the left hand holding the left controller. In another aspect, the controller 160 may be an integrated controller that receives operations of both hands. Hereinafter, the right controller 160R will be described.

右コントローラ160Rは、グリップ30と、フレーム31と、天面32とを備える。グリップ30は、ユーザ190の右手によって把持されるように構成されている。例えば、グリップ30は、ユーザ190の右手の掌と3本の指(中指、薬指、小指)とによって保持され得る。   The right controller 160R includes a grip 30, a frame 31, and a top surface 32. The grip 30 is configured to be held by the right hand of the user 190. For example, the grip 30 can be held by the palm of the right hand of the user 190 and three fingers (middle finger, ring finger, little finger).

グリップ30は、ボタン33,34と、モーションセンサ130とを含む。ボタン33は、グリップ30の側面に配置され、右手の中指による操作を受け付ける。ボタン34は、グリップ30の前面に配置され、右手の人差し指による操作を受け付ける。ある局面において、ボタン33,34は、トリガー式のボタンとして構成される。モーションセンサ130は、グリップ30の筐体に内蔵されている。なお、ユーザ190の動作がカメラその他の装置によってユーザ190の周りから検出可能である場合には、グリップ30は、モーションセンサ130を備えなくてもよい。   The grip 30 includes buttons 33 and 34 and a motion sensor 130. The button 33 is disposed on the side surface of the grip 30 and receives an operation with the middle finger of the right hand. The button 34 is disposed in front of the grip 30 and accepts an operation with the index finger of the right hand. In one aspect, the buttons 33 and 34 are configured as trigger buttons. The motion sensor 130 is built in the housing of the grip 30. Note that when the operation of the user 190 can be detected from around the user 190 by a camera or other device, the grip 30 may not include the motion sensor 130.

フレーム31は、その円周方向に沿って配置された複数の赤外線LED35を含む。赤外線LED35は、コントローラ160を使用するプログラムの実行中に、当該プログラムの進行に合わせて赤外線を発光する。赤外線LED35から発せられた赤外線は、右コントローラ160Rと左コントローラとの各位置および姿勢(傾き、向き)等を検出するために使用され得る。図8に示される例では、二列に配置された赤外線LED35が示されているが、配列の数は図8に示されるものに限られない。一列あるいは3列以上の配列が使用されてもよい。   The frame 31 includes a plurality of infrared LEDs 35 arranged along the circumferential direction. The infrared LED 35 emits infrared light in accordance with the progress of the program during the execution of the program using the controller 160. The infrared rays emitted from the infrared LED 35 can be used to detect the positions and postures (tilt, orientation), etc., of the right controller 160R and the left controller. In the example shown in FIG. 8, infrared LEDs 35 arranged in two rows are shown, but the number of arrays is not limited to that shown in FIG. An array of one or more columns may be used.

天面32は、ボタン36,37と、アナログスティック38とを備える。ボタン36,37は、プッシュ式ボタンとして構成される。ボタン36,37は、ユーザ190の右手の親指による操作を受け付ける。アナログスティック38は、ある局面において、初期位置(ニュートラルの位置)から360度任意の方向への操作を受け付ける。当該操作は、例えば、仮想空間2に配置されるオブジェクトを移動させるための操作を含む。   The top surface 32 includes buttons 36 and 37 and an analog stick 38. The buttons 36 and 37 are configured as push buttons. The buttons 36 and 37 receive an operation with the thumb of the right hand of the user 190. In one aspect, the analog stick 38 accepts an operation in an arbitrary direction of 360 degrees from the initial position (neutral position). The operation includes, for example, an operation for moving an object arranged in the virtual space 2.

ある局面において、右コントローラ160Rおよび左コントローラは、赤外線LED35その他の部材を駆動するための電池を含む。電池は、充電式、ボタン型、乾電池型等を含むが、これらに限定されない。別の局面において、右コントローラ160Rおよび左コントローラは、例えば、コンピュータ200のUSBインターフェースに接続され得る。この場合、右コントローラ160Rおよび左コントローラは、電池を必要としない。   In one aspect, the right controller 160R and the left controller include a battery for driving the infrared LED 35 and other members. The battery includes, but is not limited to, a rechargeable type, a button type, a dry battery type, and the like. In another aspect, the right controller 160R and the left controller may be connected to a USB interface of the computer 200, for example. In this case, the right controller 160R and the left controller do not require batteries.

図8の状態(A)および状態(B)に示されるように、例えば、ユーザ190の右手810に対して、ヨー、ロール、ピッチの各方向が規定される。ユーザ190が親指と人差し指とを伸ばした場合に、親指の伸びる方向がヨー方向、人差し指の伸びる方向がロール方向、ヨー方向の軸およびロール方向の軸によって規定される平面に垂直な方向がピッチ方向として規定される。   As shown in the state (A) and the state (B) of FIG. 8, for example, the yaw, roll, and pitch directions are defined for the right hand 810 of the user 190. When the user 190 extends the thumb and index finger, the direction in which the thumb extends is the yaw direction, the direction in which the index finger extends is the roll direction, and the direction perpendicular to the plane defined by the yaw direction axis and the roll direction axis is the pitch direction. Is defined as

[HMD装置の制御装置]
図9を参照して、HMD装置110の制御装置について説明する。ある実施の形態において、制御装置は周知の構成を有するコンピュータ200によって実現される。図9は、ある実施の形態に従うコンピュータ200をモジュール構成として表すブロック図である。
[Control device for HMD device]
The control device of the HMD device 110 will be described with reference to FIG. In one embodiment, the control device is realized by a computer 200 having a known configuration. FIG. 9 is a block diagram showing a computer 200 according to an embodiment as a module configuration.

図9に示されるように、コンピュータ200は、表示制御モジュール220と、仮想空間制御モジュール230と、メモリモジュール240と、通信制御モジュール250とを備える。表示制御モジュール220は、サブモジュールとして、仮想カメラ制御モジュール221と、視界領域決定モジュール222と、視界画像生成モジュール223と、基準視線特定モジュール224とを含む。仮想空間制御モジュール230は、サブモジュールとして、仮想空間定義モジュール231と、仮想オブジェクト制御モジュール232と、同期モジュール233とを含む。   As shown in FIG. 9, the computer 200 includes a display control module 220, a virtual space control module 230, a memory module 240, and a communication control module 250. The display control module 220 includes a virtual camera control module 221, a visual field region determination module 222, a visual field image generation module 223, and a reference visual line identification module 224 as submodules. The virtual space control module 230 includes a virtual space definition module 231, a virtual object control module 232, and a synchronization module 233 as submodules.

ある実施の形態において、表示制御モジュール220と仮想空間制御モジュール230とは、プロセッサ10によって実現される。別の実施の形態において、複数のプロセッサ10が表示制御モジュール220と仮想空間制御モジュール230として作動してもよい。メモリモジュール240は、メモリ11またはストレージ12によって実現される。通信制御モジュール250は、通信インターフェース14によって実現される。   In an embodiment, the display control module 220 and the virtual space control module 230 are realized by the processor 10. In another embodiment, multiple processors 10 may operate as the display control module 220 and the virtual space control module 230. The memory module 240 is realized by the memory 11 or the storage 12. The communication control module 250 is realized by the communication interface 14.

ある局面において、表示制御モジュール220は、HMD装置110のディスプレイ112における画像表示を制御する。仮想カメラ制御モジュール221は、仮想空間2に仮想カメラ1を配置し、仮想カメラ1の挙動、向き等を制御する。視界領域決定モジュール222は、HMD装置110を装着したユーザの頭の向きに応じて、視界領域23を規定する。視界画像生成モジュール223は、決定された視界領域23に基づいて、ディスプレイ112に表示される視界画像を生成する。基準視線特定モジュール224は、注視センサ140からの信号に基づいて、ユーザ190の視線を特定する。   In one aspect, the display control module 220 controls image display on the display 112 of the HMD device 110. The virtual camera control module 221 arranges the virtual camera 1 in the virtual space 2 and controls the behavior, orientation, and the like of the virtual camera 1. The view area determination module 222 defines the view area 23 according to the orientation of the head of the user wearing the HMD device 110. The view image generation module 223 generates a view image to be displayed on the display 112 based on the determined view area 23. The reference line-of-sight identifying module 224 identifies the line of sight of the user 190 based on the signal from the gaze sensor 140.

仮想空間制御モジュール230は、ユーザ190に提供される仮想空間2を制御する。仮想空間定義モジュール231は、仮想空間2を表す仮想空間データを生成することにより、HMDシステム100における仮想空間2を規定する。   The virtual space control module 230 controls the virtual space 2 provided to the user 190. The virtual space definition module 231 defines the virtual space 2 in the HMD system 100 by generating virtual space data representing the virtual space 2.

仮想オブジェクト制御モジュール232は、後述するオブジェクト情報242に基づいて、仮想空間2に配置される仮想的なオブジェクトである仮想オブジェクトを生成する。また、仮想オブジェクト制御モジュール232は、仮想空間2における仮想オブジェクトの動作(移動および状態変化等)も制御する。   The virtual object control module 232 generates a virtual object that is a virtual object placed in the virtual space 2 based on object information 242 described later. The virtual object control module 232 also controls the movement (movement, state change, etc.) of the virtual object in the virtual space 2.

仮想オブジェクトは、仮想空間2に配置されるオブジェクト全般である。以下の説明において、誤解が生じない場合には、仮想オブジェクトのことを単に「オブジェクト」と表記する。仮想オブジェクトは、例えば、ゲームのストーリーの進行に従って配置される森、山その他を含む風景、動物等を含み得る。また、仮想オブジェクトは、仮想空間2におけるユーザ190の分身としてのアバターおよびユーザ190により操作されるゲームのキャラクタ(プレイヤキャラクタ)等のキャラクタオブジェクトを含み得る。一つのキャラクタオブジェクトは一人のユーザ190に対応し、言い換えると、一つのキャラクタオブジェクトは一人のユーザ190に関連付けられる。   The virtual object is an entire object arranged in the virtual space 2. In the following description, when there is no misunderstanding, the virtual object is simply expressed as “object”. The virtual objects may include, for example, forests, mountains and other landscapes, animals, etc. that are arranged according to the progress of the game story. The virtual object may include a character object such as an avatar as a substitute for the user 190 in the virtual space 2 and a game character (player character) operated by the user 190. One character object corresponds to one user 190, in other words, one character object is associated with one user 190.

さらに、仮想オブジェクトは、ユーザ190がキャラクタオブジェクトを介して操作可能な可動オブジェクトも含み得る。仮想空間2において、可動オブジェクトは特定のキャラクタオブジェクト(ユーザ)に関連付けられて該キャラクタオブジェクトと共に動いたり、どのキャラクタオブジェクト(ユーザ)とも関連付けられずに動いたりすることができる。一例として、可動オブジェクトがボールであるとして、キャラクタオブジェクトがそのボールを掴むと、そのボールはキャラクタオブジェクトと関連付けられ、キャラクタオブジェクトが動くとボールも一緒に動く。そのキャラクタオブジェクトがボールを放すと、その関連付けは解除され、ボールはどのキャラクタオブジェクトからも独立して動く(例えば、落ちる、飛ぶなど)。別の例として、可動オブジェクトがボールであり、キャラクタオブジェクトがバットを持っているとする。そのキャラクタオブジェクトがバットでボールを打った場面では、ボールがバットに接している間において該ボールがキャラクタオブジェクトと関連付けられる。そのボールがバットから離れると、その関連付けは解除され、ボールはどのキャラクタオブジェクトからも独立して動く(例えば、落ちる、飛ぶなど)。したがって、キャラクタオブジェクトと可動オブジェクトとの関連付けは、キャラクタオブジェクトと可動オブジェクトとが直接に衝突し合った場合に限定されない。キャラクタオブジェクトが持つ道具(例えばバット)と可動オブジェクトとが衝突し合うような間接的な衝突が発生した場合にも、キャラクタオブジェクトと可動オブジェクトとが互いに関連付けられる。   Furthermore, the virtual object may also include a movable object that can be operated by the user 190 via the character object. In the virtual space 2, the movable object is associated with a specific character object (user) and can move with the character object, or can move without being associated with any character object (user). As an example, assuming that the movable object is a ball, when the character object grabs the ball, the ball is associated with the character object, and when the character object moves, the ball moves together. When the character object releases the ball, the association is released and the ball moves independently of any character object (eg, falls, flies, etc.). As another example, assume that the movable object is a ball and the character object has a bat. When the character object hits the ball with the bat, the ball is associated with the character object while the ball is in contact with the bat. When the ball leaves the bat, the association is broken and the ball moves independently of any character object (eg, falls, flies, etc.). Therefore, the association between the character object and the movable object is not limited to the case where the character object and the movable object directly collide with each other. The character object and the movable object are also associated with each other even when an indirect collision occurs such that the tool (for example, bat) that the character object has and the movable object collide with each other.

仮想空間制御モジュール230は、仮想空間2に配置されるオブジェクトのそれぞれが、他のオブジェクトと衝突した場合に、当該衝突を検出する。仮想空間制御モジュール230は、例えば、あるオブジェクトと別のオブジェクトとが触れたタイミングを検出することができ、当該検出がされたときに、予め定められた処理を行う。仮想空間制御モジュール230は、オブジェクトとオブジェクトとが触れている状態から離れたタイミングを検出することができ、当該検出がされたときに、予め定められた処理を行う。仮想空間制御モジュール230は、例えばオブジェクト毎に設定されたコリジョンエリアに基づく公知の当たり判定を実行することにより、オブジェクトとオブジェクトとが触れている状態であることを検出することができる。本開示では、仮想空間制御モジュール230は、キャラクタオブジェクトと可動オブジェクトとの間における直接のまたは間接的な衝突を検出すると、該可動オブジェクトを該キャラクタオブジェクトに関連付ける。その後、可動オブジェクトがキャラクタオブジェクトから離れると、仮想空間制御モジュール230はその関連付けを解除する。   The virtual space control module 230 detects the collision when each of the objects arranged in the virtual space 2 collides with another object. The virtual space control module 230 can detect, for example, a timing when a certain object touches another object, and performs a predetermined process when the detection is performed. The virtual space control module 230 can detect the timing at which the object is away from the touched state, and performs a predetermined process when the detection is made. The virtual space control module 230 can detect that the object is in contact with the object by executing a known hit determination based on, for example, a collision area set for each object. In the present disclosure, when the virtual space control module 230 detects a direct or indirect collision between a character object and a movable object, the virtual space control module 230 associates the movable object with the character object. Thereafter, when the movable object leaves the character object, the virtual space control module 230 cancels the association.

同期モジュール233は、可動オブジェクトを含む仮想空間2および視界画像の同期を取るために、可動オブジェクトの移動を示す動作データを送信または受信する。可動オブジェクトの移動は仮想オブジェクトの動作の一例であるので、動作データは仮想オブジェクト制御モジュール232により生成される。同期を取るとは、複数のHMDシステム100の間で、仮想空間2内(個々の視界画像内)の各仮想オブジェクトの状態(例えば、位置および動作)を合わせる処理をいう。なお、仮想空間2内のすべての仮想オブジェクトの同期を取ることは必須ではなく、一部の仮想オブジェクトが同期されなくてもよい。例えば、ある一人のユーザ190にのみ必要で他のユーザ190には必要ない仮想オブジェクトについて同期が実行されなくてもよい。また、仮想空間2の開始から終了までの時間のすべてにおいて仮想オブジェクトの同期を取ることも必須ではなく、ある時間帯において仮想オブジェクトの同期が実行されなくてもよい。   The synchronization module 233 transmits or receives motion data indicating movement of the movable object in order to synchronize the virtual space 2 including the movable object and the visual field image. Since the movement of the movable object is an example of the movement of the virtual object, the movement data is generated by the virtual object control module 232. Synchronizing refers to a process of matching the state (for example, position and motion) of each virtual object in the virtual space 2 (in each view field image) between the plurality of HMD systems 100. Note that it is not essential to synchronize all virtual objects in the virtual space 2, and some virtual objects may not be synchronized. For example, the synchronization may not be executed for a virtual object that is necessary only for one user 190 and not necessary for another user 190. Further, it is not essential to synchronize the virtual object in the entire time from the start to the end of the virtual space 2, and the virtual object may not be synchronized in a certain time zone.

メモリモジュール240は、コンピュータ200が仮想空間2をユーザ190に提供するために使用されるデータを保持している。ある局面において、メモリモジュール240は、空間情報241と、オブジェクト情報242と、ユーザ情報243とを保持している。空間情報241には、例えば、仮想空間2を提供するために規定された1つ以上のテンプレートが含まれている。オブジェクト情報242には、例えば、仮想空間2において再生されるコンテンツ、当該コンテンツで使用されるオブジェクトを配置するための情報等が含まれている。当該コンテンツは、例えば、ゲーム、現実社会と同様の風景を表したコンテンツ等を含み得る。オブジェクト情報242には、各オブジェクトを描画するための描画情報も含まれている。また、オブジェクト情報242は、各オブジェクトに関連付けられた属性を示す属性情報も含み得る。オブジェクトの属性情報としては、例えば当該オブジェクトの種類(例えばアバター等)を示す情報、およびオブジェクトが可動物(可動オブジェクト)であるか固定物(固定オブジェクト)であるかを示す情報等が挙げられる。ユーザ情報243には、例えば、HMDシステム100の制御装置としてコンピュータ200を機能させるためのプログラム、オブジェクト情報242に保持される各コンテンツを使用するアプリケーションプログラム等が含まれている。   The memory module 240 holds data used for the computer 200 to provide the virtual space 2 to the user 190. In one aspect, the memory module 240 holds space information 241, object information 242, and user information 243. The space information 241 includes, for example, one or more templates defined for providing the virtual space 2. The object information 242 includes, for example, content reproduced in the virtual space 2, information for arranging objects used in the content, and the like. The content can include, for example, content representing a scene similar to a game or a real society. The object information 242 includes drawing information for drawing each object. The object information 242 may also include attribute information indicating attributes associated with each object. Examples of the attribute information of the object include information indicating the type of the object (for example, an avatar) and information indicating whether the object is a movable object (movable object) or a fixed object (fixed object). The user information 243 includes, for example, a program for causing the computer 200 to function as a control device of the HMD system 100, an application program that uses each content held in the object information 242, and the like.

メモリモジュール240に格納されているデータおよびプログラムは、HMD装置110のユーザによって入力される。あるいは、プロセッサ10が、当該コンテンツを提供する事業者が運営するコンピュータ(例えば、サーバ150)からプログラムあるいはデータをダウンロードして、ダウンロードされたプログラムあるいはデータをメモリモジュール240に格納する。   Data and programs stored in the memory module 240 are input by the user of the HMD device 110. Alternatively, the processor 10 downloads a program or data from a computer (for example, the server 150) operated by a provider providing the content, and stores the downloaded program or data in the memory module 240.

通信制御モジュール250は、ネットワーク19を介して、サーバ150その他の情報通信装置と通信し得る。   The communication control module 250 can communicate with the server 150 and other information communication devices via the network 19.

ある局面において、表示制御モジュール220および仮想空間制御モジュール230は、例えば、ユニティテクノロジーズ社によって提供されるUnity(登録商標)を用いて実現され得る。別の局面において、表示制御モジュール220および仮想空間制御モジュール230は、各処理を実現する回路素子の組み合わせとしても実現され得る。   In an aspect, the display control module 220 and the virtual space control module 230 may be realized using, for example, Unity (registered trademark) provided by Unity Technologies. In another aspect, the display control module 220 and the virtual space control module 230 can also be realized as a combination of circuit elements that realize each process.

コンピュータ200における処理は、ハードウェアと、プロセッサ10により実行されるソフトウェアとによって実現される。このようなソフトウェアは、ハードディスクその他のメモリモジュール240に予め格納されている場合がある。また、ソフトウェアは、CD−ROMその他のコンピュータ読み取り可能な不揮発性のデータ記録媒体に格納されて、プログラム製品として流通している場合もある。あるいは、当該ソフトウェアは、インターネットその他のネットワークに接続されている情報提供事業者によってダウンロード可能なプログラム製品として提供される場合もある。このようなソフトウェアは、光ディスク駆動装置その他のデータ読取装置によってデータ記録媒体から読み取られて、あるいは、通信制御モジュール250を介してサーバ150その他のコンピュータからダウンロードされた後、メモリモジュール240に一旦格納される。そのソフトウェアは、プロセッサ10によってメモリモジュール240から読み出され、実行可能なプログラムの形式でRAMに格納される。プロセッサ10は、そのプログラムを実行する。   Processing in the computer 200 is realized by hardware and software executed by the processor 10. Such software may be stored in advance in a memory module 240 such as a hard disk. The software may be stored in a CD-ROM or other non-volatile computer-readable data recording medium and distributed as a program product. Alternatively, the software may be provided as a program product that can be downloaded by an information provider connected to the Internet or other networks. Such software is read from a data recording medium by an optical disk drive or other data reader, or downloaded from the server 150 or other computer via the communication control module 250 and then temporarily stored in the memory module 240. The The software is read from the memory module 240 by the processor 10 and stored in the RAM in the form of an executable program. The processor 10 executes the program.

図9に示されるコンピュータ200を構成するハードウェアは、一般的なものである。したがって、本実施の形態に係る最も本質的な部分は、コンピュータ200に格納されたプログラムであるともいえる。なお、コンピュータ200のハードウェアの動作は周知であるので、詳細な説明は繰り返さない。   The hardware configuring the computer 200 shown in FIG. 9 is general. Therefore, it can be said that the most essential part according to the present embodiment is a program stored in the computer 200. Since the hardware operation of computer 200 is well known, detailed description will not be repeated.

なお、データ記録媒体としては、CD−ROM、FD(Flexible Disk)、ハードディスクに限られず、磁気テープ、カセットテープ、光ディスク(MO(Magnetic Optical Disc)/MD(Mini Disc)/DVD(Digital Versatile Disc))、IC(Integrated Circuit)カード(メモリカードを含む)、光カード、マスクROM、EPROM(Erasable Programmable Read-Only Memory)、EEPROM(Electrically Erasable Programmable Read-Only Memory)、フラッシュROMなどの半導体メモリ等の固定的にプログラムを担持する不揮発性のデータ記録媒体でもよい。   The data recording medium is not limited to a CD-ROM, FD (Flexible Disk), and hard disk, but is a magnetic tape, cassette tape, optical disk (MO (Magnetic Optical Disc) / MD (Mini Disc) / DVD (Digital Versatile Disc)). ), IC (Integrated Circuit) card (including memory card), optical card, mask ROM, EPROM (Erasable Programmable Read-Only Memory), EEPROM (Electrically Erasable Programmable Read-Only Memory), flash ROM, etc. It may be a non-volatile data recording medium that carries a fixed program.

ここでいうプログラムとは、プロセッサ10により直接実行可能なプログラムだけでなく、ソースプログラム形式のプログラム、圧縮処理されたプログラム、暗号化されたプログラム等を含み得る。   The program here may include not only a program directly executable by the processor 10, but also a program in a source program format, a compressed program, an encrypted program, and the like.

[制御構造]
図10を参照して、本実施の形態に係るコンピュータ200の制御構造について説明する。図10は、ユーザ190Aによって使用されるHMDシステム100Aがユーザ190Aに仮想空間2を提供するために実行する処理を表すシーケンス図である。他のHMDシステム100B,100C,100Dにおいても、同様の処理が実行される。
[Control structure]
With reference to FIG. 10, a control structure of computer 200 according to the present embodiment will be described. FIG. 10 is a sequence diagram showing processing executed by the HMD system 100A used by the user 190A to provide the virtual space 2 to the user 190A. Similar processing is executed in the other HMD systems 100B, 100C, and 100D.

ステップS1において、コンピュータ200のプロセッサ10は、仮想空間定義モジュール231として、仮想空間2の背景を構成する仮想空間画像データ(仮想空間画像22)を特定し、仮想空間2を定義する。プロセッサ10は、その仮想空間2を規定する仮想空間データを生成する。   In step S <b> 1, the processor 10 of the computer 200 specifies the virtual space image data (virtual space image 22) constituting the background of the virtual space 2 as the virtual space definition module 231, and defines the virtual space 2. The processor 10 generates virtual space data that defines the virtual space 2.

ステップS2において、プロセッサ10は、仮想カメラ制御モジュール221として、仮想カメラ1を初期化する。例えば、プロセッサ10は、メモリのワーク領域において、仮想カメラ1を仮想空間2において予め規定された中心点に配置し、仮想カメラ1の視線をユーザ190が向いている方向に向ける。   In step S <b> 2, the processor 10 initializes the virtual camera 1 as the virtual camera control module 221. For example, the processor 10 places the virtual camera 1 at a predetermined center point in the virtual space 2 in the work area of the memory, and directs the line of sight of the virtual camera 1 in the direction in which the user 190 is facing.

ステップS3において、プロセッサ10は、視界画像生成モジュール223として、初期の視界画像を表示するための視界画像データを生成する。プロセッサ10は、少なくとも仮想空間データに基づいて視界画像データを生成する。生成された視界画像データは、視界画像生成モジュール223を介して通信制御モジュール250によってHMD装置110に送られる。   In step S <b> 3, the processor 10 generates view image data for displaying an initial view image as the view image generation module 223. The processor 10 generates view field image data based on at least the virtual space data. The generated view image data is sent to the HMD device 110 by the communication control module 250 via the view image generation module 223.

ステップS4において、HMD装置110のディスプレイ112は、コンピュータ200から受信した信号に基づいて、視界画像を表示する。HMD装置110Aを装着したユーザ190Aは、視界画像を視認すると仮想空間2を認識し得る。   In step S <b> 4, the display 112 of the HMD device 110 displays a view field image based on the signal received from the computer 200. The user 190A wearing the HMD device 110A can recognize the virtual space 2 when viewing the visual field image.

ステップS5において、HMDセンサ120は、HMD装置110から発信される複数の赤外線光に基づいて、HMD装置110の位置および傾きを検知する。検知結果は、動き検知データとして、コンピュータ200に送られる。   In step S <b> 5, the HMD sensor 120 detects the position and tilt of the HMD device 110 based on a plurality of infrared lights transmitted from the HMD device 110. The detection result is sent to the computer 200 as motion detection data.

ステップS6において、プロセッサ10は、視界領域決定モジュール222として、HMD装置110Aの位置と傾きとに基づいて、HMD装置110Aを装着したユーザ190Aの視界方向(すなわち、仮想カメラ1の位置および傾き)を特定する。プロセッサ10は、アプリケーションプログラムを実行し、アプリケーションプログラムに含まれる命令に基づいて、仮想空間2にオブジェクトを配置する。   In step S6, the processor 10 uses the visual field direction determination module 222 to determine the visual field direction (that is, the position and tilt of the virtual camera 1) of the user 190A wearing the HMD device 110A based on the position and tilt of the HMD device 110A. Identify. The processor 10 executes the application program and places an object in the virtual space 2 based on instructions included in the application program.

ステップS7において、コントローラ160は、現実空間におけるユーザ190Aの操作を検出する。例えば、ある局面において、コントローラ160は、ユーザ190Aによってボタンが押下されたことを検出する。別の局面において、コントローラ160は、ユーザ190Aの両手の動作(たとえば、両手を振る等)を検出する。検出内容を示す信号は、コンピュータ200に送られる。   In step S7, the controller 160 detects the operation of the user 190A in the real space. For example, in one aspect, the controller 160 detects that a button has been pressed by the user 190A. In another aspect, the controller 160 detects the operation of both hands of the user 190A (for example, shaking both hands). A signal indicating the detected content is sent to the computer 200.

ステップS8において、プロセッサ10は同期モジュール233として、仮想オブジェクトの動作データを送信または受信する。複数のコンピュータ200のうちの一つが仮想オブジェクトの動作を能動的に管理し、動作データを他のコンピュータ200に送信する。残りのコンピュータ200はその動作データを受信して仮想オブジェクトの動作を受動的に制御する。本開示では、可動オブジェクトの動作データを送信する側を「マスタ」ともいい、その動作データを受信する側を「スレーブ」ともいう。   In step S8, the processor 10 transmits or receives the motion data of the virtual object as the synchronization module 233. One of the plurality of computers 200 actively manages the operation of the virtual object, and transmits the operation data to the other computer 200. The remaining computer 200 receives the motion data and passively controls the motion of the virtual object. In the present disclosure, a side that transmits motion data of a movable object is also referred to as a “master”, and a side that receives the motion data is also referred to as a “slave”.

ステップS9において、プロセッサ10は、仮想オブジェクト制御モジュール232として各仮想オブジェクトの動作を制御する。ある局面では、プロセッサ10はキャラクタオブジェクトおよび可動オブジェクトの少なくとも一方の動作を制御する。   In step S <b> 9, the processor 10 controls the operation of each virtual object as the virtual object control module 232. In one aspect, the processor 10 controls at least one of the character object and the movable object.

ステップS10において、プロセッサ10は、視界画像生成モジュール223として、ステップS9の処理結果と仮想空間データとに基づく視界画像を表示するための視界画像データを生成し、生成した視界画像データをHMD装置110に出力する。   In step S10, the processor 10 generates view image data for displaying the view image based on the processing result of step S9 and the virtual space data as the view image generation module 223, and the generated view image data is the HMD device 110. Output to.

ステップS11において、HMD装置110のディスプレイ112は、受信した視界画像データに基づいて視界画像を更新し、更新後の視界画像を表示する。   In step S11, the display 112 of the HMD device 110 updates the view image based on the received view image data, and displays the updated view image.

ステップS5〜S11の処理は、定期的に繰り返し実行される。   The processes in steps S5 to S11 are repeatedly executed periodically.

[HMDシステム間の同期]
図11は、ある実施の形態に従う仮想空間2の一例を模式的に表す図である。この例では、仮想空間2は、HMD装置110Aを装着するユーザ190Aに関連付けられたキャラクタオブジェクト311と、HMD装置110Bを装着するユーザ190Bに関連付けられたキャラクタオブジェクト312と、HMD装置110Cを装着するユーザ190Cに関連付けられたキャラクタオブジェクト313と、HMD装置110Dを装着するユーザ190Dに関連付けられたキャラクタオブジェクト314とを含む。したがって、この仮想空間2は4人のユーザ190A〜190Dに共通である。各ユーザ190A〜190Dはこの共通の仮想空間2の中で、他のユーザと共通の仮想世界を体験したり、チャットなどのコミュニケーションを行ったりすることができる。この例では、キャラクタオブジェクト311〜314は野球をしており、キャラクタオブジェクト311は投手、キャラクタオブジェクト312は打者、キャラクタオブジェクト313,314は内野手である。
[Synchronization between HMD systems]
FIG. 11 is a diagram schematically illustrating an example of the virtual space 2 according to an embodiment. In this example, the virtual space 2 is a character object 311 associated with the user 190A wearing the HMD device 110A, a character object 312 associated with the user 190B wearing the HMD device 110B, and a user wearing the HMD device 110C. The character object 313 associated with 190C and the character object 314 associated with the user 190D wearing the HMD device 110D are included. Therefore, this virtual space 2 is common to the four users 190A to 190D. Each user 190 </ b> A to 190 </ b> D can experience a common virtual world with other users in this common virtual space 2, and perform communication such as chat. In this example, character objects 311 to 314 are playing baseball, character object 311 is a pitcher, character object 312 is a batter, and character objects 313 and 314 are infielders.

さらに、仮想空間2はボールを可動オブジェクト315として含む。図11は投手がボールを掴んでいる状況を表し、これは、可動オブジェクト315がキャラクタオブジェクト311に関連付けられていることを意味する。仮想空間2で可動オブジェクト315と関連付けられるキャラクタオブジェクトは変わり得る。例えば、打者のバットがボールに当たった瞬間には、可動オブジェクト315はキャラクタオブジェクト312と関連付けられ、いずれかの内野手がボールを捕った場合には、可動オブジェクト315はキャラクタオブジェクト313または314と関連付けられる。投げられたり打たれたりしたボールが飛んだり転がったりしている間は、可動オブジェクト315はどのキャラクタオブジェクトにも関連付けられない。   Further, the virtual space 2 includes a ball as a movable object 315. FIG. 11 shows a situation where the pitcher is holding the ball, which means that the movable object 315 is associated with the character object 311. The character object associated with the movable object 315 in the virtual space 2 can change. For example, when the batter's bat hits the ball, the movable object 315 is associated with the character object 312, and when any infielder catches the ball, the movable object 315 is associated with the character object 313 or 314. It is done. While the thrown or hit ball flies or rolls, the movable object 315 is not associated with any character object.

キャラクタオブジェクト311〜314の視野はHMDシステム100A〜100Dにおける仮想カメラ1の視野とそれぞれ対応する。したがって、各ユーザ190A〜190Dには1人称視点における視界画像が提供される。   The visual fields of the character objects 311 to 314 correspond to the visual fields of the virtual camera 1 in the HMD systems 100A to 100D, respectively. Accordingly, a view image at the first person viewpoint is provided to each of the users 190A to 190D.

図12は、ある実施の形態に従うHMD装置110により提供される視界画像の一例を表す図である。図12での状態(A)は、ユーザ190Aに対応するキャラクタオブジェクト311の1人称視点における視界画像300Aである。この視界画像300Aはキャラクタオブジェクト311の投球動作を表し、キャラクタオブジェクト311の右手から可動オブジェクト(ボール)315が離れようとしている場面を表す。この状態(A)では、キャラクタオブジェクト311と可動オブジェクト315との関連付けは未だ維持されているが、その関連付けはもうすぐ解除されようとしている。状態(B)は、ユーザ190Bに対応するキャラクタオブジェクト312の1人称視点における視界画像300Bである。状態(C)は、ユーザ190Cに対応するキャラクタオブジェクト313の1人称視点における視界画像300Cである。状態(D)は、ユーザ190Dに対応するキャラクタオブジェクト314の1人称視点における視界画像300Dである。これら四つの視界画像300A,300B,300C,300Dは互いに同期が取れている。したがって、各ユーザ190は、キャラクタオブジェクト311が可動オブジェクト315を投げようとしている場面を同時期に共有する。   FIG. 12 is a diagram illustrating an example of a field-of-view image provided by HMD device 110 according to an embodiment. A state (A) in FIG. 12 is a view field image 300A in the first person viewpoint of the character object 311 corresponding to the user 190A. The view image 300A represents a pitching motion of the character object 311 and represents a scene where the movable object (ball) 315 is about to leave the right hand of the character object 311. In this state (A), the association between the character object 311 and the movable object 315 is still maintained, but the association is about to be released soon. The state (B) is the view image 300B in the first person viewpoint of the character object 312 corresponding to the user 190B. The state (C) is the view image 300C in the first person viewpoint of the character object 313 corresponding to the user 190C. The state (D) is the visual field image 300D at the first person viewpoint of the character object 314 corresponding to the user 190D. These four view images 300A, 300B, 300C, and 300D are synchronized with each other. Therefore, each user 190 shares the scene where the character object 311 is about to throw the movable object 315 at the same time.

図13も、ある実施の形態に従うHMD装置110により提供される視界画像の一例を表す図である。図13での状態(A)は、ユーザ190Aに対応するキャラクタオブジェクト311の1人称視点における視界画像300Aである。この視界画像300Aは図12の状態(A)の直ぐ後の状況を表し、具体的には、キャラクタオブジェクト311が投げた可動オブジェクト315がキャラクタオブジェクト312に向かって進んでいる場面を表す。図13の状態(A)では、キャラクタオブジェクト311と可動オブジェクト315との関連付けは既に解除されており、可動オブジェクト315はどのキャラクタオブジェクトとも関連付けられていない。図13での状態(B)は、ユーザ190Bに対応するキャラクタオブジェクト312の1人称視点における視界画像300Bである。図13での状態(C)は、ユーザ190Cに対応するキャラクタオブジェクト313の1人称視点における視界画像300Cである。図13での状態(D)は、ユーザ190Dに対応するキャラクタオブジェクト314の1人称視点における視界画像300Dである。図13に示す四つの視界画像300A,300B,300C,300Dも互いに同期が取れている。したがって、各ユーザ190は、可動オブジェクト315がキャラクタオブジェクト312に向かって飛んでいる場面も同時期に共有する。   FIG. 13 is also a diagram illustrating an example of a field-of-view image provided by HMD device 110 according to an embodiment. A state (A) in FIG. 13 is a view image 300A in the first person viewpoint of the character object 311 corresponding to the user 190A. The view image 300A represents a situation immediately after the state (A) of FIG. 12, and specifically represents a scene in which the movable object 315 thrown by the character object 311 is moving toward the character object 312. In the state (A) of FIG. 13, the association between the character object 311 and the movable object 315 has already been released, and the movable object 315 is not associated with any character object. A state (B) in FIG. 13 is a view image 300B in the first person viewpoint of the character object 312 corresponding to the user 190B. A state (C) in FIG. 13 is a view image 300C in the first person viewpoint of the character object 313 corresponding to the user 190C. The state (D) in FIG. 13 is a view image 300D in the first person viewpoint of the character object 314 corresponding to the user 190D. Four view images 300A, 300B, 300C, and 300D shown in FIG. 13 are also synchronized with each other. Therefore, each user 190 also shares a scene where the movable object 315 is flying toward the character object 312 at the same time.

本開示では、仮想空間2を共有する複数のユーザ190に対応する複数のHMDシステム100(より具体的には、複数のコンピュータ200)が、サーバ150を介することなく互いに直接にデータ通信し合うことで仮想オブジェクトの同期を取る。このデータ通信を実現するためのネットワークトポロジは限定されないが、例えばメッシュ型のネットワークであってもよい。図14は、ある実施の形態に従うメッシュ型ネットワークの一例を示す図である。この例では、各HMDシステム100の各コンピュータ200が、他のHMDシステム100のコンピュータ200のすべてと直接に接続されている。例えば、HMDシステム100Aのコンピュータ200Aは、他のHMDシステム100B,100C,100Dのコンピュータ200B,200C,200Dのそれぞれと接続されている。なお、コンピュータ200間の接続方法は限定されず、無線ネットワークまたは有線ネットワークでもよい。   In the present disclosure, a plurality of HMD systems 100 (more specifically, a plurality of computers 200) corresponding to a plurality of users 190 sharing the virtual space 2 directly communicate with each other without going through the server 150. To synchronize virtual objects. The network topology for realizing this data communication is not limited, but may be, for example, a mesh type network. FIG. 14 is a diagram illustrating an example of a mesh network according to an embodiment. In this example, each computer 200 of each HMD system 100 is directly connected to all the computers 200 of other HMD systems 100. For example, the computer 200A of the HMD system 100A is connected to each of the computers 200B, 200C, and 200D of other HMD systems 100B, 100C, and 100D. The connection method between the computers 200 is not limited, and may be a wireless network or a wired network.

ある仮想オブジェクトについて複数のHMDシステム100間で同期を取るために、一つのコンピュータ200がマスタとして機能し、該仮想オブジェクトの動作データを他のコンピュータ200に送信する。該他のコンピュータ200はスレーブとして機能し、マスタから受信した動作データを処理することで該仮想オブジェクトの状態を生成する。   In order to synchronize a virtual object among a plurality of HMD systems 100, one computer 200 functions as a master and transmits motion data of the virtual object to another computer 200. The other computer 200 functions as a slave, and generates the state of the virtual object by processing the motion data received from the master.

本開示では、あるユーザ190に対応するキャラクタオブジェクトの同期は、そのユーザ190に対応するコンピュータ200がマスタとして機能することで実現する。図12および図13での例では、キャラクタオブジェクト311の動作は、コンピュータ200Aが動作データを他のコンピュータ200B,200C,200Dに送信することで同期される。すなわち、キャラクタオブジェクト311の同期は、コンピュータ200Aがマスタとして機能し、コンピュータ200B,200C,200Dがスレーブとして機能することで実現される。同様に、キャラクタオブジェクト312,313,314の同期は、コンピュータ200B,200C,200Dがそれぞれマスタとして機能することで実現する。   In the present disclosure, the synchronization of the character object corresponding to a certain user 190 is realized by the computer 200 corresponding to the user 190 functioning as a master. In the example in FIGS. 12 and 13, the motion of the character object 311 is synchronized by the computer 200A transmitting motion data to the other computers 200B, 200C, and 200D. That is, the synchronization of the character object 311 is realized by the computer 200A functioning as a master and the computers 200B, 200C, and 200D functioning as slaves. Similarly, the synchronization of the character objects 312, 313, and 314 is realized by the computers 200B, 200C, and 200D functioning as masters.

可動オブジェクトは、ユーザ190がキャラクタオブジェクトを介して操作可能であるが、ユーザ190に対応するオブジェクトではない。また、この可動オブジェクトは、特定のキャラクタオブジェクトに関連付けられる場合もあれば、いずれのキャラクタオブジェクトにも関連付けられない場合もある。すなわち、可動オブジェクトは、持ち主が不定であるオブジェクトである。本開示では、可動オブジェクトが特定のキャラクタオブジェクトに関連付けられると、該キャラクタオブジェクトに対応するコンピュータ200がマスタとして機能し、該可動オブジェクトの動作データを他のコンピュータ200に送信する。その後、可動オブジェクトと該キャラクタオブジェクトとの関連付けが解除された場合にも(すなわち、可動オブジェクトがキャラクタオブジェクトから離れた場合にも)、所定の期間において、可動オブジェクトと最後に関連付いていた該キャラクタオブジェクトに対応するコンピュータ200がマスタとして機能し続ける。   The movable object can be operated by the user 190 via the character object, but is not an object corresponding to the user 190. The movable object may be associated with a specific character object or may not be associated with any character object. That is, the movable object is an object whose owner is indefinite. In the present disclosure, when a movable object is associated with a specific character object, the computer 200 corresponding to the character object functions as a master and transmits motion data of the movable object to another computer 200. Thereafter, even when the association between the movable object and the character object is released (that is, even when the movable object is separated from the character object), the character last associated with the movable object in a predetermined period of time. The computer 200 corresponding to the object continues to function as a master.

図12および図13の例における可動オブジェクト315の同期について説明する。図12ではキャラクタオブジェクト311が可動オブジェクト315を投げようとしているが、この時点ではまだ可動オブジェクト315がキャラクタオブジェクト311と関連付けられている。したがって、キャラクタオブジェクト311に対応するコンピュータ200Aが可動オブジェクト315の動作データを他のコンピュータ200B,200C,200Dに送信する。もちろん、コンピュータ200Aは図12に示す視界画像300Aを出力する。コンピュータ200B,200C,200Dはその動作データを受信して処理することで、図12に示す視界画像300B,300C,300Dをそれぞれ出力する。   The synchronization of the movable object 315 in the examples of FIGS. 12 and 13 will be described. Although the character object 311 is about to throw the movable object 315 in FIG. 12, the movable object 315 is still associated with the character object 311 at this time. Therefore, the computer 200A corresponding to the character object 311 transmits the motion data of the movable object 315 to the other computers 200B, 200C, and 200D. Of course, the computer 200A outputs the field-of-view image 300A shown in FIG. The computers 200B, 200C, and 200D receive and process the operation data to output view images 300B, 300C, and 300D shown in FIG.

可動オブジェクト315がキャラクタオブジェクト311から離れると、キャラクタオブジェクト311と可動オブジェクト315との関連付けが解除されて、視界画像300Aは図13の状態(A)に遷移する。関連付けが解除された後も、キャラクタオブジェクト311に対応するコンピュータ200Aが可動オブジェクト315の動作データを他のコンピュータ200B,200C,200Dに送信し続ける。コンピュータ200B,200C,200Dはその動作データを受信して処理することで、図13に示す、視界画像300Aと同期が取れた視界画像300B,300C,300Dを出力する。   When the movable object 315 moves away from the character object 311, the association between the character object 311 and the movable object 315 is released, and the view field image 300A changes to the state (A) in FIG. Even after the association is released, the computer 200A corresponding to the character object 311 continues to transmit the motion data of the movable object 315 to the other computers 200B, 200C, and 200D. The computers 200B, 200C, and 200D receive and process the operation data to output view images 300B, 300C, and 300D that are synchronized with the view image 300A shown in FIG.

このように、本開示では、可動オブジェクトの同期は、サーバ150を介することなく、個々のユーザ190のHMDシステム100(コンピュータ200)の間で実行される。   As described above, in the present disclosure, the synchronization of the movable object is performed between the HMD systems 100 (computers 200) of the individual users 190 without using the server 150.

図15および図16を参照しながら、複数のHMDシステム100間における可動オブジェクト315の同期をさらに詳しく説明する。図15および図16は、ある実施の形態に従う可動オブジェクト315の同期を表すシーケンス図であり、より具体的には、図12および図13に示す視界画像300A〜300Dに対応する処理を表す。   The synchronization of the movable object 315 between the plurality of HMD systems 100 will be described in more detail with reference to FIGS. 15 and 16. FIGS. 15 and 16 are sequence diagrams showing synchronization of movable object 315 according to an embodiment, and more specifically, processing corresponding to view images 300A to 300D shown in FIGS. 12 and 13.

ステップS21において、各HMDシステム100のプロセッサ10は、仮想空間定義モジュール231および視界画像生成モジュール223として機能し、共通の仮想空間2を示す視界画像を出力する。この処理は図10でのステップS1,S3,S4に対応し得る。各プロセッサ10は、空間情報241、オブジェクト情報242、およびユーザ情報243のうち少なくとも一種類の情報をメモリモジュール240から読み出す。続いて、各プロセッサ10は読み出した情報に基づいて、仮想空間2を定義する仮想空間データを生成することにより、仮想空間2を規定する。あるいは、各プロセッサ10は、コンテンツを提供する事業者が運営するコンピュータ(例えば、サーバ150)から予めダウンロードされたプログラムおよびデータ(仮想空間画像データ、オブジェクトの描画および初期配置等に関する情報)にも基づいて仮想空間データを生成してもよい。続いて、各プロセッサ10は、その仮想空間データに基づいて、初期の視界画像を表示するための視界画像データを生成し、この視界画像データを対応するHMD装置110に出力(送信)する。各HMD装置110はその視界画像データを処理して視界画像を表示する。   In step S <b> 21, the processor 10 of each HMD system 100 functions as the virtual space definition module 231 and the view image generation module 223 and outputs a view image indicating the common virtual space 2. This process can correspond to steps S1, S3, and S4 in FIG. Each processor 10 reads at least one type of information from the memory module 240 among the space information 241, the object information 242, and the user information 243. Subsequently, each processor 10 defines the virtual space 2 by generating virtual space data defining the virtual space 2 based on the read information. Alternatively, each processor 10 is also based on programs and data (information on virtual space image data, drawing of objects, initial arrangement, etc.) downloaded in advance from a computer (for example, server 150) operated by a provider that provides content. Virtual space data may be generated. Subsequently, each processor 10 generates view image data for displaying an initial view image based on the virtual space data, and outputs (transmits) the view image data to the corresponding HMD device 110. Each HMD device 110 processes the view image data and displays a view image.

ステップS21において、HMDシステム100Aのプロセッサ10Aは、少なくともキャラクタオブジェクト311を含む視界画像300Aを出力する。HMDシステム100Bのプロセッサ10Bは、少なくともキャラクタオブジェクト312を含む視界画像300Bを出力する。HMDシステム100Cのプロセッサ10Cは、少なくともキャラクタオブジェクト313を含む視界画像300Cを出力する。HMDシステム100Dのプロセッサ10Dは、少なくともキャラクタオブジェクト314を含む視界画像300Dを出力する。仮想空間2には可動オブジェクト315も存在するものとする。   In step S21, the processor 10A of the HMD system 100A outputs a visual field image 300A including at least the character object 311. The processor 10B of the HMD system 100B outputs a view field image 300B including at least the character object 312. The processor 10C of the HMD system 100C outputs a view field image 300C including at least the character object 313. The processor 10D of the HMD system 100D outputs a view field image 300D including at least the character object 314. It is assumed that a movable object 315 is also present in the virtual space 2.

ステップS22において、プロセッサ10Aは仮想空間制御モジュール230として機能し、キャラクタオブジェクト311と可動オブジェクト315との衝突を検出してこれらのオブジェクト同士を関連付ける。例えば、プロセッサ10Aは、仮想空間2内でキャラクタオブジェクト311が可動オブジェクト315を掴んだときにこの関連付けを実行する。   In step S22, the processor 10A functions as the virtual space control module 230, detects a collision between the character object 311 and the movable object 315, and associates these objects with each other. For example, the processor 10 </ b> A performs this association when the character object 311 grabs the movable object 315 in the virtual space 2.

ステップS23において、プロセッサ10Aは、キャラクタオブジェクト311に関連付けられた可動オブジェクト315の動作を示す動作データをHMDシステム100B,100C,100Dに送信する。まず、プロセッサ10Aは仮想オブジェクト制御モジュール232として機能し、可動オブジェクト315の動作を示す動作データを生成する。次いで、プロセッサ10Aは同期モジュール233として機能し、その動作データをコンピュータ200B,200C,200Dに送信する。プロセッサ10B,10C,10Dはそれぞれ同期モジュール233として機能し、その動作データを受信する。これらの処理は図10でのステップS8に対応し得る。   In step S23, the processor 10A transmits motion data indicating the motion of the movable object 315 associated with the character object 311 to the HMD systems 100B, 100C, and 100D. First, the processor 10A functions as the virtual object control module 232 and generates motion data indicating the motion of the movable object 315. Next, the processor 10A functions as the synchronization module 233 and transmits the operation data to the computers 200B, 200C, and 200D. Each of the processors 10B, 10C, and 10D functions as the synchronization module 233 and receives the operation data. These processes may correspond to step S8 in FIG.

ステップS24において、各プロセッサ10は仮想オブジェクト制御モジュール232および視界画像生成モジュール223として機能し、可動オブジェクト315の動作を示す視界画像を出力する。この処理は図10でのステップS9〜S11に対応し得る。   In step S <b> 24, each processor 10 functions as the virtual object control module 232 and the view image generation module 223, and outputs a view image indicating the operation of the movable object 315. This process may correspond to steps S9 to S11 in FIG.

マスタとして機能するプロセッサ10Aは、生成した動作データに基づいて可動オブジェクト315の新たな動作を制御する。続いて、プロセッサ10Aは該新たな動きを表示するための視界画像データを生成し、その視界画像データをHMD装置110Aに出力(送信)する。HMD装置110Aはその視界画像データを処理して視界画像300Aを更新する。   The processor 10A functioning as a master controls a new motion of the movable object 315 based on the generated motion data. Subsequently, the processor 10A generates view image data for displaying the new movement, and outputs (transmits) the view image data to the HMD device 110A. The HMD device 110A processes the view image data and updates the view image 300A.

スレーブとして機能するプロセッサ10Bは、受信した動作データに基づいて可動オブジェクト315の新たな動作を制御する。続いて、プロセッサ10Bは該新たな動きを表示するための視界画像データを生成し、その視界画像データをHMD装置110Bに出力(送信)する。HMD装置110Bはその視界画像データを処理して視界画像300Bを更新する。プロセッサ10C,10Dもスレーブとしてプロセッサ10Bと同様の処理を実行し、視界画像300C,300Dをそれぞれ更新する。   The processor 10B functioning as a slave controls a new motion of the movable object 315 based on the received motion data. Subsequently, the processor 10B generates view image data for displaying the new movement, and outputs (transmits) the view image data to the HMD device 110B. The HMD device 110B processes the view image data and updates the view image 300B. The processors 10C and 10D also perform the same processing as the processor 10B as slaves, and update the view images 300C and 300D, respectively.

ステップS23,S24の処理は繰り返し実行され得る。   The processes in steps S23 and S24 can be repeatedly executed.

ステップS24が実行されると、複数のHMDシステム100間で同期が取れたかたちで、共通の仮想空間2が各HMDシステム100に表示される。例えば、図12に示す視界画像300A〜300D(キャラクタオブジェクト311から可動オブジェクト315が離れようとしている場面)がHMD装置110A〜110Dにそれぞれ表示される。   When step S <b> 24 is executed, the common virtual space 2 is displayed on each HMD system 100 in the form of synchronization among the plurality of HMD systems 100. For example, the view images 300A to 300D (scenes where the movable object 315 is about to leave the character object 311) shown in FIG. 12 are displayed on the HMD devices 110A to 110D, respectively.

ステップS25において、プロセッサ10Aは仮想空間制御モジュール230として機能し、可動オブジェクト315がキャラクタオブジェクト311から移動したことを検出する。そして、プロセッサ10Aはキャラクタオブジェクト311と可動オブジェクト315との関連付けを解除する。例えば、プロセッサ10Aは、仮想空間2内でキャラクタオブジェクト311の手から可動オブジェクト315が離れた時に関連付けを解除する。   In step S <b> 25, the processor 10 </ b> A functions as the virtual space control module 230 and detects that the movable object 315 has moved from the character object 311. Then, the processor 10A releases the association between the character object 311 and the movable object 315. For example, the processor 10 </ b> A releases the association when the movable object 315 is separated from the hand of the character object 311 in the virtual space 2.

ステップS26において、プロセッサ10Aは、キャラクタオブジェクト311から移動した可動オブジェクト315の動作を示す動作データをHMDシステム100B,100C,100Dに送信する。プロセッサ10Aは可動オブジェクト315の動作を示す動作データを生成し、その動作データをコンピュータ200B,200C,200Dに送信する。プロセッサ10B,10C,10Dはそれぞれその動作データを受信する。これらの処理は図10でのステップS8に対応し得る。   In step S26, the processor 10A transmits motion data indicating the motion of the movable object 315 moved from the character object 311 to the HMD systems 100B, 100C, and 100D. The processor 10A generates motion data indicating the motion of the movable object 315, and transmits the motion data to the computers 200B, 200C, and 200D. Each of the processors 10B, 10C, and 10D receives the operation data. These processes may correspond to step S8 in FIG.

ステップS27はステップS24と同様であり、したがって、図10でのステップS9〜S11に対応し得る。ステップS27の処理が実行されると、複数のHMDシステム100間で同期が取れたかたちで、共通の仮想空間2における可動オブジェクト315の更新後の動作が各HMDシステム100に表示される。例えば、図13に示す視界画像300A〜300D(キャラクタオブジェクト311から離れた可動オブジェクト315がキャラクタオブジェクト312に向かって進んでいる場面)がHMD装置110A〜110Dにそれぞれ表示される。   Step S27 is similar to step S24, and therefore can correspond to steps S9 to S11 in FIG. When the process of step S27 is executed, the updated operation of the movable object 315 in the common virtual space 2 is displayed on each HMD system 100 in a form in which the plurality of HMD systems 100 are synchronized. For example, the view images 300A to 300D (scenes where the movable object 315 away from the character object 311 is moving toward the character object 312) shown in FIG. 13 are displayed on the HMD devices 110A to 110D, respectively.

ステップS26,S27の処理は、所定の条件を満たす間、所定の時間間隔で繰り返し実行され得る。ある局面では、プロセッサ10Aは、可動オブジェクト315の移動を検出した時点から、他のユーザ(他のコンピュータ200)に対応するキャラクタオブジェクトに可動オブジェクト315が関連付けられる前の任意の時点までの間において、ステップS26,S27を繰り返してもよい。   The processes in steps S26 and S27 can be repeatedly executed at predetermined time intervals while satisfying predetermined conditions. In one aspect, the processor 10A detects a movement of the movable object 315 until an arbitrary point in time before the movable object 315 is associated with the character object corresponding to another user (other computer 200). Steps S26 and S27 may be repeated.

図16を参照しながらその後の処理を説明する。キャラクタオブジェクト311から離れた可動オブジェクト315が別のキャラクタオブジェクトに関連付けられると、該別のオブジェクトに対応するHMDシステム100がマスタとして機能し、可動オブジェクト315の動作を能動的に管理する。図16の例ではHMDシステム100B(コンピュータ200Bおよびプロセッサ10B)がマスタとして機能する。   Subsequent processing will be described with reference to FIG. When the movable object 315 away from the character object 311 is associated with another character object, the HMD system 100 corresponding to the other object functions as a master and actively manages the movement of the movable object 315. In the example of FIG. 16, the HMD system 100B (computer 200B and processor 10B) functions as a master.

ステップS28において、プロセッサ10Bは仮想空間制御モジュール230として機能し、キャラクタオブジェクト312と可動オブジェクト315との衝突を検出してこれらのオブジェクト同士を関連付ける。例えば、プロセッサ10Bは、仮想空間2内でキャラクタオブジェクト312が可動オブジェクト315をバットで打った瞬間にこの関連付けを実行する。   In step S28, the processor 10B functions as the virtual space control module 230, detects a collision between the character object 312 and the movable object 315, and associates these objects with each other. For example, the processor 10 </ b> B executes this association at the moment when the character object 312 hits the movable object 315 with a bat in the virtual space 2.

ステップS29において、プロセッサ10Bは、キャラクタオブジェクト312に関連付けられた可動オブジェクト315の動作を示す動作データをHMDシステム100A,100C,100Dに送信する。まず、プロセッサ10Bは仮想オブジェクト制御モジュール232として機能し、可動オブジェクト315の動作を示す動作データを生成する。次いで、プロセッサ10Bは同期モジュール233として機能し、その動作データをコンピュータ200A,200C,200Dに送信する。プロセッサ10A,10C,10Dはそれぞれ同期モジュール233として機能し、その動作データを受信する。これらの処理は図10でのステップS8に対応し得る。   In step S29, the processor 10B transmits motion data indicating the motion of the movable object 315 associated with the character object 312 to the HMD systems 100A, 100C, and 100D. First, the processor 10B functions as the virtual object control module 232, and generates motion data indicating the motion of the movable object 315. Next, the processor 10B functions as the synchronization module 233, and transmits the operation data to the computers 200A, 200C, and 200D. Each of the processors 10A, 10C, and 10D functions as the synchronization module 233 and receives the operation data. These processes may correspond to step S8 in FIG.

ステップS30において、各プロセッサ10は仮想オブジェクト制御モジュール232および視界画像生成モジュール223として機能し、可動オブジェクト315の動作を示す視界画像を出力する。この処理は図10でのステップS9〜S11に対応し得る。   In step S <b> 30, each processor 10 functions as the virtual object control module 232 and the view image generation module 223, and outputs a view image indicating the operation of the movable object 315. This process may correspond to steps S9 to S11 in FIG.

マスタとして機能するプロセッサ10Bは、生成した動作データに基づいて可動オブジェクト315の新たな動作を制御する。続いて、プロセッサ10Bは該新たな動きを表示するための視界画像データを生成し、その視界画像データをHMD装置110Bに出力(送信)する。HMD装置110Bはその視界画像データを処理して視界画像300Bを更新する。   The processor 10B functioning as a master controls a new motion of the movable object 315 based on the generated motion data. Subsequently, the processor 10B generates view image data for displaying the new movement, and outputs (transmits) the view image data to the HMD device 110B. The HMD device 110B processes the view image data and updates the view image 300B.

スレーブとして機能するプロセッサ10Aは、受信した動作データに基づいて可動オブジェクト315の新たな動作を制御する。続いて、プロセッサ10Aは該新たな動きを表示するための視界画像データを生成し、その視界画像データをHMD装置110Aに出力(送信)する。HMD装置110Aはその視界画像データを処理して視界画像300Aを更新する。プロセッサ10C,10Dもスレーブとしてプロセッサ10Bと同様の処理を実行し、視界画像300C,300Dをそれぞれ更新する。   The processor 10A functioning as a slave controls a new motion of the movable object 315 based on the received motion data. Subsequently, the processor 10A generates view image data for displaying the new movement, and outputs (transmits) the view image data to the HMD device 110A. The HMD device 110A processes the view image data and updates the view image 300A. The processors 10C and 10D also perform the same processing as the processor 10B as slaves, and update the view images 300C and 300D, respectively.

ステップS30により、複数のHMDシステム100間で同期が維持される。例えば、キャラクタオブジェクト312が可動オブジェクト315をバットで打った瞬間がHMD装置110A〜110Dにそれぞれ表示される。   By step S30, synchronization is maintained among the plurality of HMD systems 100. For example, the moment when the character object 312 hits the movable object 315 with a bat is displayed on each of the HMD devices 110A to 110D.

ステップS29,S30の処理は繰り返し実行され得る。   The processes of steps S29 and S30 can be repeatedly executed.

ステップS31において、プロセッサ10Bは仮想空間制御モジュール230として機能し、可動オブジェクト315がキャラクタオブジェクト312から移動したことを検出する。そして、プロセッサ10Bはキャラクタオブジェクト312と可動オブジェクト315との関連付けを解除する。例えば、プロセッサ10Bは、仮想空間2内でキャラクタオブジェクト312のバットから可動オブジェクト315が離れた時に関連付けを解除する。   In step S <b> 31, the processor 10 </ b> B functions as the virtual space control module 230 and detects that the movable object 315 has moved from the character object 312. Then, the processor 10B releases the association between the character object 312 and the movable object 315. For example, the processor 10 </ b> B releases the association when the movable object 315 moves away from the bat of the character object 312 in the virtual space 2.

ステップS32において、プロセッサ10Bは、キャラクタオブジェクト312から移動した可動オブジェクト315の動作を示す動作データをHMDシステム100A,100C,100Dに送信する。プロセッサ10Bは可動オブジェクト315の動作を示す動作データを生成し、その動作データをコンピュータ200A,200C,200Dに送信する。プロセッサ10A,10C,10Dはそれぞれその動作データを受信する。これらの処理は図10でのステップS8に対応し得る。   In step S32, the processor 10B transmits motion data indicating the motion of the movable object 315 moved from the character object 312 to the HMD systems 100A, 100C, and 100D. The processor 10B generates motion data indicating the motion of the movable object 315, and transmits the motion data to the computers 200A, 200C, and 200D. Each of the processors 10A, 10C, and 10D receives the operation data. These processes may correspond to step S8 in FIG.

ステップS33はステップS30と同様であり、したがって、図10でのステップS9〜S11に対応し得る。この処理により、複数のHMDシステム100間で同期が維持される。例えば、バットから離れた可動オブジェクト315が飛んでいく場面がHMD装置110A〜110Dにそれぞれ表示される。   Step S33 is similar to step S30, and therefore can correspond to steps S9 to S11 in FIG. By this processing, synchronization is maintained among the plurality of HMD systems 100. For example, scenes where the movable object 315 away from the bat flies are displayed on the HMD devices 110A to 110D, respectively.

ステップS32,S33の処理は、所定の条件を満たす間、所定の時間間隔で繰り返し実行され得る。ある局面では、プロセッサ10Bは、可動オブジェクト315の移動を検出した時点から、他のユーザ(他のコンピュータ200)に対応するキャラクタオブジェクトに可動オブジェクト315が関連付けられる前の任意の時点までの間において、ステップS32,S33を繰り返してもよい。   The processes of steps S32 and S33 can be repeatedly executed at predetermined time intervals while satisfying predetermined conditions. In an aspect, the processor 10B detects from the time when the movement of the movable object 315 is detected to any time before the movable object 315 is associated with the character object corresponding to the other user (other computer 200). Steps S32 and S33 may be repeated.

ステップS34において、プロセッサ10BはステップS31と同様の処理を実行して、キャラクタオブジェクト311からの可動オブジェクト315の移動を検出する。ステップS35において、プロセッサ10Bは動作データを送信することなくステップS33と同様の処理を実行することで、可動オブジェクト315の更新後の動作をHMD装置110Bに表示させる。このように、所定の条件が満たされなくなると、マスタのコンピュータ200のみが可動オブジェクト315を更新する可能性がある。   In step S <b> 34, the processor 10 </ b> B executes the same process as in step S <b> 31 and detects the movement of the movable object 315 from the character object 311. In step S35, the processor 10B displays the operation after the update of the movable object 315 on the HMD device 110B by executing the same process as in step S33 without transmitting the operation data. As described above, when the predetermined condition is not satisfied, only the master computer 200 may update the movable object 315.

図17を参照しながら、マスタとして機能するコンピュータ200による処理を説明する。図17は、ある実施の形態に従うマスタ側での可動オブジェクト315の制御を表すフローチャートである。   Processing performed by the computer 200 functioning as a master will be described with reference to FIG. FIG. 17 is a flowchart showing control of movable object 315 on the master side according to an embodiment.

ステップS41において、マスタの役割を果たすプロセッサ10(以下では単に「プロセッサ10」という)は仮想空間制御モジュール230として機能し、キャラクタオブジェクトからの可動オブジェクト315の移動を検出する。この処理は、例えば図15でのステップS25に対応し得る。   In step S41, the processor 10 serving as a master (hereinafter simply referred to as “processor 10”) functions as the virtual space control module 230, and detects the movement of the movable object 315 from the character object. This process may correspond to, for example, step S25 in FIG.

ステップS42において、プロセッサ10は仮想オブジェクト制御モジュール232として機能し、可動オブジェクト315の移動を示す動作データを生成する。   In step S <b> 42, the processor 10 functions as the virtual object control module 232 and generates motion data indicating the movement of the movable object 315.

ステップS43において、プロセッサ10は同期モジュール233として機能し、動作データを送信するか否かを判定する。プロセッサ10は複数のコンピュータ200間で可動オブジェクト315の同期を取る必要があると判定した場合には動作データを送信すると判定する(ステップS43においてYES)。この場合には、プロセッサ10はステップS44において、他のコンピュータ200にその動作データを送信する。この処理は、例えば図15でのステップS26に対応し得る。一方、可動オブジェクト315の同期を取る必要がないと判定した場合には(ステップS43においてNO)、プロセッサ10はステップS44の処理を省略する。   In step S43, the processor 10 functions as the synchronization module 233 and determines whether to transmit operation data. If it is determined that the movable object 315 needs to be synchronized among the plurality of computers 200, the processor 10 determines to transmit motion data (YES in step S43). In this case, the processor 10 transmits the operation data to the other computer 200 in step S44. This process may correspond to, for example, step S26 in FIG. On the other hand, when it is determined that there is no need to synchronize the movable object 315 (NO in step S43), the processor 10 omits the process of step S44.

ステップS45において、プロセッサ10は仮想オブジェクト制御モジュール232として機能し、動作データに基づいて可動オブジェクトの動作を更新する。この処理は、例えば図15でのステップS27に対応し得る。   In step S45, the processor 10 functions as the virtual object control module 232, and updates the motion of the movable object based on the motion data. This process may correspond to, for example, step S27 in FIG.

ステップS46において、プロセッサ10は視界画像生成モジュール223として機能し、可動オブジェクト315についての新たな動きを表示するための視界画像データを生成し、その視界画像データをHMD装置110に出力(送信)する。HMD装置110はその視界画像データを処理して視界画像を更新する。この処理は、例えば図15でのステップS27に対応し得る。   In step S <b> 46, the processor 10 functions as the view image generation module 223, generates view image data for displaying a new movement of the movable object 315, and outputs (transmits) the view image data to the HMD device 110. . The HMD device 110 processes the view image data and updates the view image. This process may correspond to, for example, step S27 in FIG.

ステップS47においてプロセッサ10が可動オブジェクト315の処理を終了すると判定するまで、プロセッサ10はステップS41〜S46を繰り返す。   The processor 10 repeats steps S41 to S46 until the processor 10 determines to end the process of the movable object 315 in step S47.

このように、マスタのコンピュータ200(プロセッサ10)は、他のコンピュータ200への動作データを送信することなく、自機内で可動オブジェクト315の動作をさらに更新する可能性がある。   As described above, the master computer 200 (processor 10) may further update the operation of the movable object 315 in its own device without transmitting the operation data to the other computer 200.

同期の必要性を判定する具体的な手法は限定されず、マスタのプロセッサ10は任意の手法を用いてステップS43を実行してもよい。例えば、プロセッサ10は、他のユーザ(他のコンピュータ200)に対応する他のキャラクタオブジェクトに可動オブジェクト315が関連付けられた場合に、動作データを送信しないと判定してもよい。プロセッサ10は、自機で演算した可動オブジェクト315の位置と、他のコンピュータ200から受信した他のキャラクタオブジェクトの位置とに基づいて、これら二つのオブジェクトの衝突の有無を判定する。そして、プロセッサ10は、それら二つのオブジェクトが衝突したと判定した場合に、該二つのオブジェクトが関連付けられたと判定し、動作データの送信を中止する。   The specific method for determining the necessity of synchronization is not limited, and the master processor 10 may execute step S43 using any method. For example, the processor 10 may determine not to transmit motion data when the movable object 315 is associated with another character object corresponding to another user (another computer 200). Based on the position of the movable object 315 calculated by the own apparatus and the position of the other character object received from the other computer 200, the processor 10 determines whether or not these two objects collide. When the processor 10 determines that the two objects have collided, the processor 10 determines that the two objects are associated with each other, and stops transmitting the motion data.

マスタのプロセッサ10は、他のユーザ(他のコンピュータ200)に対応する他のキャラクタオブジェクトに可動オブジェクト315が関連付けられる前に、動作データを送信しないと判定してもよい。例えば、プロセッサ10は、可動オブジェクト315の移動ベクトルに基づいて、該可動オブジェクト315の動作データの送信の終了タイミングを決定してもよい。プロセッサ10は、移動ベクトルの大きさ(移動距離または速度)が所定の閾値以下になった場合に動作データの送信を終了してもよい。なお、閾値は0でもよいし、0より大きい任意の値でもよい。あるいは、プロセッサ10は、移動ベクトルの向きが所定の方向に固定された場合に動作データの送信を終了してもよい。   The master processor 10 may determine not to transmit motion data before the movable object 315 is associated with another character object corresponding to another user (another computer 200). For example, the processor 10 may determine the end timing of the movement data transmission of the movable object 315 based on the movement vector of the movable object 315. The processor 10 may end the transmission of the motion data when the magnitude of the movement vector (movement distance or speed) becomes a predetermined threshold value or less. The threshold value may be 0, or an arbitrary value greater than 0. Alternatively, the processor 10 may end the transmission of the operation data when the direction of the movement vector is fixed in a predetermined direction.

一例として、仮想空間2の少なくとも一部がボクセルで表現された視界画像が用いられた場合における、動作データの送信の要否の判定を説明する。プロセッサ10は、複数のボクセルで表される単位区画を基準として用い、可動オブジェクト315が現在の単位区画から他の単位区画に移るか否かに基づいて、動作データの送信の要否を判定してもよい。ここで、ボクセルとは、3次元デジタル画像を構成する最小描画単位であり、一般には立方体で表現される。単位区画は複数のボクセルを並べることで生成される3次元空間である。したがって、可動オブジェクト315が現在の単位区画から他の単位区画に移るか否かの判定は、可動オブジェクト315の移動距離が、ボクセルの個数で表される閾値以下であるかを判定することと同じであるといえる。   As an example, a description will be given of determination of necessity of transmission of motion data when a view field image in which at least a part of the virtual space 2 is expressed by voxels is used. The processor 10 determines whether or not it is necessary to transmit motion data based on whether or not the movable object 315 moves from the current unit section to another unit section, using a unit section represented by a plurality of voxels as a reference. May be. Here, the voxel is a minimum drawing unit constituting a three-dimensional digital image, and is generally expressed as a cube. The unit section is a three-dimensional space generated by arranging a plurality of voxels. Therefore, determining whether or not the movable object 315 moves from the current unit section to another unit section is the same as determining whether or not the moving distance of the movable object 315 is equal to or less than the threshold value represented by the number of voxels. You can say that.

プロセッサ10は、可動オブジェクト315の現在の移動ベクトルを動作データから得る。また、プロセッサ10は可動オブジェクト315が現在位置している単位区画を特定し、さらに、該単位区画内での可動オブジェクト315の位置を特定する。続いて、プロセッサ10はこれらの移動ベクトルおよび位置に基づいて、可動オブジェクト315が現在の単位区画から他の単位区画に移るか否かを判定する。可動オブジェクト315が他の単位区画に移ると判定した場合には、プロセッサ10は動作データを他のコンピュータ200に送信する。一方、可動オブジェクトが他の単位区画に移らない(すなわち、さらに動いたとしても最終的には現在の単位区画内で止まる)と判定した場合には、プロセッサ10は動作データの送信を実行しない。   The processor 10 obtains the current movement vector of the movable object 315 from the motion data. Further, the processor 10 specifies the unit section where the movable object 315 is currently located, and further specifies the position of the movable object 315 within the unit section. Subsequently, the processor 10 determines whether or not the movable object 315 moves from the current unit section to another unit section based on these movement vectors and positions. If it is determined that the movable object 315 moves to another unit section, the processor 10 transmits motion data to the other computer 200. On the other hand, when it is determined that the movable object does not move to another unit section (that is, even if it moves further, it finally stops in the current unit section), the processor 10 does not transmit the operation data.

スレーブのプロセッサ10は、マスタのコンピュータ200から動作データが送られてくる間に限って、可動オブジェクト315の動作を更新する。マスタのHMDシステム100が提供する視界画像において、可動オブジェクト315が止まる単位区画内で該可動オブジェクト315が若干動いたとしても、この1単位区画内の動きはスレーブのHMDシステム100に反映されない。そのため、マスタとスレーブとの間で、視界画像内での可動オブジェクト315の位置に、無視して問題ない若干の差異が生じる可能性がある。   The slave processor 10 updates the motion of the movable object 315 only while motion data is sent from the master computer 200. In the view image provided by the master HMD system 100, even if the movable object 315 moves slightly in the unit section where the movable object 315 stops, the movement in the one unit section is not reflected in the slave HMD system 100. Therefore, there may be a slight difference between the master and the slave that can be ignored in the position of the movable object 315 in the view field image.

図18は、マスタとスレーブとの間での可動オブジェクト315の位置の差異の例を表す図である。この図の例は、図16でのステップS33〜S35に対応し、キャラクタオブジェクト312から移動した可動オブジェクト315が仮想空間2内のある地点で止まろうとしている場面を示す。当該地点およびその周囲が三つの単位区画401〜403で表され、単位区画401に入った可動オブジェクト315が単位区画402に移って最終的に単位区画403内で止まるものとする。可動オブジェクト315が単位区画401から単位区画402に移るときは、マスタのプロセッサ10Bは可動オブジェクト315の動作データを他のコンピュータ200A,200C,200Cに送信する。可動オブジェクト315が単位区画402から単位区画403に移るときにも動作データがマスタからスレーブに送信される。   FIG. 18 is a diagram illustrating an example of the difference in position of the movable object 315 between the master and the slave. The example of this figure corresponds to steps S33 to S35 in FIG. 16 and shows a scene where the movable object 315 moved from the character object 312 is about to stop at a certain point in the virtual space 2. The point and its surroundings are represented by three unit sections 401 to 403, and the movable object 315 entering the unit section 401 moves to the unit section 402 and finally stops in the unit section 403. When the movable object 315 moves from the unit section 401 to the unit section 402, the master processor 10B transmits the motion data of the movable object 315 to the other computers 200A, 200C, and 200C. Motion data is also transmitted from the master to the slave when the movable object 315 moves from the unit section 402 to the unit section 403.

可動オブジェクト315が単位区画403に入った場合に、プロセッサ10Bは単位区画403内での可動オブジェクト315の更なる動きを求め、その動きを視界画像300B上に表示する。しかし、プロセッサ10Bは可動オブジェクト315が単位区画403から出ないと判定するので、その動きに対応する動作データを他のコンピュータ200A,200C,200Dに送信しない。したがって、視界画像300A,300C,300Dでは可動オブジェクト315の動作が表示されない。この結果、図18に示すように、マスタとスレーブとで可動オブジェクト315の最終的な位置に差異が生じ得る。しかし、この差異は単位区画の一辺の長さ未満であり非常に小さいので、各ユーザ190への仮想空間2の提供に影響を及ぼさない。このような差異を無視することで、動作データの送信が早く終了する。そのため、コンピュータ200間の通信量が低減され、動作データの伝送に起因する各コンピュータ200の処理負荷も低減される。   When the movable object 315 enters the unit section 403, the processor 10B obtains further movement of the movable object 315 in the unit section 403 and displays the movement on the view image 300B. However, since the processor 10B determines that the movable object 315 does not exit the unit section 403, the processor 10B does not transmit motion data corresponding to the motion to the other computers 200A, 200C, and 200D. Therefore, the motion of the movable object 315 is not displayed in the view images 300A, 300C, and 300D. As a result, as shown in FIG. 18, there may be a difference in the final position of the movable object 315 between the master and the slave. However, this difference is less than the length of one side of the unit section and is so small that it does not affect the provision of the virtual space 2 to each user 190. By ignoring such a difference, the transmission of the operation data is completed early. Therefore, the amount of communication between computers 200 is reduced, and the processing load on each computer 200 due to the transmission of operation data is also reduced.

別の例として、プロセッサ10は、可動オブジェクト315の移動方向がXYZ座標系の特定の1軸と平行になった場合に、動作データの送信を省略してもよい。例えば、プロセッサ10は、可動オブジェクト315が一地点で鉛直方向(Y方向)に平行に所定の範囲内(例えばキャラクタオブジェクトのY方向の寸法以内)でバウンドするようになった場合に、動作データの送信を省略してもよい。   As another example, the processor 10 may omit the transmission of motion data when the moving direction of the movable object 315 is parallel to one specific axis of the XYZ coordinate system. For example, when the movable object 315 bounces within a predetermined range (for example, within the dimension of the character object in the Y direction) parallel to the vertical direction (Y direction) at one point, the processor 10 Transmission may be omitted.

マスタのプロセッサ10は、動作データを送信しないと判定した場合に、自機内における可動オブジェクト315の動作の更新も終了してもよい。この場合には、マスタのコンピュータ200の処理負荷がさらに低減される。   When the master processor 10 determines not to transmit the motion data, the update of the motion of the movable object 315 in the own device may be terminated. In this case, the processing load on the master computer 200 is further reduced.

単位区画を構成する最小描画単位はボクセルに限定されず、例えばポリゴンでもよい。   The minimum drawing unit constituting the unit section is not limited to voxels, and may be polygons, for example.

[変形例]
以上、本開示の実施形態について説明したが、本発明の技術的範囲は、本実施形態の説明によって限定的に解釈されるべきではない。本実施形態は一例であって、特許請求の範囲に記載された発明の範囲内において、様々な実施形態の変更が可能であることが当業者によって理解されるところである。本発明の技術的範囲は、特許請求の範囲に記載された発明の範囲およびその均等の範囲に基づいて定められるべきである。
[Modification]
As mentioned above, although embodiment of this indication was described, the technical scope of this invention should not be limitedly interpreted by description of this embodiment. This embodiment is an example, and it is understood by those skilled in the art that various modifications can be made within the scope of the invention described in the claims. The technical scope of the present invention should be determined based on the scope of the invention described in the claims and the equivalents thereof.

コンピュータ200間の通信ネットワークが混雑している場合には、通信の遅延などにより、スレーブのコンピュータ200が、一つの可動オブジェクト315について複数のコンピュータから動作データを受信する可能性がある。この場合には、スレーブのコンピュータ200(プロセッサ10)は、可動オブジェクト315を示す前回の動作データを送ってきたタイミングが最も遅いコンピュータ200から受信した動作データを用いて、視界画像を生成してもよい。プロセッサ10は、前回の動作データの送信タイミングを、動作データに含まれる送信時刻により判定してもよいし、前回の動作データの受信タイミングを送信タイミングとみなして判定してもよい。この場合には、送られてきた動作データのうち一つのみがスレーブ側で処理されるので、スレーブのコンピュータ200の処理負荷が低減される。また、可動オブジェクト315の動きに違和感が生じないように視界画像を生成できる蓋然性が高まる。   When the communication network between the computers 200 is congested, there is a possibility that the slave computer 200 receives operation data from a plurality of computers for one movable object 315 due to communication delay or the like. In this case, the slave computer 200 (processor 10) may generate a view image using the motion data received from the computer 200 with the latest timing of sending the motion data indicating the movable object 315. Good. The processor 10 may determine the transmission timing of the previous operation data based on the transmission time included in the operation data, or may determine the reception timing of the previous operation data as the transmission timing. In this case, only one of the sent operation data is processed on the slave side, so that the processing load on the slave computer 200 is reduced. In addition, the probability that a field-of-view image can be generated so that a sense of incongruity does not occur in the movement of the movable object 315 increases.

上記実施形態においては、HMD装置110によってユーザ190が没入する仮想空間(VR空間)を例示して説明したが、HMD装置110として、透過型のHMD装置を採用してもよい。この場合、透過型のHMD装置を介してユーザ190が視認する現実空間に仮想空間を構成する画像の一部を合成した視界画像を出力することにより、拡張現実(AR:Augumented Reality)空間または複合現実(MR:Mixed Reality)空間における仮想体験をユーザ190に提供してもよい。この場合、ユーザ190の手がキャラクタオブジェクトの全体または一部として処理されてもよい。具体的には、プロセッサ10は、現実空間におけるユーザ190の手の位置の座標情報を特定するとともに、仮想空間2内における対象オブジェクト(例えば可動オブジェクト)の位置を現実空間における座標情報との関係で定義してもよい。これにより、プロセッサ10は、現実空間におけるユーザ190の手と仮想空間2における対象オブジェクトとの位置関係を把握し、ユーザ190の手と対象オブジェクトとの間で上述した衝突制御等に対応する処理を実行可能となる。その結果、ユーザ190の手の動きに基づいて対象オブジェクトに作用を与えることが可能となる。   In the above embodiment, the virtual space (VR space) in which the user 190 is immersed by the HMD device 110 has been described as an example. However, as the HMD device 110, a transmissive HMD device may be employed. In this case, an augmented reality (AR) space or a composite image is output by outputting a visual field image obtained by synthesizing a part of an image constituting the virtual space to the real space visually recognized by the user 190 via the transmission type HMD device. A virtual experience in a Reality (MR) space may be provided to the user 190. In this case, the hand of the user 190 may be processed as all or part of the character object. Specifically, the processor 10 specifies the coordinate information of the position of the hand of the user 190 in the real space, and determines the position of the target object (for example, a movable object) in the virtual space 2 in relation to the coordinate information in the real space. It may be defined. Thereby, the processor 10 grasps the positional relationship between the hand of the user 190 in the real space and the target object in the virtual space 2, and performs processing corresponding to the above-described collision control between the hand of the user 190 and the target object. It becomes executable. As a result, it is possible to act on the target object based on the hand movement of the user 190.

本明細書に開示された主題は、例えば、以下のような項目として示される。   The subject matter disclosed in the present specification is indicated as, for example, the following items.

(項目1)
表示部(ディスプレイ112)を備えるヘッドマウントデバイス(HMD装置110)を介して第1ユーザ(例えばユーザ190A)に仮想空間(仮想空間2)を提供するために、該第1ユーザに対応する第1コンピュータ(例えばコンピュータ200A)によって実行される情報処理方法であって、
前記第1ユーザに対応する第1キャラクタオブジェクト(例えばキャラクタオブジェクト311)に関連付けられた可動オブジェクト(可動オブジェクト315)を含む前記仮想空間を規定する仮想空間データを生成するステップ(例えば、図10のステップS1または図15のステップS21)と、
前記第1キャラクタオブジェクトからの前記可動オブジェクトの移動を検出した場合に、該移動を示す動作データを生成するステップ(例えば、図15のステップS26)と、
前記仮想空間データと前記動作データとに基づいて第1視界画像(例えば視界画像300A)を生成し、前記表示部に該第1視界画像を表示させるステップ(例えば、図15のステップS27)と、
1以上の第2ユーザ(例えばユーザ190B,190C,190D)に対応する1以上の第2コンピュータ(例えばコンピュータ200B,200C,200D)に前記動作データを送信することで、該1以上の第2コンピュータのそれぞれに、前記第1視界画像と同期する第2視界画像(例えば視界画像300B,300C,300D)を前記動作データに基づき表示させるステップ(例えば、図15のステップS27)と
を含む情報処理方法。
(Item 1)
In order to provide a virtual space (virtual space 2) to a first user (for example, user 190A) via a head mounted device (HMD device 110) having a display unit (display 112), a first corresponding to the first user is provided. An information processing method executed by a computer (for example, computer 200A),
Generating virtual space data defining the virtual space including a movable object (movable object 315) associated with a first character object (for example, character object 311) corresponding to the first user (for example, step of FIG. 10); S1 or step S21) of FIG.
When the movement of the movable object from the first character object is detected, generating action data indicating the movement (for example, step S26 in FIG. 15);
Generating a first visual field image (for example, a visual field image 300A) based on the virtual space data and the motion data, and displaying the first visual field image on the display unit (for example, step S27 in FIG. 15);
By transmitting the operation data to one or more second computers (for example, computers 200B, 200C, and 200D) corresponding to one or more second users (for example, users 190B, 190C, and 190D), the one or more second computers Each displaying a second visual field image (for example, visual field images 300B, 300C, 300D) synchronized with the first visual field image based on the operation data (for example, step S27 in FIG. 15). .

本項目の情報処理方法によれば、第1コンピュータに対応する第1キャラクタオブジェクトから可動オブジェクトが移動すると、その移動を示す動作データが他のコンピュータ(第2コンピュータ)に送られる。したがって、第2コンピュータは第1コンピュータによる第1視界画像と同期する第2視界画像を表示させることができる。複数のコンピュータ間で視界画像の同期が取られるので、仮想空間におけるユーザの仮想体験のエンタテイメント性を向上させることができる。   According to the information processing method of this item, when the movable object moves from the first character object corresponding to the first computer, motion data indicating the movement is sent to another computer (second computer). Therefore, the second computer can display the second view image synchronized with the first view image by the first computer. Since the visual field images are synchronized among a plurality of computers, it is possible to improve the entertainment property of the virtual experience of the user in the virtual space.

仮想空間の中には、場面によってユーザ操作とは関係なく動いたりユーザ操作に基づいて動いたりする可動オブジェクトが存在し得る。可動オブジェクトとユーザが操作するキャラクタオブジェクトとの関連付けはいつどのように変化するか予測できない。従来は、そのような可動オブジェクトの同期を取るために、サーバが可動オブジェクトの動きを追跡して各ユーザ端末にその動きを伝送していた。例えば、上記特許文献1に記載のシステムでは、サーバが仮想ボールの移動および位置を追跡し、仮想ボールの到着の正確な位置およびタイミングをユーザデバイスに通信する。   In the virtual space, there may be a movable object that moves regardless of the user operation or moves based on the user operation. When and how the association between the movable object and the character object operated by the user changes cannot be predicted. Conventionally, in order to synchronize such a movable object, a server tracks the movement of the movable object and transmits the movement to each user terminal. For example, in the system described in Patent Document 1, the server tracks the movement and position of the virtual ball, and communicates the exact position and timing of the arrival of the virtual ball to the user device.

しかし、クライアント−サーバ型のシステムでは同期処理にどうしても時間が掛かってしまうので、可動オブジェクトの動作の更新に要する時間も増大してしまう。処理速度が低下すると、視界画像の更新頻度(フレームレート)が低下してユーザがVR酔いしてしまう可能性がある。本項目の情報処理方法によれば、個々のユーザのHMDシステム(コンピュータ)の間で可動オブジェクトの動作データが直接に伝送されるので、サーバを介する場合よりも高速に該動作データが各HMDシステムで処理される。その結果、仮想空間が円滑に表示され続け、VR酔いを防止することが可能になる。   However, in the client-server type system, the synchronization process takes time, so the time required for updating the motion of the movable object also increases. When the processing speed is reduced, there is a possibility that the update frequency (frame rate) of the view image is reduced and the user gets VR sick. According to the information processing method of this item, since the motion data of the movable object is directly transmitted between the HMD systems (computers) of the individual users, the motion data is transmitted to each HMD system at a higher speed than when using a server. Is processed. As a result, the virtual space continues to be displayed smoothly, and VR sickness can be prevented.

サーバを用いることなくコンピュータで可動オブジェクトの動作データを送受信する場合には、どのコンピュータがマスタとして動作データを他のコンピュータに送信するかを決める必要がある。1台のコンピュータが常にマスタとして機能することも考えられるが、この場合にはマスタのコンピュータの処理負荷が増大してしまい、マスタ内での処理遅延や通信遅延などの不都合が生じて、結局、視界画像の更新頻度およびVR酔いを引き起こしかねない。本項目の情報処理方法によれば、最後に可動オブジェクトと関連付いていたキャラクタオブジェクトに対応するコンピュータがマスタとして機能するので、動作データの送信処理が複数のコンピュータに分散される。その結果、複数のコンピュータ間で処理負荷が均されてシステム全体としての処理負荷が下がるので、視界画像の更新頻度が高いレベルで維持され、VR酔いを防止することが可能になる。   When transmitting / receiving motion data of a movable object using a computer without using a server, it is necessary to decide which computer will transmit motion data to another computer as a master. Although it is conceivable that one computer always functions as a master, in this case, the processing load of the master computer increases, causing inconveniences such as processing delay and communication delay in the master. This can cause the frequency of visual field image updates and VR sickness. According to the information processing method of this item, the computer corresponding to the character object last associated with the movable object functions as a master, so that the operation data transmission processing is distributed to a plurality of computers. As a result, the processing load is balanced among a plurality of computers and the processing load of the entire system is reduced, so that the update frequency of the visual field image is maintained at a high level, and VR sickness can be prevented.

(項目2)
前記移動を検出した時点から、前記第2ユーザ(例えばユーザ190B)に対応する第2キャラクタオブジェクト(例えばキャラクタオブジェクト312)に前記可動オブジェクトが関連付けられる前の時点までの間において、前記動作データを生成するステップと、前記第1視界画像を表示させるステップと、前記動作データを送信するステップとを繰り返す、
項目1の情報処理方法。
(Item 2)
The motion data is generated from the time when the movement is detected to the time before the movable object is associated with the second character object (for example, the character object 312) corresponding to the second user (for example, the user 190B). Repeating the steps of: displaying the first field-of-view image; and transmitting the motion data.
Item 1. Information processing method.

本項目の情報処理方法によれば、可動オブジェクトが他のキャラクタオブジェクト(第2キャラクタオブジェクト)に関連付けられるまでは、最後に該可動オブジェクトと関連付いていたキャラクタオブジェクトに対応するコンピュータが動作データを繰り返し送信する。したがって、仮想空間において可動オブジェクトの同期を取り続けることができる。   According to the information processing method of this item, until the movable object is associated with another character object (second character object), the computer corresponding to the character object associated with the movable object last repeats the motion data. Send. Therefore, the movable object can be kept synchronized in the virtual space.

(項目3)
前記可動オブジェクトの移動ベクトルに基づいて前記動作データの送信の終了タイミングを決定するステップ(図17のステップS43)
を含む項目1または2の情報処理方法。
(Item 3)
A step of determining an end timing of transmission of the motion data based on a movement vector of the movable object (step S43 in FIG. 17)
Information processing method for item 1 or 2 including:

本項目の情報処理方法によれば、可動オブジェクトの動作に合わせて動作データの送信期間が決まるので、可動オブジェクトの同期に必要な通信の期間および回数が最低限に抑えられる。したがって、各コンピュータの処理負荷を抑えつつ、同期の取れた視界画像を高い更新頻度で表示させることができる。   According to the information processing method of this item, since the transmission period of the motion data is determined in accordance with the motion of the movable object, the communication period and the number of times necessary for synchronization of the movable object can be minimized. Therefore, it is possible to display a synchronized view field image with high update frequency while suppressing the processing load on each computer.

(項目4)
前記可動オブジェクトの移動距離が所定の閾値以下になった場合に前記動作データの送信を終了するステップ(図17のステップS43)
を含む項目3の情報処理方法。
(Item 4)
A step of ending the transmission of the motion data when the moving distance of the movable object is equal to or less than a predetermined threshold (step S43 in FIG. 17).
Information processing method for item 3 including:

本項目の情報処理方法によれば、可動オブジェクトが今後あまり動かないと推定される場合に動作データの送信が打ち切られるので、可動オブジェクトの同期に必要な通信の期間および回数が最低限に抑えられる。したがって、各コンピュータの処理負荷を抑えつつ、同期の取れた視界画像を高い更新頻度で表示させることができる。   According to the information processing method of this item, since the transmission of motion data is terminated when it is estimated that the movable object will not move much in the future, the communication period and the number of times necessary for synchronization of the movable object can be minimized. . Therefore, it is possible to display a synchronized view field image with high update frequency while suppressing the processing load on each computer.

(項目5)
前記所定の閾値が前記第1視界画像の最小描画単位の個数で表される、
項目4の情報処理方法。
(Item 5)
The predetermined threshold is represented by the number of minimum drawing units of the first view image.
Item 4. Information processing method.

本項目の情報処理方法によれば、可動オブジェクトの移動距離と、動作データの送信の要否を判断するための閾値とが視界画像の最小描画単位の個数で表されるので、視界画像の粒度との関係で可動オブジェクトの移動を制御することができる。そのため、視界画像にとって適切な同期を取ることができる。   According to the information processing method of this item, the moving distance of the movable object and the threshold value for determining whether or not to transmit the motion data are represented by the number of minimum rendering units of the visual field image. Therefore, the movement of the movable object can be controlled. Therefore, it is possible to achieve appropriate synchronization for the view field image.

(項目6)
項目1〜5のいずれか一項の情報処理方法をコンピュータに実行させるプログラム。
(Item 6)
A program for causing a computer to execute the information processing method according to any one of items 1 to 5.

(項目7)
少なくともメモリ(メモリモジュール240)と、前記メモリに結合されたプロセッサ(プロセッサ10)とを備え、前記プロセッサの制御により項目1〜5のいずれか一項の情報処理方法を実行する、装置。
(Item 7)
An apparatus comprising at least a memory (memory module 240) and a processor (processor 10) coupled to the memory, and executing the information processing method according to any one of items 1 to 5 under control of the processor.

(項目8)
表示部を備えるヘッドマウントデバイスを介して第1ユーザ(例えばユーザ190A)に仮想空間を提供するために、該第1ユーザに対応する第1コンピュータ(例えばコンピュータ200A)によって実行される情報処理方法であって、
可動オブジェクトを含む前記仮想空間を規定する仮想空間データを生成するステップ(例えば、図10のステップS1または図15のステップS21)と、
第2ユーザ(例えばユーザ190B)に対応するキャラクタオブジェクト(キャラクタオブジェクト312)からの前記可動オブジェクトの移動を示す動作データを、該第2ユーザに対応する第2コンピュータ(例えばコンピュータ200B)から受信するステップ(例えば、図16のS32)と、
前記仮想空間データと前記動作データとに基づいて、前記第2コンピュータにより表示される第2視界画像(例えば視界画像300B)と同期する第1視界画像(例えば視界画像300A)を生成し、前記表示部に該第1視界画像を表示させるステップ(例えば、図16のS33)と
を含む情報処理方法。
(Item 8)
An information processing method executed by a first computer (for example, computer 200A) corresponding to a first user in order to provide a virtual space to the first user (for example, user 190A) via a head mounted device having a display unit. There,
Generating virtual space data defining the virtual space including a movable object (for example, step S1 in FIG. 10 or step S21 in FIG. 15);
Step of receiving movement data indicating movement of the movable object from a character object (character object 312) corresponding to a second user (for example, user 190B) from a second computer (for example, computer 200B) corresponding to the second user. (For example, S32 in FIG. 16),
Based on the virtual space data and the motion data, a first view image (for example, view image 300A) that is synchronized with a second view image (for example, view image 300B) displayed by the second computer is generated, and the display An information processing method including a step (for example, S33 in FIG. 16) of displaying the first view field image on the unit.

本項目の情報処理方法によれば、他のコンピュータ(第2コンピュータ)に対応するキャラクタオブジェクトから可動オブジェクトが移動すると、その移動を示す動作データがそのコンピュータから送られてくる。したがって、この動作データを受信したコンピュータ(第1コンピュータ)は、第2コンピュータによる第2視界画像と同期する第1視界画像を表示させることができる。複数のコンピュータ間で視界画像の同期が取られるので、仮想空間におけるユーザの仮想体験のエンタテイメント性を向上させることができる。   According to the information processing method of this item, when a movable object moves from a character object corresponding to another computer (second computer), motion data indicating the movement is sent from the computer. Therefore, the computer (first computer) that has received the operation data can display the first view image synchronized with the second view image by the second computer. Since the visual field images are synchronized among a plurality of computers, it is possible to improve the entertainment property of the virtual experience of the user in the virtual space.

本項目の情報処理方法によれば、個々のユーザのHMDシステム(コンピュータ)の間で可動オブジェクトの動作データが直接に伝送されるので、サーバを介する場合よりも高速に該動作データが各HMDシステムで処理される。また、最後に可動オブジェクトと関連付いていたキャラクタオブジェクトに対応するコンピュータがマスタとして機能するので、動作データの送信処理が複数のコンピュータに分散される。その結果、複数のコンピュータ間で処理負荷が均されてシステム全体としての処理負荷が下がる。これらが仮想空間の円滑な表示に貢献するので、VR酔いを防止することが可能になる。   According to the information processing method of this item, since the motion data of the movable object is directly transmitted between the HMD systems (computers) of the individual users, the motion data is transmitted to each HMD system at a higher speed than when using a server. Is processed. In addition, since the computer corresponding to the character object associated with the last movable object functions as a master, the operation data transmission process is distributed to a plurality of computers. As a result, the processing load is balanced among a plurality of computers, and the processing load of the entire system is reduced. Since these contribute to smooth display of the virtual space, VR sickness can be prevented.

(項目9)
複数の前記第2コンピュータから前記動作データを受信した場合に、前回の動作データを送ってきたタイミングが最も遅い前記第2コンピュータから受信した動作データを用いて、前記第1視界画像を生成するステップ
を含む項目8の情報処理方法。
(Item 9)
When the operation data is received from a plurality of the second computers, the step of generating the first visual field image using the operation data received from the second computer with the latest timing of sending the operation data. Information processing method for item 8 including:

本項目の情報処理方法によれば、送られてきた動作データのうち一つのみが処理されるので、コンピュータの処理負荷が低減される。また、可動オブジェクトの動きに違和感が生じないように視界画像を生成できる蓋然性が高まる。   According to the information processing method of this item, since only one of the sent operation data is processed, the processing load on the computer is reduced. In addition, the probability that a field-of-view image can be generated so as not to cause a sense of incongruity in the movement of the movable object increases.

1…仮想カメラ、2…仮想空間、5…基準視線、10…プロセッサ、11…メモリ、12…ストレージ、13…入出力インターフェース、14…通信インターフェース、15…バス、19…ネットワーク、21…中心、22…仮想空間画像、23…視界領域、24,25…領域、30…グリップ、31…フレーム、32…天面、33,34,36,37…ボタン、35…赤外線LED、38…アナログスティック、100,100A,100B,100C,100D…HMDシステム、110,110A,110B,110C,110D…HMD装置、112…ディスプレイ、114…センサ、116…カメラ、118…マイク、120…HMDセンサ、130…モーションセンサ、140…注視センサ、150…サーバ、160…コントローラ、160R…右コントローラ、190,190A…ユーザ、200…コンピュータ、220…表示制御モジュール、221…仮想カメラ制御モジュール、222…視界領域決定モジュール、223…視界画像生成モジュール、224…基準視線特定モジュール、230…仮想空間制御モジュール、231…仮想空間定義モジュール、232…仮想オブジェクト制御モジュール、233…同期モジュール、240…メモリモジュール、241…空間情報、242…オブジェクト情報、243…ユーザ情報、250…通信制御モジュール、300A,300B,300C,300D…視界画像、311〜314…キャラクタオブジェクト、315…可動オブジェクト、401〜403…単位区画。   DESCRIPTION OF SYMBOLS 1 ... Virtual camera, 2 ... Virtual space, 5 ... Base line of sight, 10 ... Processor, 11 ... Memory, 12 ... Storage, 13 ... Input / output interface, 14 ... Communication interface, 15 ... Bus, 19 ... Network, 21 ... Center, 22 ... Virtual space image, 23 ... Field of view, 24, 25 ... Area, 30 ... Grip, 31 ... Frame, 32 ... Top, 33, 34, 36, 37 ... Button, 35 ... Infrared LED, 38 ... Analog stick, 100, 100A, 100B, 100C, 100D ... HMD system, 110, 110A, 110B, 110C, 110D ... HMD device, 112 ... display, 114 ... sensor, 116 ... camera, 118 ... microphone, 120 ... HMD sensor, 130 ... motion Sensor 140 ... Gaze sensor 150 ... Server 160 ... Control 160R ... right controller 190, 190A ... user, 200 ... computer, 220 ... display control module, 221 ... virtual camera control module, 222 ... view area determination module, 223 ... view image generation module, 224 ... reference line of sight identification module , 230 ... Virtual space control module, 231 ... Virtual space definition module, 232 ... Virtual object control module, 233 ... Synchronization module, 240 ... Memory module, 241 ... Spatial information, 242 ... Object information, 243 ... User information, 250 ... Communication Control module, 300A, 300B, 300C, 300D ... view image, 311 to 314 ... character object, 315 ... movable object, 401-403 ... unit section.

Claims (9)

表示部を備えるヘッドマウントデバイスを介して第1ユーザに仮想空間を提供するために、該第1ユーザに対応する第1コンピュータによって実行される情報処理方法であって、
前記第1ユーザに対応する第1キャラクタオブジェクトに関連付けられた可動オブジェクトを含む前記仮想空間を規定する仮想空間データを生成するステップと、
前記第1キャラクタオブジェクトからの前記可動オブジェクトの移動を検出した場合に、該移動を示す動作データを生成するステップと、
前記仮想空間データと前記動作データとに基づいて第1視界画像を生成し、前記表示部に該第1視界画像を表示させるステップと、
1以上の第2ユーザに対応する1以上の第2コンピュータに前記動作データを送信することで、該1以上の第2コンピュータのそれぞれに、前記第1視界画像と同期する第2視界画像を前記動作データに基づき表示させるステップと
を含む情報処理方法。
An information processing method executed by a first computer corresponding to a first user in order to provide a virtual space to the first user via a head mounted device including a display unit,
Generating virtual space data defining the virtual space including a movable object associated with a first character object corresponding to the first user;
Generating movement data indicating the movement when the movement of the movable object from the first character object is detected;
Generating a first view image based on the virtual space data and the motion data, and displaying the first view image on the display unit;
By transmitting the operation data to one or more second computers corresponding to one or more second users, a second view image synchronized with the first view image is transmitted to each of the one or more second computers. An information processing method including a step of displaying based on operation data.
前記移動を検出した時点から、前記第2ユーザに対応する第2キャラクタオブジェクトに前記可動オブジェクトが関連付けられる前の時点までの間において、前記動作データを生成するステップと、前記第1視界画像を表示させるステップと、前記動作データを送信するステップとを繰り返す、
請求項1に記載の情報処理方法。
The step of generating the motion data from the time when the movement is detected to the time before the movable object is associated with the second character object corresponding to the second user, and displaying the first view image And repeating the step of transmitting the operation data,
The information processing method according to claim 1.
前記可動オブジェクトの移動ベクトルに基づいて前記動作データの送信の終了タイミングを決定するステップ
を含む請求項1または2に記載の情報処理方法。
The information processing method according to claim 1, further comprising a step of determining an end timing of transmission of the motion data based on a movement vector of the movable object.
前記可動オブジェクトの移動距離が所定の閾値以下になった場合に前記動作データの送信を終了するステップ
を含む請求項3に記載の情報処理方法。
The information processing method according to claim 3, further comprising a step of ending the transmission of the motion data when a moving distance of the movable object becomes a predetermined threshold value or less.
前記所定の閾値が前記第1視界画像の最小描画単位の個数で表される、
請求項4に記載の情報処理方法。
The predetermined threshold is represented by the number of minimum drawing units of the first view image.
The information processing method according to claim 4.
請求項1〜5のいずれか一項に記載の情報処理方法をコンピュータに実行させるプログラム。   The program which makes a computer perform the information processing method as described in any one of Claims 1-5. 少なくともメモリと、前記メモリに結合されたプロセッサとを備え、前記プロセッサの制御により請求項1〜5のいずれか一項に記載の情報処理方法を実行する、装置。   An apparatus comprising: at least a memory; and a processor coupled to the memory, wherein the information processing method according to claim 1 is executed under the control of the processor. 表示部を備えるヘッドマウントデバイスを介して第1ユーザに仮想空間を提供するために、該第1ユーザに対応する第1コンピュータによって実行される情報処理方法であって、
可動オブジェクトを含む前記仮想空間を規定する仮想空間データを生成するステップと、
第2ユーザに対応するキャラクタオブジェクトからの前記可動オブジェクトの移動を示す動作データを、該第2ユーザに対応する第2コンピュータから受信するステップと、
前記仮想空間データと前記動作データとに基づいて、前記第2コンピュータにより表示される第2視界画像と同期する第1視界画像を生成し、前記表示部に該第1視界画像を表示させるステップと
を含む情報処理方法。
An information processing method executed by a first computer corresponding to a first user in order to provide a virtual space to the first user via a head mounted device including a display unit,
Generating virtual space data defining the virtual space including a movable object;
Receiving movement data indicating movement of the movable object from a character object corresponding to a second user from a second computer corresponding to the second user;
Generating a first view image synchronized with a second view image displayed by the second computer based on the virtual space data and the motion data, and causing the display unit to display the first view image; An information processing method including:
複数の前記第2コンピュータから前記動作データを受信した場合に、前回の動作データを送ってきたタイミングが最も遅い前記第2コンピュータから受信した動作データを用いて、前記第1視界画像を生成するステップ
を含む請求項8に記載の情報処理方法。
When the operation data is received from a plurality of the second computers, the step of generating the first visual field image using the operation data received from the second computer with the latest timing of sending the operation data. The information processing method according to claim 8, including:
JP2017136319A 2017-07-12 2017-07-12 An information processing method, a device, and a program for causing a computer to execute the information processing method. Active JP6946084B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2017136319A JP6946084B2 (en) 2017-07-12 2017-07-12 An information processing method, a device, and a program for causing a computer to execute the information processing method.

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2017136319A JP6946084B2 (en) 2017-07-12 2017-07-12 An information processing method, a device, and a program for causing a computer to execute the information processing method.

Publications (2)

Publication Number Publication Date
JP2019017483A true JP2019017483A (en) 2019-02-07
JP6946084B2 JP6946084B2 (en) 2021-10-06

Family

ID=65352397

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2017136319A Active JP6946084B2 (en) 2017-07-12 2017-07-12 An information processing method, a device, and a program for causing a computer to execute the information processing method.

Country Status (1)

Country Link
JP (1) JP6946084B2 (en)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006129942A (en) * 2004-11-02 2006-05-25 Namco Ltd Program, information storage medium, and game machine
JP2012050804A (en) * 2010-08-06 2012-03-15 Nintendo Co Ltd Game system, game apparatus, game program, and game process method
JP2016202686A (en) * 2015-04-24 2016-12-08 株式会社コロプラ System, method, and program for sharing game experience, and recording medium
JP2017113233A (en) * 2015-12-24 2017-06-29 株式会社コロプラ Match type game control method and program

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2006129942A (en) * 2004-11-02 2006-05-25 Namco Ltd Program, information storage medium, and game machine
JP2012050804A (en) * 2010-08-06 2012-03-15 Nintendo Co Ltd Game system, game apparatus, game program, and game process method
JP2016202686A (en) * 2015-04-24 2016-12-08 株式会社コロプラ System, method, and program for sharing game experience, and recording medium
JP2017113233A (en) * 2015-12-24 2017-06-29 株式会社コロプラ Match type game control method and program

Also Published As

Publication number Publication date
JP6946084B2 (en) 2021-10-06

Similar Documents

Publication Publication Date Title
US10936149B2 (en) Information processing method and apparatus for executing the information processing method
JP6263252B1 (en) Information processing method, apparatus, and program for causing computer to execute information processing method
JP6244593B1 (en) Information processing method, apparatus, and program for causing computer to execute information processing method
JP6470796B2 (en) Information processing method, program, and computer
JP6392911B2 (en) Information processing method, computer, and program for causing computer to execute information processing method
JP6290467B1 (en) Information processing method, apparatus, and program causing computer to execute information processing method
JP6201028B1 (en) Information processing method, apparatus, and program for causing computer to execute information processing method
JP6248219B1 (en) Information processing method, computer, and program for causing computer to execute information processing method
JP2018125003A (en) Information processing method, apparatus, and program for implementing that information processing method in computer
JP2018147465A (en) Information processing method, device, and program for causing computer to execute the method
JP2018124981A (en) Information processing method, information processing device and program causing computer to execute information processing method
JP6479933B1 (en) Program, information processing apparatus, and method
JP6368404B1 (en) Information processing method, program, and computer
JP2019032844A (en) Information processing method, device, and program for causing computer to execute the method
JP6419268B1 (en) Information processing method, apparatus, and program for causing computer to execute information processing method
JP6263292B1 (en) Information processing method, computer, and program for causing computer to execute information processing method
JP2019087262A (en) Program, information processing device and method
JP2019048045A (en) Information processing method device, and program for causing computer to execute the information processing method
JP2019030638A (en) Information processing method, device, and program for causing computer to execute information processing method
JP2018092635A (en) Information processing method, device, and program for implementing that information processing method on computer
JP2019036122A (en) Information processing method, program and computer
JP2018092592A (en) Information processing method, apparatus, and program for implementing that information processing method on computer
JP2019020832A (en) Information processing method, device, and program for causing computer to execute the method
JP6392953B1 (en) Information processing method, apparatus, and program for causing computer to execute information processing method
JP6441517B1 (en) Program, information processing apparatus, and method

Legal Events

Date Code Title Description
RD04 Notification of resignation of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7424

Effective date: 20171013

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20200701

A977 Report on retrieval

Free format text: JAPANESE INTERMEDIATE CODE: A971007

Effective date: 20201209

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20210129

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20210329

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20210907

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20210915

R150 Certificate of patent or registration of utility model

Ref document number: 6946084

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250