JP6911070B2 - Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. - Google Patents
Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. Download PDFInfo
- Publication number
- JP6911070B2 JP6911070B2 JP2019040931A JP2019040931A JP6911070B2 JP 6911070 B2 JP6911070 B2 JP 6911070B2 JP 2019040931 A JP2019040931 A JP 2019040931A JP 2019040931 A JP2019040931 A JP 2019040931A JP 6911070 B2 JP6911070 B2 JP 6911070B2
- Authority
- JP
- Japan
- Prior art keywords
- user
- virtual space
- computer
- input
- search key
- 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.)
- Active
Links
Images
Description
この開示は、仮想空間を提供する技術に関し、より特定的には、仮想空間に展開される
パノラマ画像を変更するための技術に関する。
This disclosure relates to a technique for providing a virtual space, and more specifically to a technique for changing a panoramic image developed in the virtual space.
ヘッドマウントデバイス(HMD:Head-Mounted Device)を用いて仮想空間を提供す
る技術が知られている。たとえば、特開2016−140078号公報(特許文献1)は
、ヘッドマウントディスプレイにパノラマ画像を表示する技術を開示している。
A technique for providing a virtual space using a head-mounted device (HMD) is known. For example, Japanese Patent Application Laid-Open No. 2016-140078 (Patent Document 1) discloses a technique for displaying a panoramic image on a head-mounted display.
また、近年、仮想空間におけるユーザの体験を豊かにする様々な技術が提案されている
。たとえば、非特許文献1は、仮想空間上に複数のユーザの各々のアバターを配置し、こ
れらアバターを通じてユーザ間でのコミュニケーションを図る技術を開示している。
Further, in recent years, various technologies have been proposed to enrich the user's experience in virtual space. For example, Non-Patent
ある局面において、ユーザは、仮想空間に展開されているパノラマ画像を変更したいと
考える。非特許文献1は、ユーザに対して切り替え候補のパノラマ画像を提示する技術を
開示しているものの、これら切り替え候補のパノラマ画像の中にユーザが所望するパノラ
マ画像が含まれていない場合があった。したがって、ユーザが所望するパノラマ画像の候
補を提示する技術が必要とされている。
In one aspect, the user wants to change the panoramic image developed in the virtual space. Although Non-Patent
本開示は、上記のような問題を解決するためになされたものであって、ある局面におけ
る目的は、仮想空間に展開されるパノラマ画像を変更するにあたり、ユーザの所望するパ
ノラマ画像をユーザに提示する技術を提供することである。
The present disclosure has been made to solve the above-mentioned problems, and the purpose in a certain aspect is to present the user with a panoramic image desired by the user in order to change the panoramic image developed in the virtual space. To provide the technology to do.
ある実施形態に従うと、ヘッドマウントデバイスによって仮想空間を提供するためにコ
ンピュータで実行されるプログラムが提供される。このプログラムはコンピュータに、予
め定められた複数のパノラマ画像に含まれる一のパノラマ画像を仮想空間に展開するステ
ップと、ヘッドマウントデバイスのユーザから、仮想空間に展開されているパノラマ画像
を他のパノラマ画像に変更するためのトリガの入力を受け付けるステップと、トリガの入
力を受け付けた後に、ユーザから検索キーの入力を受け付けるステップと、複数のパノラ
マ画像の中から、検索キーにより検索された一以上のパノラマ画像を特定するための情報
を仮想空間に提示するステップと、ユーザから、一以上のパノラマ画像の中から一のパノ
ラマ画像を選択する入力を受け付けるステップと、選択された一のパノラマ画像を仮想空
間に展開するステップとを実行させる。
According to certain embodiments, a headmount device provides a program that runs on a computer to provide virtual space. This program has a step of expanding one panoramic image contained in a plurality of predetermined panoramic images into a virtual space on a computer, and another panorama of a panoramic image expanded in the virtual space from a user of a head mount device. A step of accepting a trigger input for changing to an image, a step of accepting a search key input from a user after accepting a trigger input, and one or more panoramic images searched by a search key. A step of presenting information for identifying a panoramic image in a virtual space, a step of accepting an input from a user to select one panoramic image from one or more panoramic images, and a virtual step of virtualizing the selected one panoramic image. Perform steps to expand into space.
ある実施形態に従うプログラムは、仮想空間に展開されるパノラマ画像を変更するにあ
たり、ユーザの所望するパノラマ画像をユーザに提示できる。
A program according to an embodiment can present a panoramic image desired by the user to the user in changing the panoramic image developed in the virtual space.
開示された技術的特徴の上記および他の目的、特徴、局面および利点は、添付の図面と
関連して理解されるこの発明に関する次の詳細な説明から明らかとなるであろう。
The above and other objectives, features, aspects and advantages of the disclosed technical features will become apparent from the following detailed description of the invention, which is understood in connection with the accompanying drawings.
以下、この技術的思想の実施形態について図面を参照しながら詳細に説明する。以下の
説明では、同一の部品には同一の符号を付してある。それらの名称および機能も同じであ
る。したがって、それらについての詳細な説明は繰り返さない。なお、以下で説明される
各実施の形態および各変形例は、適宜選択的に組み合わされてもよい。
Hereinafter, embodiments of this technical idea will be described in detail with reference to the drawings. In the following description, the same parts are designated by the same reference numerals. Their names and functions are the same. Therefore, the detailed description of them will not be repeated. In addition, each embodiment and each modification described below may be selectively combined as appropriate.
[HMDシステムの構成]
図1を参照して、HMDシステム100の構成について説明する。図1は、ある実施の
形態に従うHMDシステム100の構成の概略を表す図である。ある局面において、HM
Dシステム100は、家庭用のシステムとしてあるいは業務用のシステムとして提供され
る。
[HMD system configuration]
The configuration of the
The
HMDシステム100は、HMD110と、HMDセンサ120と、コントローラ16
0と、コンピュータ200とを備える。HMD110は、モニタ112と、注視センサ1
40と、スピーカ115と、マイク119とを含む。コントローラ160は、モーション
センサ130を含み得る。
The
0 and a
40, a
ある局面において、コンピュータ200は、インターネットその他のネットワーク19
に接続可能であり、ネットワーク19に接続されているサーバ150その他のコンピュー
タと通信可能である。他の局面において、HMD110は、HMDセンサ120の代わり
に、センサ114を含み得る。
In one aspect, the
It is possible to connect to the
HMD110は、ユーザ190の頭部に装着され、動作中に仮想空間2をユーザ190
に提供し得る。より具体的には、HMD110は、右目用の画像および左目用の画像をモ
ニタ112にそれぞれ表示する。ユーザ190の各目がそれぞれの画像を視認すると、ユ
ーザ190は、両目の視差に基づき当該画像を3次元の画像として認識し得る。
The
Can be provided to. More specifically, the
モニタ112は、たとえば、非透過型の表示装置として実現される。ある局面において
、モニタ112は、ユーザ190の両目の前方に位置するようにHMD110の本体に配
置されている。したがって、ユーザ190は、モニタ112に表示される3次元画像を視
認すると、仮想空間2に没入することができる。ある実施の形態において、仮想空間2は
、たとえば、背景、ユーザ190が操作可能なオブジェクト、ユーザ190が選択可能な
メニューの画像を含む。複数のコンピュータ200が各ユーザの動作に基づく信号を受け
渡しすることで、複数のユーザが一の仮想空間2で仮想体験できる構成であれば、各ユー
ザに対応するアバターオブジェクトが、仮想空間2に提示される。
The
なお、オブジェクトとは、仮想空間2に存在する仮想の物体である。ある局面において
、オブジェクトは、ユーザに対応するアバターオブジェクト、アバターオブジェクトが身
に着ける仮想アクセサリおよび仮想衣服、ユーザに関する情報が示されたパネルを模した
仮想パネル、手紙を模した仮想手紙、およびポストを模した仮想ポストなどを含む。さら
に、アバターオブジェクトは、仮想空間2においてユーザ190を象徴するキャラクタで
あり、たとえば人型、動物型、ロボット型などを含む。オブジェクトの形は様々である。
ユーザ190は、予め決められたオブジェクトの中から好みのオブジェクトを仮想空間2
に提示するようにしてもよいし、自分が作成したオブジェクトを仮想空間2に提示するよ
うにしてもよい。
The object is a virtual object existing in the
The
It may be presented to the
ある実施の形態において、モニタ112は、所謂スマートフォンその他の情報表示端末
が備える液晶モニタまたは有機EL(Electro Luminescence)モニタとして実現され得
る。
In certain embodiments, the
ある局面において、モニタ112は、右目用の画像を表示するためのサブスクリーンと
、左目用の画像を表示するためのサブスクリーンとを含み得る。他の局面において、モニ
タ112は、右目用の画像と左目用の画像とを一体として表示する構成であってもよい。
この場合、モニタ112は、高速シャッタを含む。高速シャッタは、画像がいずれか一方
の目にのみ認識されるように、右目用の画像と左目用の画像とを交互に表示可能に作動す
る。
In some aspects, the
In this case, the
注視センサ140は、ユーザ190の右目および左目の視線が向けられる方向(視線方
向)を検出する。当該方向の検出は、たとえば、公知のアイトラッキング機能によって実
現される。注視センサ140は、当該アイトラッキング機能を有するセンサにより実現さ
れる。ある局面において、注視センサ140は、右目用のセンサおよび左目用のセンサを
含むことが好ましい。注視センサ140は、たとえば、ユーザ190の右目および左目に
赤外光を照射するとともに、照射光に対する角膜および虹彩からの反射光を受けることに
より各眼球の回転角を検出するセンサであってもよい。注視センサ140は、検出した各
回転角に基づいて、ユーザ190の視線方向を検知することができる。
The
スピーカ115は、コンピュータ200から受信した音声データに対応する音声(発話
)を外部に出力する。マイク119は、ユーザ190の発話に対応する音声データをコン
ピュータ200に出力する。ユーザ190は、マイク119を用いて他のユーザに向けて
発話する一方で、スピーカ115を用いて他のユーザの音声(発話)を聞くことができる
。
The
より具体的には、ユーザ190がマイク119に向かって発話すると、当該ユーザ19
0の発話に対応する音声データがコンピュータ200に入力される。コンピュータ200
は、その音声データを、ネットワーク19を介してサーバ150に出力する。サーバ15
0は、コンピュータ200から受信した音声データを、ネットワーク19を介して他のコ
ンピュータ200に出力する。他のコンピュータ200は、サーバ150から受信した音
声データを、他のユーザが装着するHMD110のスピーカ115に出力する。これによ
り、他のユーザは、HMD110のスピーカ115を介してユーザ190の音声を聞くこ
とができる。同様に、他のユーザからの発話は、ユーザ190が装着するHMD110の
スピーカ115から出力される。
More specifically, when the
The voice data corresponding to the utterance of 0 is input to the
Outputs the voice data to the
0 outputs the voice data received from the
コンピュータ200は、他のユーザのコンピュータ200から受信した音声データに応
じて、当該他のユーザに対応する他アバターオブジェクトを動かすような画像をモニタ1
12に表示する。たとえば、ある局面において、コンピュータ200は、他アバターオブ
ジェクトの口を動かすような画像をモニタ112に表示することで、あたかも仮想空間2
内でアバターオブジェクト同士が会話しているかのように仮想空間2を表現する。このよ
うに、複数のコンピュータ200間で音声データの送受信が行なわれることで、一の仮想
空間2内で複数のユーザ間での会話(チャット)が実現される。
The
Display on 12. For example, in a certain situation, the
The
HMDセンサ120は、複数の光源(図示しない)を含む。各光源は、たとえば、赤外
線を発するLED(Light Emitting Diode)により実現される。HMDセンサ120は
、HMD110の動きを検出するためのポジショントラッキング機能を有する。HMDセ
ンサ120は、この機能を用いて、現実空間内におけるHMD110の位置および傾きを
検出する。
The
なお、他の局面において、HMDセンサ120は、カメラにより実現されてもよい。こ
の場合、HMDセンサ120は、カメラから出力されるHMD110の画像情報を用いて
、画像解析処理を実行することにより、HMD110の位置および傾きを検出することが
できる。
In another aspect, the
他の局面において、HMD110は、位置検出器として、HMDセンサ120の代わり
に、センサ114を備えてもよい。HMD110は、センサ114を用いて、HMD11
0自身の位置および傾きを検出し得る。たとえば、センサ114が、角速度センサ、地磁
気センサ、加速度センサ、あるいはジャイロセンサなどである場合、HMD110は、H
MDセンサ120の代わりに、これらの各センサのいずれかを用いて、自身の位置および
傾きを検出し得る。一例として、センサ114が角速度センサである場合、角速度センサ
は、現実空間におけるHMD110の3軸周りの角速度を経時的に検出する。HMD11
0は、各角速度に基づいて、HMD110の3軸周りの角度の時間的変化を算出し、さら
に、角度の時間的変化に基づいて、HMD110の傾きを算出する。
In another aspect, the
The position and tilt of 0 itself can be detected. For example, when the
Instead of the
0 calculates the temporal change of the angle around the three axes of the
また、HMD110は、透過型表示装置を備えていても良い。この場合、当該透過型表
示装置は、その透過率を調整することにより、一時的に非透過型の表示装置として構成可
能であってもよい。また、視野画像は仮想空間2を構成する画像の一部に、現実空間を提
示する構成を含んでいてもよい。たとえば、HMD110に搭載されたカメラで撮影した
画像を視野画像の一部に重畳して表示させてもよいし、当該透過型表示装置の一部の透過
率を高く設定することにより、視野画像の一部から現実空間を視認可能にしてもよい。
Further, the
サーバ150は、コンピュータ200にプログラムを送信し得る。他の局面において、
サーバ150は、他のユーザによって使用されるHMD110に仮想現実を提供するため
の他のコンピュータ200と通信し得る。たとえば、アミューズメント施設において、複
数のユーザが参加型のゲームを行なう場合、各コンピュータ200は、各ユーザの動作に
基づく信号を他のコンピュータ200と通信して、同じ仮想空間2において複数のユーザ
が共通のゲームを楽しむことを可能にする。また、上述したように、複数のコンピュータ
200が各ユーザの動作に基づく信号を送受信することで、一の仮想空間2内で複数のユ
ーザが会話を楽しむことができる。
The
The
コントローラ160は、ユーザ190からコンピュータ200への命令の入力を受け付
ける。ある局面において、コントローラ160は、ユーザ190によって把持可能に構成
される。他の局面において、コントローラ160は、ユーザ190の身体あるいは衣類の
一部に装着可能に構成される。他の局面において、コントローラ160は、コンピュータ
200から送られる信号に基づいて、振動、音、光のうちの少なくともいずれかを出力す
るように構成されてもよい。他の局面において、コントローラ160は、仮想現実を提供
する空間に配置されるオブジェクトの位置や動きを制御するためにユーザ190によって
与えられる操作を受け付ける。
The
モーションセンサ130は、ある局面において、ユーザ190の手に取り付けられて、
ユーザ190の手の動きを検出する。たとえば、モーションセンサ130は、手の回転速
度、回転数などを検出する。モーションセンサ130によって得られたユーザ190の手
の動きの検出結果を表すデータ(以下、検出データともいう)は、コンピュータ200に
送られる。モーションセンサ130は、たとえば、手袋型のコントローラ160に設けら
れている。ある実施の形態において、現実空間における安全のため、コントローラ160
は、手袋型のようにユーザ190の手に装着されることにより容易に飛んで行かないもの
に装着されるのが望ましい。他の局面において、ユーザ190に装着されないセンサがユ
ーザ190の手の動きを検出してもよい。たとえば、ユーザ190を撮影するカメラの信
号が、ユーザ190の動作を表す信号として、コンピュータ200に入力されてもよい。
モーションセンサ130とコンピュータ200とは、有線により、または無線により互い
に接続される。無線の場合、通信形態は特に限られず、たとえば、Bluetooth(
登録商標)その他の公知の通信手法が用いられる。
The
Detects the movement of the
Is preferably attached to something that does not easily fly by being attached to the
The
Registered trademark) Other known communication methods are used.
他の局面において、HMDシステム100は、テレビジョン放送受信チューナを備えて
もよい。このような構成によれば、HMDシステム100は、仮想空間2においてテレビ
番組を表示することができる。
In another aspect, the
さらに他の局面において、HMDシステム100は、インターネットに接続するための
通信回路、あるいは、電話回線に接続するための通話機能を備えていてもよい。
In still other aspects, the
[コンピュータのハードウェア構成]
図2を参照して、本実施の形態に係るコンピュータ200について説明する。図2は、
一局面に従うコンピュータ200のハードウェア構成の一例を表すブロック図である。コ
ンピュータ200は、主たる構成要素として、プロセッサ10と、メモリ11と、ストレ
ージ12と、入出力インターフェース13と、通信インターフェース14とを備える。各
構成要素は、それぞれ、バス15に接続されている。
[Computer hardware configuration]
The
It is a block diagram which shows an example of the hardware composition of the
プロセッサ10は、コンピュータ200に与えられる信号に基づいて、あるいは、予め
定められた条件が成立したことに基づいて、メモリ11またはストレージ12に格納され
ているプログラムに含まれる一連の命令を実行する。ある局面において、プロセッサ10
は、CPU(Central Processing Unit)、MPU(Micro Processor Unit)、FP
GA(Field-Programmable Gate Array)その他のデバイスとして実現される。
The
Is a CPU (Central Processing Unit), MPU (Micro Processor Unit), FP
It is realized as a GA (Field-Programmable Gate Array) and other devices.
メモリ11は、プログラムおよびデータを一時的に保存する。プログラムは、たとえば
、ストレージ12からロードされる。データは、コンピュータ200に入力されたデータ
と、プロセッサ10によって生成されたデータとを含む。ある局面において、メモリ11
は、RAM(Random Access Memory)その他の揮発メモリとして実現される。
The
Is realized as RAM (Random Access Memory) or other volatile memory.
ストレージ12は、プログラムおよびデータを永続的に保持する。ストレージ12は、
たとえば、ROM(Read-Only Memory)、ハードディスク装置、フラッシュメモリ、そ
の他の不揮発記憶装置として実現される。ストレージ12に格納されるプログラムは、H
MDシステム100において仮想空間2を提供するためのプログラム、シミュレーション
プログラム、ゲームプログラム、ユーザ認証プログラム、他のコンピュータ200との通
信を実現するためのプログラムを含む。ストレージ12に格納されるデータは、仮想空間
2を規定するためのデータおよびオブジェクトなどを含む。
The
For example, it is realized as a ROM (Read-Only Memory), a hard disk device, a flash memory, or other non-volatile storage device. The program stored in the
The
なお、他の局面において、ストレージ12は、メモリカードのように着脱可能な記憶装
置として実現されてもよい。さらに他の局面において、コンピュータ200に内蔵された
ストレージ12の代わりに、外部の記憶装置に保存されているプログラムおよびデータを
使用する構成が使用されてもよい。このような構成によれば、たとえば、アミューズメン
ト施設のように複数のHMDシステム100が使用される場面において、プログラムやデ
ータの更新を一括して行なうことが可能になる。
In another aspect, the
ある実施の形態において、入出力インターフェース13は、HMD110、HMDセン
サ120またはモーションセンサ130との間で信号を通信する。ある局面において、入
出力インターフェース13は、USB(Universal Serial Bus)インターフェース、D
VI(Digital Visual Interface)、HDMI(登録商標)(High-Definition Multi
media Interface)その他の端子を用いて実現される。なお、入出力インターフェース1
3は上述のものに限られない。
In certain embodiments, the input /
VI (Digital Visual Interface), HDMI (Registered Trademark) (High-Definition Multi)
media Interface) Realized using other terminals. Input /
3 is not limited to the above.
ある実施の形態において、入出力インターフェース13は、さらに、コントローラ16
0と通信し得る。たとえば、入出力インターフェース13は、モーションセンサ130か
ら出力された信号の入力を受ける。他の局面において、入出力インターフェース13は、
プロセッサ10から出力された命令を、コントローラ160に送る。当該命令は、振動、
音声出力、発光などをコントローラ160に指示する。コントローラ160は、当該命令
を受信すると、その命令に応じて、振動、音声出力または発光のいずれかを実行する。
In certain embodiments, the input /
Can communicate with 0. For example, the input /
The instruction output from the
Instruct the
通信インターフェース14は、ネットワーク19に接続されて、ネットワーク19に接
続されている他のコンピュータ(たとえば、サーバ150、他のユーザのコンピュータ2
00など)と通信する。ある局面において、通信インターフェース14は、たとえば、L
AN(Local Area Network)その他の有線通信インターフェース、あるいは、WiFi
(Wireless Fidelity)、Bluetooth(登録商標)、NFC(Near Field Com
munication)その他の無線通信インターフェースとして実現される。なお、通信インター
フェース14は上述のものに限られない。
The
Communicate with (00, etc.). In one aspect, the
AN (Local Area Network) or other wired communication interface, or WiFi
(Wireless Fidelity), Bluetooth®, NFC (Near Field Com)
munication) Realized as another wireless communication interface. The
ある局面において、プロセッサ10は、ストレージ12にアクセスし、ストレージ12
に格納されている1つ以上のプログラムをメモリ11にロードし、当該プログラムに含ま
れる一連の命令を実行する。当該1つ以上のプログラムは、コンピュータ200のオペレ
ーティングシステム、仮想空間2を提供するためのアプリケーションプログラム、コント
ローラ160を用いて仮想空間2で実行可能なゲームソフトウェアなどを含み得る。プロ
セッサ10は、入出力インターフェース13を介して、仮想空間2を提供するための信号
をHMD110に送る。HMD110は、その信号に基づいてモニタ112に映像を表示
する。
In one aspect, the
One or more programs stored in the
なお、図2に示される例では、コンピュータ200は、HMD110の外部に設けられ
る構成が示されているが、他の局面において、コンピュータ200は、HMD110に内
蔵されてもよい。一例として、モニタ112を含む携帯型の情報通信端末(たとえば、ス
マートフォン)がコンピュータ200として機能してもよい。
In the example shown in FIG. 2, the
また、コンピュータ200は、複数のHMD110に共通して用いられる構成であって
もよい。このような構成によれば、たとえば、複数のユーザに同一の仮想空間2を提供す
ることもできるので、各ユーザは同一の仮想空間2で他のユーザと同一のアプリケーショ
ンを楽しむことができる。
Further, the
ある実施の形態において、HMDシステム100では、グローバル座標系が予め設定さ
れている。グローバル座標系は、現実空間における鉛直方向、鉛直方向に直交する水平方
向、ならびに、鉛直方向および水平方向の双方に直交する前後方向にそれぞれ平行な、3
つの基準方向(軸)を有する。本実施の形態では、グローバル座標系は視点座標系の一つ
である。そこで、グローバル座標系における水平方向、鉛直方向(上下方向)、および前
後方向は、それぞれ、x軸、y軸、z軸と規定される。より具体的には、グローバル座標
系において、x軸は現実空間の水平方向に平行である。y軸は、現実空間の鉛直方向に平
行である。z軸は現実空間の前後方向に平行である。
In one embodiment, the
It has one reference direction (axis). In the present embodiment, the global coordinate system is one of the viewpoint coordinate systems. Therefore, the horizontal direction, the vertical direction (vertical direction), and the front-back direction in the global coordinate system are defined as the x-axis, the y-axis, and the z-axis, respectively. More specifically, in the global coordinate system, the x-axis is parallel to the horizontal direction of real space. The y-axis is parallel to the vertical direction in real space. The z-axis is parallel to the front-back direction of the real space.
ある局面において、HMDセンサ120は、赤外線センサを含む。赤外線センサが、H
MD110の各光源から発せられた赤外線をそれぞれ検出すると、HMD110の存在を
検出する。HMDセンサ120は、さらに、各点の値(グローバル座標系における各座標
値)に基づいて、HMD110を装着したユーザ190の動きに応じた、現実空間内にお
けるHMD110の位置および傾きを検出する。より詳しくは、HMDセンサ120は、
経時的に検出された各値を用いて、HMD110の位置および傾きの時間的変化を検出で
きる。
In some aspects, the
When the infrared rays emitted from each light source of the MD110 are detected, the presence of the HMD110 is detected. The
Each value detected over time can be used to detect temporal changes in the position and tilt of the
グローバル座標系は現実空間の座標系と平行である。したがって、HMDセンサ120
によって検出されたHMD110の各傾きは、グローバル座標系におけるHMD110の
3軸周りの各傾きに相当する。HMDセンサ120は、グローバル座標系におけるHMD
110の傾きに基づき、uvw視野座標系をHMD110に設定する。HMD110に設
定されるuvw視野座標系は、HMD110を装着したユーザ190が仮想空間2におい
て物体を見る際の視点座標系に対応する。
The global coordinate system is parallel to the coordinate system in real space. Therefore, the
Each slope of the
Based on the tilt of 110, the uvw field coordinate system is set to HMD110. The uvw field-of-view coordinate system set in the
[uvw視野座標系]
図3を参照して、uvw視野座標系について説明する。図3は、ある実施の形態に従う
HMD110に設定されるuvw視野座標系を概念的に表す図である。HMDセンサ12
0は、HMD110の起動時に、グローバル座標系におけるHMD110の位置および傾
きを検出する。プロセッサ10は、検出された値に基づいて、uvw視野座標系をHMD
110に設定する。
[Uvw field coordinate system]
The uvw field coordinate system will be described with reference to FIG. FIG. 3 is a diagram conceptually representing the uvw field coordinate system set in the
0 detects the position and tilt of the
Set to 110.
図3に示されるように、HMD110は、HMD110を装着したユーザ190の頭部
を中心(原点)とした3次元のuvw視野座標系を設定する。より具体的には、HMD1
10は、グローバル座標系を規定する水平方向、鉛直方向、および前後方向(x軸、y軸
、z軸)を、グローバル座標系内においてHMD110の各軸周りの傾きだけ各軸周りに
それぞれ傾けることによって新たに得られる3つの方向を、HMD110におけるuvw
視野座標系のピッチ方向(u軸)、ヨー方向(v軸)、およびロール方向(w軸)として
設定する。
As shown in FIG. 3, the
It is set as the pitch direction (u-axis), yaw direction (v-axis), and roll direction (w-axis) of the visual field coordinate system.
ある局面において、HMD110を装着したユーザ190が直立し、かつ、正面を視認
している場合、プロセッサ10は、グローバル座標系に平行なuvw視野座標系をHMD
110に設定する。この場合、グローバル座標系における水平方向(x軸)、鉛直方向(
y軸)、および前後方向(z軸)は、HMD110におけるuvw視野座標系のピッチ方
向(u軸)、ヨー方向(v軸)、およびロール方向(w軸)に一致する。
In a certain aspect, when the
Set to 110. In this case, the horizontal direction (x-axis) and the vertical direction (x-axis) in the global coordinate system (
The y-axis) and the anteroposterior direction (z-axis) coincide with the pitch direction (u-axis), yaw direction (v-axis), and roll direction (w-axis) of the uvw visual field coordinate system in the
uvw視野座標系がHMD110に設定された後、HMDセンサ120は、HMD11
0の動きに基づいて、設定されたuvw視野座標系におけるHMD110の傾き(傾きの
変化量)を検出できる。この場合、HMDセンサ120は、HMD110の傾きとして、
uvw視野座標系におけるHMD110のピッチ角(θu)、ヨー角(θv)、およびロ
ール角(θw)をそれぞれ検出する。ピッチ角(θu)は、uvw視野座標系におけるピ
ッチ方向周りのHMD110の傾き角度を表す。ヨー角(θv)は、uvw視野座標系に
おけるヨー方向周りのHMD110の傾き角度を表す。ロール角(θw)は、uvw視野
座標系におけるロール方向周りのHMD110の傾き角度を表す。
After the uvw field coordinate system is set to HMD110, the
Based on the movement of 0, the inclination (change amount of inclination) of the
The pitch angle (θu), yaw angle (θv), and roll angle (θw) of the
HMDセンサ120は、検出されたHMD110の傾き角度に基づいて、HMD110
が動いた後のHMD110におけるuvw視野座標系を、HMD110に設定する。HM
D110と、HMD110のuvw視野座標系との関係は、HMD110の位置および傾
きに関わらず、常に一定である。HMD110の位置および傾きが変わると、当該位置お
よび傾きの変化に連動して、グローバル座標系におけるHMD110のuvw視野座標系
の位置および傾きが変化する。
The
The uvw field-of-view coordinate system in the
The relationship between D110 and the uvw field coordinate system of HMD110 is always constant regardless of the position and inclination of HMD110. When the position and inclination of the
ある局面において、HMDセンサ120は、赤外線センサからの出力に基づいて取得さ
れる赤外線の光強度および複数の点間の相対的な位置関係(たとえば、各点間の距離など
)に基づいて、HMD110の現実空間内における位置を、HMDセンサ120に対する
相対位置として特定してもよい。また、プロセッサ10は、特定された相対位置に基づい
て、現実空間内(グローバル座標系)におけるHMD110のuvw視野座標系の原点を
決定してもよい。
In one aspect, the
[仮想空間]
図4を参照して、仮想空間2についてさらに説明する。図4は、ある実施の形態に従う
仮想空間2を表現する一態様を概念的に表す図である。仮想空間2は、中心21の360
度方向の全体を覆う全天球状の構造を有する。図4では、説明を複雑にしないために、仮
想空間2のうちの上半分の天球が例示されている。仮想空間2では各メッシュが規定され
る。各メッシュの位置は、仮想空間2に規定されるXYZ座標系における座標値として予
め規定されている。コンピュータ200は、仮想空間2に展開可能なコンテンツ(静止画
、動画など)を構成する各部分画像を、仮想空間2において対応する各メッシュにそれぞ
れ対応付けて、ユーザ190によって視認可能な仮想空間画像22が展開される仮想空間
2をユーザ190に提供する。
[Virtual space]
The
It has an all-sky spherical structure that covers the entire direction. In FIG. 4, the celestial sphere in the upper half of the
ある局面において、仮想空間2では、中心21を原点とするXYZ座標系が規定される
。XYZ座標系は、たとえば、グローバル座標系に平行である。XYZ座標系は視点座標
系の一種であるため、XYZ座標系における水平方向、鉛直方向(上下方向)、および前
後方向は、それぞれX軸、Y軸、Z軸として規定される。したがって、XYZ座標系のX
軸(水平方向)がグローバル座標系のx軸と平行であり、XYZ座標系のY軸(鉛直方向
)がグローバル座標系のy軸と平行であり、XYZ座標系のZ軸(前後方向)がグローバ
ル座標系のz軸と平行である。
In a certain aspect, the
The axis (horizontal direction) 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-back direction) of the XYZ coordinate system is. It is parallel to the z-axis of the global coordinate system.
HMD110の起動時、すなわちHMD110の初期状態において、仮想カメラ1が、
仮想空間2の中心21に配置される。仮想カメラ1は、現実空間におけるHMD110の
動きに連動して、仮想空間2を同様に移動する。これにより、現実空間におけるHMD1
10の位置および向きの変化が、仮想空間2において同様に再現される。
When the HMD110 is started, that is, in the initial state of the HMD110, the
It is arranged at the
The changes in the position and orientation of 10 are similarly reproduced in the
仮想カメラ1には、HMD110の場合と同様に、uvw視野座標系が規定される。仮
想空間2における仮想カメラのuvw視野座標系は、現実空間(グローバル座標系)にお
けるHMD110のuvw視野座標系に連動するように規定されている。したがって、H
MD110の傾きが変化すると、それに応じて、仮想カメラ1の傾きも変化する。また、
仮想カメラ1は、HMD110を装着したユーザ190の現実空間における移動に連動し
て、仮想空間2において移動することもできる。
As in the case of the
When the tilt of the
The
仮想カメラ1の向きは、仮想カメラ1の位置および傾きに応じて決まるので、ユーザ1
90が仮想空間画像22を視認する際に基準となる視線(基準視線5)は、仮想カメラ1
の向きに応じて決まる。コンピュータ200のプロセッサ10は、基準視線5に基づいて
、仮想空間2における視界領域23を規定する。視界領域23は、仮想空間2のうち、H
MD110を装着したユーザ190の視界に対応する。
Since the orientation of the
When the 90 visually recognizes the
It depends on the direction of. The
It corresponds to the field of view of the
注視センサ140によって検出されるユーザ190の視線方向は、ユーザ190が物体
を視認する際の視点座標系における方向である。HMD110のuvw視野座標系は、ユ
ーザ190がモニタ112を視認する際の視点座標系に等しい。また、仮想カメラ1のu
vw視野座標系は、HMD110のuvw視野座標系に連動している。したがって、ある
局面に従うHMDシステム100は、注視センサ140によって検出されたユーザ190
の視線方向を、仮想カメラ1のuvw視野座標系におけるユーザ190の視線方向とみな
すことができる。
The line-of-sight direction of the
The vw field-of-view coordinate system is linked to the uvw field-of-view coordinate system of the
The line-of-sight direction can be regarded as the line-of-sight direction of the
[ユーザの視線]
図5を参照して、ユーザ190の視線方向の決定について説明する。図5は、ある実施
の形態に従うHMD110を装着するユーザ190の頭部を上から表した図である。
[User's line of sight]
The determination of the line-of-sight direction of the
ある局面において、注視センサ140は、ユーザ190の右目および左目の各視線を検
出する。ある局面において、ユーザ190が近くを見ている場合、注視センサ140は、
視線R1およびL1を検出する。他の局面において、ユーザ190が遠くを見ている場合
、注視センサ140は、視線R2およびL2を検出する。この場合、ロール方向wに対し
て視線R2およびL2がなす角度は、ロール方向wに対して視線R1およびL1がなす角
度よりも小さい。注視センサ140は、検出結果をコンピュータ200に送信する。
In one aspect, the
The lines of sight R1 and L1 are detected. In another aspect, when the
コンピュータ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
[視界領域]
図6および図7を参照して、視界領域23について説明する。図6は、仮想空間2にお
いて視界領域23をX方向から見たYZ断面を表す図である。図7は、仮想空間2におい
て視界領域23をY方向から見たXZ断面を表す図である。
[Visibility area]
The field of
図6に示されるように、YZ断面における視界領域23は、領域24を含む。領域24
は、仮想カメラ1の基準視線5と仮想空間2のYZ断面とによって定義される。プロセッ
サ10は、仮想空間2おける基準視線5を中心として極角αを含む範囲を、領域24とし
て規定する。
As shown in FIG. 6, the field of
Is defined by the reference line of
図7に示されるように、XZ断面における視界領域23は、領域25を含む。領域25
は、基準視線5と仮想空間2のXZ断面とによって定義される。プロセッサ10は、仮想
空間2における基準視線5を中心とした方位角βを含む範囲を、領域25として規定する
。
As shown in FIG. 7, the field of
Is defined by the reference line of
ある局面において、HMDシステム100は、コンピュータ200からの信号に基づい
て、視界画像をモニタ112に表示させることにより、ユーザ190に仮想空間2を提供
する。視界画像は、仮想空間画像22のうちの視界領域23に重畳する部分に相当する。
ユーザ190が、頭に装着したHMD110を動かすと、その動きに連動して仮想カメラ
1も動く。その結果、仮想空間2における視界領域23の位置が変化する。これにより、
モニタ112に表示される視界画像は、仮想空間画像22のうち、仮想空間2においてユ
ーザ190が向いた方向の視界領域23に重畳する画像に更新される。ユーザ190は、
仮想空間2における所望の方向を視認することができる。
In one aspect, the
When the
The visual field image displayed on the
The desired direction in the
ユーザ190は、HMD110を装着している間、現実世界を視認することなく、仮想
空間2に展開される仮想空間画像22のみを視認できる。そのため、HMDシステム10
0は、仮想空間2への高い没入感覚をユーザ190に与えることができる。
While wearing the
0 can give the user 190 a high sense of immersion in the
ある局面において、プロセッサ10は、HMD110を装着したユーザ190の現実空
間における移動に連動して、仮想空間2において仮想カメラ1を移動し得る。この場合、
プロセッサ10は、仮想空間2における仮想カメラ1の位置および向きに基づいて、HM
D110のモニタ112に投影される画像領域(すなわち、仮想空間2における視界領域
23)を特定する。
In a certain aspect, the
The
The image area projected on the
ある実施の形態に従うと、仮想カメラ1は、二つの仮想カメラ、すなわち、右目用の画
像を提供するための仮想カメラと、左目用の画像を提供するための仮想カメラとを含むこ
とが望ましい。また、ユーザ190が3次元の仮想空間2を認識できるように、適切な視
差が、二つの仮想カメラに設定されていることが好ましい。本実施の形態においては、仮
想カメラ1が二つの仮想カメラを含み、二つの仮想カメラのロール方向が合成されること
によって生成されるロール方向(w)がHMD110のロール方向(w)に適合されるよ
うに構成されているものとして、本開示に係る技術思想を例示する。
According to certain embodiments, the
[コントローラ]
図8を参照して、コントローラ160の一例について説明する。図8は、ある実施の形
態に従うコントローラ160の概略構成を表す図である。
[controller]
An example of the
図8の分図(A)に示されるように、ある局面において、コントローラ160は、右コ
ントローラ800と左コントローラ(図示しない)とを含み得る。右コントローラ800
は、ユーザ190の右手で操作される。左コントローラは、ユーザ190の左手で操作さ
れる。ある局面において、右コントローラ800と左コントローラとは、別個の装置とし
て対称に構成される。したがって、ユーザ190は、右コントローラ800を把持した右
手と、左コントローラを把持した左手とをそれぞれ自由に動かすことができる。他の局面
において、コントローラ160は両手の操作を受け付ける一体型のコントローラであって
もよい。以下、右コントローラ800について説明する。
As shown in the segment (A) of FIG. 8, in some aspects, the
Is operated with the right hand of
右コントローラ800は、グリップ30と、フレーム31と、天面32とを備える。グ
リップ30は、ユーザ190の右手によって把持されるように構成されている。たとえば
、グリップ30は、ユーザ190の右手の掌と3本の指(中指、薬指、小指)とによって
保持され得る。
The
グリップ30は、ボタン33,34と、モーションセンサ130とを含む。ボタン33
は、グリップ30の側面に配置され、右手の中指による操作を受け付ける。ボタン34は
、グリップ30の前面に配置され、右手の人差し指による操作を受け付ける。ある局面に
おいて、ボタン33,34は、トリガー式のボタンとして構成される。モーションセンサ
130は、グリップ30の筐体に内蔵されている。なお、ユーザ190の動作がカメラそ
の他の装置によってユーザ190の周りから検出可能である場合には、グリップ30は、
モーションセンサ130を備えなくてもよい。
The
Is arranged on the side surface of the
The
フレーム31は、その円周方向に沿って配置された複数の赤外線LED35を含む。赤
外線LED35は、コントローラ160を使用するプログラムの実行中に、当該プログラ
ムの進行に合わせて赤外線を発光する。赤外線LED35から発せられた赤外線は、右コ
ントローラ800と左コントローラとの各位置や姿勢(傾き、向き)を検出するために使
用され得る。図8に示される例では、二列に配置された赤外線LED35が示されている
が、配列の数は図8に示されるものに限られない。一列あるいは3列以上の配列が使用さ
れてもよい。
The
天面32は、ボタン36,37と、アナログスティック38とを備える。ボタン36,
37は、プッシュ式ボタンとして構成される。ボタン36,37は、ユーザ190の右手
の親指による操作を受け付ける。アナログスティック38は、ある局面において、初期位
置(ニュートラルの位置)から360度任意の方向への操作を受け付ける。当該操作は、
たとえば、仮想空間2に配置されるオブジェクトを移動するための操作を含む。
The
37 is configured as a push-type button.
For example, it includes an operation for moving an object arranged in the
ある局面において、右コントローラ800および左コントローラは、赤外線LED35
その他の部材を駆動するための電池を含む。電池は、充電式、ボタン型、乾電池型などを
含むが、これらに限定されない。他の局面において、右コントローラ800と左コントロ
ーラは、たとえば、コンピュータ200のUSBインターフェースに接続され得る。この
場合、右コントローラ800および左コントローラは、電池を必要としない。
In one aspect, the
Includes batteries for driving other components. Batteries include, but are not limited to, rechargeable, button type, dry cell type and the like. In another aspect, the
図8の分図(B)は、右コントローラ800を把持するユーザ190の右手に対応して
仮想空間2に配置されるハンドオブジェクト810の一例を示す。たとえば、ユーザ19
0の右手に対応するハンドオブジェクト810に対して、ヨー、ロール、ピッチの各方向
が規定される。たとえば、入力操作が、右コントローラ800のボタン34に対して行な
われると、ハンドオブジェクト810の人差し指を握りこんだ状態とし、入力操作がボタ
ン34に対して行なわれていない場合には、分図(B)に示すように、ハンドオブジェク
ト810の人差し指を伸ばした状態とすることもできる。たとえば、ハンドオブジェクト
810において親指と人差し指とが伸びている場合に、親指の伸びる方向がヨー方向、人
差し指の伸びる方向がロール方向、ヨー方向の軸およびロール方向の軸によって規定され
る平面に垂直な方向がピッチ方向としてハンドオブジェクト810に規定される。
FIG. 8B shows an example of a
The yaw, roll, and pitch directions are defined for the
[HMDの制御装置]
図9を参照して、HMD110の制御装置について説明する。ある実施の形態において
、制御装置は周知の構成を有するコンピュータ200によって実現される。図9は、ある
実施の形態に従うコンピュータ200をモジュール構成として表すブロック図である。
[HMD control device]
The control device of the
図9に示されるように、コンピュータ200は、表示制御モジュール220と、仮想空
間制御モジュール230と、音声制御モジュール225と、メモリモジュール240と、
通信制御モジュール250とを備える。
As shown in FIG. 9, the
It includes a
表示制御モジュール220は、サブモジュールとして、仮想カメラ制御モジュール22
1と、視界領域決定モジュール222と、視界画像生成モジュール223と、基準視線特
定モジュール224と、視線検出モジュール226と、ハンドトラッキングモジュール2
27と、フェイストラッキングモジュール228とを含む。
The
1, the field of view
27 and a
仮想空間制御モジュール230は、サブモジュールとして、仮想空間定義モジュール2
31と、仮想オブジェクト生成モジュール232と、手オブジェクト制御モジュール23
3とを含む。
The virtual
31, virtual
3 and is included.
ある実施の形態において、表示制御モジュール220、仮想空間制御モジュール230
、および音声制御モジュール225は、プロセッサ10によって実現される。他の実施の
形態において、複数のプロセッサ10が表示制御モジュール220、仮想空間制御モジュ
ール230、および音声制御モジュール225として作動してもよい。メモリモジュール
240は、メモリ11またはストレージ12によって実現される。通信制御モジュール2
50は、通信インターフェース14によって実現される。
In one embodiment, the
, And the
50 is realized by the
ある局面において、表示制御モジュール220は、HMD110のモニタ112におけ
る画像表示を制御する。仮想カメラ制御モジュール221は、仮想空間2に仮想カメラ1
を配置し、仮想カメラ1の挙動、向きなどを制御する。視界領域決定モジュール222は
、HMD110を装着したユーザ190の頭の向きに応じて、視界領域23を規定する。
視界画像生成モジュール223は、決定された視界領域23に基づいて、モニタ112に
表示される視界画像のデータ(視界画像データともいう)を生成する。さらに、視界画像
生成モジュール223は、仮想空間制御モジュール230から受信したデータに基づいて
、視界画像データを生成する。視界画像生成モジュール223によって生成された視界画
像データは、通信制御モジュール250によってHMD110に出力される。基準視線特
定モジュール224は、HMDセンサ120またはセンサ114からの信号に基づいて基
準視線(HMD110の傾き)を検出する。視線検出モジュール226は、注視センサ1
40からの信号に基づいて、ユーザ190の視線を特定する。ハンドトラッキングモジュ
ール227は、ユーザ190が装着するコントローラ160の動き、つまり、ユーザ19
0の手の動きを検出する。より具体的には、HMDセンサ120は、コントローラ160
に設けられた赤外線LED35が発する赤外線を検出してコンピュータ200に出力する
。ハンドトラッキングモジュール227は、HMDセンサ120から入力される検出結果
に基づいて、コントローラ160(右コントローラ800および左コントローラの各々)
の位置を検出する。フェイストラッキングモジュール228は、ユーザ190の表情を検
出する。フェイストラッキングモジュール228の詳細は後述される。
In one aspect, the
Is arranged to control the behavior, orientation, etc. of the
The visual field
The line of sight of the
Detects 0 hand movements. More specifically, the
The infrared rays emitted by the infrared rays LED 35 provided in the
Detect the position of. The
仮想空間制御モジュール230は、ユーザ190に提供される仮想空間2を制御する。
仮想空間定義モジュール231は、仮想空間2を表す仮想空間データを生成することによ
り、HMDシステム100における仮想空間2を規定する。
The virtual
The virtual
仮想オブジェクト生成モジュール232は、仮想空間2に配置されるオブジェクトのデ
ータを生成する。オブジェクトは、たとえば、他アバターオブジェクト、仮想パネル、仮
想手紙、および仮想ポストなどを含み得る。仮想オブジェクト生成モジュール232によ
って生成されたデータは、視界画像生成モジュール223に出力される。
The virtual
手オブジェクト制御モジュール233は、手オブジェクトを仮想空間2に配置する。手
オブジェクトは、たとえば、コントローラ160を保持したユーザ190の右手あるいは
左手に対応する。ある局面において、手オブジェクト制御モジュール233は、右手ある
いは左手に対応する手オブジェクトを仮想空間2に配置するためのデータを生成する。ま
た、手オブジェクト制御モジュール233は、ユーザ190によるコントローラ160の
操作に応じて、手オブジェクトを動かすためのデータを生成する。手オブジェクト制御モ
ジュール233によって生成されたデータは、視界画像生成モジュール223に出力され
る。
The hand object control module 233 arranges the hand object in the
他の局面において、ユーザ190の体の一部の動き(たとえば、左手、右手、左足、右
足、頭などの動き)がコントローラ160に関連付けられている場合、仮想空間制御モジ
ュール230は、ユーザ190の体の一部に対応する部分オブジェクトを仮想空間2に配
置するためのデータを生成する。仮想空間制御モジュール230は、ユーザ190が体の
一部を用いてコントローラ160を操作すると、部分オブジェクトを動かすためのデータ
を生成する。これらのデータは、視界画像生成モジュール223に出力される。
In another aspect, if the movement of a part of the body of the user 190 (eg, the movement of the left hand, right hand, left foot, right foot, head, etc.) is associated with the
音声制御モジュール225は、HMD110から、ユーザ190のマイク119を用い
た発話を検出すると、当該発話に対応する音声データの送信対象のコンピュータ200を
特定する。音声データは、音声制御モジュール225によって特定されたコンピュータ2
00に送信される。音声制御モジュール225は、ネットワーク19を介して他のユーザ
のコンピュータ200から音声データを受信すると、当該音声データに対応する音声(発
話)をスピーカ115から出力する。
When the
It is sent to 00. When the
メモリモジュール240は、コンピュータ200が仮想空間2をユーザ190に提供す
るために使用されるデータを保持している。ある局面において、メモリモジュール240
は、空間情報241と、オブジェクト情報242と、ユーザ情報243と、顔情報244
とを保持している。
The
Is
And holds.
空間情報241は、仮想空間2を提供するために規定された1つ以上のテンプレートを
保持している。
オブジェクト情報242は、仮想空間2において再生されるコンテンツ、当該コンテン
ツで使用されるオブジェクトを配置するための情報を保持している。当該コンテンツは、
たとえば、ゲーム、現実社会と同様の風景を表したコンテンツなどを含み得る。さらに、
オブジェクト情報242は、コントローラ160を操作するユーザ190の手に相当する
手オブジェクトを仮想空間2に配置するためのデータと、各ユーザのアバターオブジェク
トを仮想空間2に配置するためのデータと、仮想パネルなどのその他のオブジェクトを仮
想空間2に配置するためのデータとを含む。
The
For example, it may include a game, content representing a landscape similar to the real world, and the like. Moreover,
The
ユーザ情報243は、HMDシステム100の制御装置としてコンピュータ200を機
能させるためのプログラム、オブジェクト情報242に保持される各コンテンツを使用す
るアプリケーションプログラムなどを保持している。メモリモジュール240に格納され
ているデータおよびプログラムは、HMD110のユーザ190によって入力される。あ
るいは、プロセッサ10が、当該コンテンツを提供する事業者が運営するコンピュータ(
たとえば、サーバ150)からプログラムあるいはデータをダウンロードして、ダウンロ
ードされたプログラムあるいはデータをメモリモジュール240に格納する。顔情報24
4は、ユーザ190の顔器官を検出するために必要なテンプレートを含む。ある実施形態
において、顔情報244は、口テンプレート245と、目テンプレート246と、眉テン
プレート247とを含む。各テンプレートは、顔を構成する器官に対応する画像であり得
る。たとえば、口テンプレート245は、口の画像であり得る。なお、各テンプレートは
複数の画像を含んでもよい。
The
For example, a program or data is downloaded from the server 150), and the downloaded program or data is stored in the
4 includes a template required to detect the facial organs of
通信制御モジュール250は、ネットワーク19を介して、サーバ150その他の情報
通信装置と通信し得る。
The
ある局面において、表示制御モジュール220および仮想空間制御モジュール230は
、たとえば、ユニティテクノロジーズ社によって提供されるUnity(登録商標)を用
いて実現され得る。他の局面において、表示制御モジュール220および仮想空間制御モ
ジュール230は、各処理を実現する回路素子の組み合わせとしても実現され得る。
In certain aspects, the
コンピュータ200における処理は、ハードウェアと、プロセッサ10により実行され
るソフトウェアとによって実現される。このようなソフトウェアは、ハードディスクその
他のメモリモジュール240に予め格納されている場合がある。また、ソフトウェアは、
CD−ROMその他のコンピュータ読み取り可能な不揮発性のデータ記録媒体に格納され
て、プログラム製品として流通している場合もある。あるいは、当該ソフトウェアは、イ
ンターネットその他のネットワークに接続されている情報提供事業者によってダウンロー
ド可能なプログラム製品として提供される場合もある。このようなソフトウェアは、光デ
ィスク駆動装置その他のデータ読取装置によってデータ記録媒体から読み取られて、ある
いは、通信制御モジュール250を介してサーバ150その他のコンピュータからダウン
ロードされた後、記憶モジュールに一旦格納される。そのソフトウェアは、プロセッサ1
0によって記憶モジュールから読み出され、実行可能なプログラムの形式でRAMに格納
される。プロセッサ10は、そのプログラムを実行する。
The processing in the
It may be stored on a CD-ROM or other computer-readable non-volatile data recording medium and distributed as a program product. Alternatively, the software may be provided as a downloadable program product 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 a
Read from the storage module by 0 and stored in RAM in the form of an executable program.
コンピュータ200を構成するハードウェアは、一般的なものである。したがって、本
実施の形態に係る最も本質的な部分は、コンピュータ200に格納されたプログラムであ
るとも言える。なお、コンピュータ200のハードウェアの動作は周知であるので、詳細
な説明は繰り返さない。
The hardware that constitutes the
なお、データ記録媒体としては、CD−ROM、FD(Flexible Disk)、ハードディ
スクに限られず、磁気テープ、カセットテープ、光ディスク(MO(Magnetic Optical
Disc)/MD(Mini Disc)/DVD(Digital Versatile Disc))、IC(Integr
ated Circuit)カード(メモリカードを含む)、光カード、マスクROM、EPROM
(Electronically Programmable Read-Only Memory)、EEPROM(Electronicall
y Erasable Programmable Read-Only Memory)、フラッシュROMなどの半導体メモ
リなどの固定的にプログラムを担持する不揮発性のデータ記録媒体でもよい。
The data recording medium is not limited to CD-ROM, FD (Flexible Disk), and hard disk, but also magnetic tape, cassette tape, and optical disk (MO (Magnetic Optical).
Disc) / MD (Mini Disc) / DVD (Digital Versatile Disc)), IC (Integr
ated Circuit) Card (including memory card), optical card, mask ROM, EPROM
(Electronically Programmable Read-Only Memory), EEPROM (Electronicall)
y Erasable Programmable Read-Only Memory), a non-volatile data recording medium such as a semiconductor memory such as a flash ROM that stably carries a program may be used.
ここで言うプログラムとは、プロセッサ10により直接実行可能なプログラムだけでな
く、ソースプログラム形式のプログラム、圧縮処理されたプログラム、暗号化されたプロ
グラムなどを含み得る。
The program referred to here may include not only a program that can be directly executed by the
[HMDシステムの制御構造]
図10を参照して、HMDシステム100の制御構造について説明する。図10は、あ
る実施の形態に従うHMDシステム100において実行される処理の一部を表すシーケン
スチャートである。
[Control structure of HMD system]
The control structure of the
図10に示されるように、ステップS1010にて、コンピュータ200のプロセッサ
10は、仮想空間定義モジュール231として、仮想空間画像データを特定し、仮想空間
2を定義する。
As shown in FIG. 10, in step S1010, the
ステップS1020にて、プロセッサ10は、仮想カメラ1を初期化する。たとえば、
プロセッサ10は、メモリのワーク領域において、仮想カメラ1を仮想空間2において予
め規定された中心点に配置し、仮想カメラ1の視線をユーザ190が向いている方向に向
ける。
In step S1020, the
The
ステップS1030にて、プロセッサ10は、視界画像生成モジュール223として、
初期の視界画像を表示するための視界画像データを生成する。生成された視界画像データ
は、通信制御モジュール250によってHMD110に出力される。
In step S1030, the
Generates field of view image data for displaying the initial field of view image. The generated visual field image data is output to the
ステップS1032にて、HMD110のモニタ112は、コンピュータ200から受
信した視界画像データに基づいて、視界画像を表示する。HMD110を装着したユーザ
190は、視界画像を視認すると仮想空間2を認識し得る。
In step S1032, the
ステップS1034にて、HMDセンサ120は、HMD110から発信される複数の
赤外線光に基づいて、HMD110の位置と傾きを検知する。検知結果は、動き検知デー
タとして、コンピュータ200に出力される。
In step S1034, the
ステップS1040にて、プロセッサ10は、HMD110の動き検知データに含まれ
る位置と傾きとに基づいて、HMD110を装着したユーザ190の視界方向を特定する
。
In step S1040, the
ステップS1050にて、プロセッサ10は、アプリケーションプログラムを実行し、
アプリケーションプログラムに含まれる命令に基づいて、仮想空間2にオブジェクトを提
示する。このとき提示されるオブジェクトは、他アバターオブジェクトを含む。
In step S1050, the
An object is presented in the
ステップS1060にて、コントローラ160は、モーションセンサ130から出力さ
れる信号に基づいて、ユーザ190の操作を検出し、その検出された操作を表す検出デー
タをコンピュータ200に出力する。なお、他の局面において、ユーザ190によるコン
トローラ160の操作は、ユーザ190の周囲に配置されたカメラからの画像に基づいて
検出されてもよい。
In step S1060, the
ステップS1065にて、プロセッサ10は、コントローラ160から取得した検出デ
ータに基づいて、ユーザ190によるコントローラ160の操作を検出する。
In step S1065, the
ステップS1070にて、プロセッサ10は、手オブジェクトを仮想空間2に提示する
ための視界画像データを生成する。
In step S1070, the
ステップS1080にて、プロセッサ10は、ユーザ190によるコントローラ160
の操作に基づく視界画像データを生成する。生成された視界画像データは、通信制御モジ
ュール250によってHMD110に出力される。
In step S1080,
Generates field of view image data based on the operation of. The generated visual field image data is output to the
ステップS1092にて、HMD110は、受信した視界画像データに基づいて視界画
像を更新し、更新後の視界画像をモニタ112に表示する。
In step S1092, the
[技術思想]
次に、図11〜図13を用いて本開示に従う技術思想を説明する。図11は、仮想空間
2に展開されている仮想空間画像22(以下、「パノラマ画像22」とも言う)を変更す
るための処理を説明する図(その1)である。
[Technical Thought]
Next, the technical idea according to the present disclosure will be described with reference to FIGS. 11 to 13. FIG. 11 is a diagram (No. 1) for explaining a process for changing the virtual space image 22 (hereinafter, also referred to as “
図11を参照して、仮想空間2には花1110を含むパノラマ画像22が展開されてい
る。また、仮想空間2は、スピーカオブジェクト1120を含む。ある局面において、ユ
ーザ190は、仮想空間2に展開されているパノラマ画像22を変更したいと思う。係る
場合、ユーザ190は、パノラマ画像22を変更するためのトリガをコンピュータ200
に入力する(ステップS1)。一例として、トリガは、スピーカオブジェクト1120と
ハンドオブジェクト810とを接触させることを含む。
With reference to FIG. 11, a
Is input to (step S1). As an example, the trigger involves bringing the
その後、ユーザ190は、検索キーをコンピュータ200に入力する(ステップS2)
。図11に示される例において、ユーザ190は、「動物」と発話する。コンピュータ2
00は、マイク119から入力される音声信号から文字列「動物」を抽出する。コンピュ
ータ200は、抽出された文字列を表す検索キー1130をサーバ150に送信する(ス
テップS3)。サーバ150は、パノラマ画像DB(データベース)1934を保持する
ストレージ1930を有する。パノラマ画像DB1934は、パノラマ画像(動画像を含
む)と、パノラマ画像を識別する情報(以下、「パノラマ画像ID」とも言う。)とを関
連付けて複数保持する。
After that, the
.. In the example shown in FIG. 11, the
00 extracts the character string "animal" from the audio signal input from the
サーバ150は、コンピュータ200から検索キー1130が入力されると、当該検索
キー1130に基づいて、パノラマ画像DB1934に格納される複数のパノラマ画像の
中から、一以上のパノラマ画像を検索する(ステップS4)。サーバ150は、検索され
た一以上のパノラマ画像のサムネイル1140を生成する。サムネイル1140は、パノ
ラマ画像を特定するための情報として機能する。サーバ150は、生成したサムネイル1
140とパノラマ画像ID1150とをコンピュータ200に送信する(ステップS5)
。
When the search key 1130 is input from the
The 140 and the
..
図12は、パノラマ画像22を変更するための処理を説明する図(その2)である。図
12に示される視界画像1200は、サムネイル1210〜1260を含む。これらのサ
ムネイルは、受信した一以上のサムネイル1140に対応する。また、これらのサムネイ
ルは、静止画像または動画像のいずれであってもよい。
FIG. 12 is a diagram (No. 2) for explaining the process for changing the
ユーザ190は、サムネイル1210〜1260のうち一のサムネイル(パノラマ画像
)をハンドオブジェクト810で選択する(ステップS6)。たとえば、ユーザ190は
、犬を含むサムネイル1210とハンドオブジェクト810とを接触させることにより、
サムネイル1210を選択する。
The
図13は、パノラマ画像22を変更するための処理を説明する図(その3)である。コ
ンピュータ200は、ユーザ190から選択されたサムネイルに対応するパノラマ画像I
D1310をサーバ150に送信する(ステップS7)。サーバ150は、受信したパノ
ラマ画像IDに対応するパノラマ画像1320をコンピュータ200に送信する。コンピ
ュータ200は、受信したパノラマ画像1320を仮想空間2に展開する(ステップS9
)。これにより、ユーザ190は、仮想空間2において犬1330を含むパノラマ画像1
320を視認できる。
FIG. 13 is a diagram (No. 3) for explaining the process for changing the
D1310 is transmitted to the server 150 (step S7). The
). As a result, the
320 can be visually recognized.
上記によれば、コンピュータ200は、ユーザ190に入力された検索キーに関連する
一以上のパノラマ画像、換言すれば、ユーザ190が所望するパノラマ画像(を特定する
情報)をユーザ190に提示できる。以下、パノラマ画像を変更するためのより具体的な
処理について説明する。
According to the above, the
[HMDシステム1400の構成]
図14は、ある実施形態に従うHMDシステム1400の構成を説明するための図であ
る。HMDシステム1400は、HMD110に替えてHMD1410を有する点におい
て、図1で説明したHMDシステム100と相違する。
[Configuration of HMD system 1400]
FIG. 14 is a diagram for explaining the configuration of the
HMD1410は、第1カメラ116と、第2カメラ117とを有する点において、H
MD110と相違する。第1カメラ116は、ユーザ190の顔の下部を撮影する。より
具体的には、第1カメラ116は、ユーザ190の鼻、頬、および口などを撮影する。第
2カメラ117は、ユーザ190の目および眉などを撮影する。HMD1410のユーザ
190側の筐体をHMD1410の内側、HMD1410のユーザ190とは逆側の筐体
をHMD1410の外側と定義する。ある局面において、第1カメラ116は、HMD1
410の外側に配置され、第2カメラ117は、HMD1410の内側に配置され得る。
第1カメラ116および第2カメラ117が生成した画像は、コンピュータ200に入力
される。
The
It is different from MD110. The
Located outside the 410, the
The images generated by the
フェイストラッキングモジュール228は、ユーザ190の第1カメラ116および第
2カメラ117が生成するユーザ190の顔の画像から、ユーザ190の顔を構成する器
官(例えば、口,目,眉)を検出する。フェイストラッキングモジュール228は、検出
した各器官ごとの特徴点の位置を間欠的に検出する。換言すれば、フェイストラッキング
モジュール228は、ユーザ190の表情を検出する。以下、フェイストラッキングモジ
ュール228のより具体的な処理を説明する。
The
[フェイストラッキング]
以下、図15〜図18を参照して、ユーザの表情(顔の動き)を検出するための具体例
について説明する。図15〜図18では、一例として、ユーザ190の口の動きを検出す
る具体例について説明する。なお、図15〜図18で説明される検出方法は、ユーザ19
0の口の動きに限られず、ユーザ190の顔を構成する他の器官(例えば、目、眉、鼻、
頬)の動きの検出にも適用され得る。
[Face tracking]
Hereinafter, a specific example for detecting a user's facial expression (face movement) will be described with reference to FIGS. 15 to 18. 15 to 18 show, as an example, a specific example of detecting the movement of the mouth of the
Not limited to 0 mouth movements, other organs that make up the
It can also be applied to the detection of cheek) movement.
図15は、ユーザの顔画像1500から口を検出する制御について説明する図である。
第1カメラ116により生成された顔画像1500は、ユーザ190の鼻と口とを含む。
FIG. 15 is a diagram illustrating control for detecting a mouth from a user's
The
フェイストラッキングモジュール228は、顔情報244に格納される口テンプレート
245を利用したパターンマッチングにより、顔画像1500から口領域1510を特定
する。ある局面において、フェイストラッキングモジュール228は、顔画像1500に
おいて、矩形上の比較領域を設定し、この比較領域の大きさ、位置および角度をそれぞれ
変えながら、比較領域の画像と、口テンプレート245の画像との類似度を算出する。フ
ェイストラッキングモジュール228は、予め定められたしきい値よりも大きい類似度が
算出された比較領域を、口領域1510として特定し得る。
The
フェイストラッキングモジュール228はさらに、算出した類似度がしきい値よりも大
きい比較領域の位置と、他の顔器官(例えば、目、鼻)の位置との相対関係に基づいて、
当該比較領域が口領域に相当するか否かを判断し得る。
The
It can be determined whether or not the comparison region corresponds to the mouth region.
フェイストラッキングモジュール228は、特定した口領域1510に基づいて、より
詳細な口の形状を検出する。
The
図16は、フェイストラッキングモジュール228が口の形状を検出する処理を説明す
る図(その1)である。図16を参照して、フェイストラッキングモジュール228は、
口領域1510に含まれる口の形状(唇の輪郭)を検出するための複数の輪郭検出線16
00を設定する。各輪郭検出線1600は、顔の高さ方向に直交する方向に、予め定めら
れた間隔で設定される。
FIG. 16 is a diagram (No. 1) illustrating a process by which the
A plurality of contour detection lines 16 for detecting the shape of the mouth (contour of the lips) included in the
Set 00. Each
フェイストラッキングモジュール228は、複数の輪郭検出線1600の各々に沿った
口領域1510の輝度値の変化を検出し、輝度値の変化が急激な位置を輪郭点として特定
し得る。より具体的には、フェイストラッキングモジュール228は、隣接画素との輝度
差(すなわち、輝度値変化)が予め定められたしきい値以上である画素を、輪郭点として
特定し得る。画素の輝度値は、たとえば、画素のRBG値を所定の重み付けで積算するこ
とにより得られる。
The
フェイストラッキングモジュール228は、口領域1510に対応する画像から2種類
の輪郭点を特定する。フェイストラッキングモジュール228は、口(唇)の外側の輪郭
に対応する輪郭点1610と、口(唇)の内側の輪郭に対応する輪郭点1620とを特定
する。ある局面において、フェイストラッキングモジュール228は、1つの輪郭検出線
1600上に3つ以上の輪郭点が検出された場合には、両端の輪郭点を外側の輪郭点16
10として特定し得る。この場合、フェイストラッキングモジュール228は、外側の輪
郭点1610以外の輪郭点を、内側の輪郭点1620として特定し得る。また、フェイス
トラッキングモジュール228は、1つの輪郭検出線1600上に二つ以下の輪郭点が検
出された場合には、検出された輪郭点を外側の輪郭点1610として特定し得る。
The
Can be specified as 10. In this case, the
図17は、フェイストラッキングモジュール228が口の形状を検出する処理を説明す
るための図(その2)である。図17では、外側の輪郭点1610は白丸、内側の輪郭点
1620はハッチングされた丸としてそれぞれ示されている。
FIG. 17 is a diagram (No. 2) for explaining a process in which the
フェイストラッキングモジュール228は、内側の輪郭点1620間を補完することに
より、口形状1700を特定する。この場合、輪郭点1620は、口の特徴点と言える。
ある局面において、フェイストラッキングモジュール228は、スプライン補完などの非
線形の補完方法を用いて、口形状1700を特定し得る。なお、他の局面において、フェ
イストラッキングモジュール228は、外側の輪郭点1610間を補完することにより口
形状1700を特定してもよい。さらに他の局面において、フェイストラッキングモジュ
ール228は、想定される口形状(人の上唇と下唇とによって形成され得る所定の形状)
から、大きく逸脱する輪郭点を除外し、残った輪郭点によって口形状1700を特定して
もよい。このようにして、フェイストラッキングモジュール228は、ユーザの口の動作
(形状)を特定し得る。なお、口形状1700の検出方法は上記に限られず、フェイスト
ラッキングモジュール228は、他の手法により口形状1700を検出してもよい。また
、フェイストラッキングモジュール228は、同様にして、ユーザの目および眉の動作を
検出し得る。なお、フェイストラッキングモジュール228は、頬、鼻などの器官の形状
を検出可能に構成されてもよい。
The
In certain aspects, the
Therefore, the contour points that deviate significantly may be excluded, and the
図18は、フェイストラッキングデータの構造の一例を表す。フェイストラッキングデ
ータは、各器官の形状を構成する複数の特徴点のuvw視野座標系における位置座標を表
す。たとえば、図18に示されるポイントm1、m2・・は、口形状1700を構成する
内側の輪郭点1620に対応する。ある局面において、フェイストラッキングデータは、
第1カメラ116または第2カメラ117の位置を基準(原点)としたuvw視野座標系
における座標値である。他の局面において、フェイストラッキングデータは、各器官ごと
に予め定められた特徴点を基準(原点)とした座標系における座標値である。一例として
、ポイントm1、m2・・・は、内側の輪郭点1620のうち口角に対応するいずれか一
方の特徴点を原点とした座標系における座標値である。
FIG. 18 shows an example of the structure of face tracking data. The face tracking data represents the position coordinates of a plurality of feature points constituting the shape of each organ in the uvw visual field coordinate system. For example, the points m1, m2, ... Shown in FIG. 18 correspond to the
It is a coordinate value in the uvw field of view coordinate system with the position of the
[サーバ150の構成]
図19は、サーバ150のハードウェア構成と機能構成とを表すブロック図である。あ
る実施形態において、サーバ150は、主たるハードウェアとして通信インターフェース
1910と、プロセッサ1920と、ストレージ1930とを備える。
[Configuration of server 150]
FIG. 19 is a block diagram showing a hardware configuration and a functional configuration of the
通信インターフェース1910は、コンピュータ200など外部の通信機器と信号を送
受信するための変復調処理などを行なう無線通信用の通信モジュールとして機能する。通
信インターフェース1910は、チューナ、高周波回路等により実現される。
The
プロセッサ1920は、サーバ150の動作を制御する。プロセッサ1920は、スト
レージ1930に格納される各種の制御プログラムを実行することにより、送受信部19
21、サーバ処理部1922、検索エンジン1923、物体特定部1924、感情判断部
1925、学習部1926として機能する。
The
It functions as 21, a
送受信部1921は、各コンピュータ200との間で各種情報を送受信する。たとえば
、送受信部1921は、仮想空間2にオブジェクトを配置する要求、オブジェクトを仮想
空間2から削除する要求、オブジェクトを移動させる要求、ユーザの音声などを各コンピ
ュータ200に送信する。
The transmission /
サーバ処理部1922は、コンピュータ200から受信した情報に基づいて、後述され
るユーザDB1933および学習用DB1935を更新する。検索エンジン1923は、
コンピュータ200から受信した検索キーに基づいて、パノラマ画像DB1934に含ま
れる複数のパノラマ画像の中から一以上のパノラマ画像を検索する。
The
Based on the search key received from the
物体特定部1924は、後述する学習モデル1936を利用して、コンピュータ200
から入力された線図データに対応する物体の候補を特定する。感情判断部1925は、後
述する学習モデル1937を利用して、コンピュータ200から受信したフェイストラッ
キングデータに対応するユーザ190の感情の候補を判断する。学習部1926は、後述
する学習モデル1936、1937を更新する。
The
Identify the candidate objects corresponding to the diagram data input from. The
ストレージ1930は、仮想空間指定情報1931と、オブジェクト指定情報1932
と、ユーザDB1933と、パノラマ画像DB1934と、学習用DB1935と、学習
モデル1936、1937とを保持する。
The
, The
仮想空間指定情報1931は、コンピュータ200の仮想空間定義モジュール231が
仮想空間2を定義するために用いられる情報である。たとえば、仮想空間指定情報193
1は、仮想空間2の大きさまたは形状を指定する情報を含む。オブジェクト指定情報19
32は、コンピュータ200の仮想オブジェクト生成モジュール232が仮想空間2に配
置(生成)するオブジェクトを指定する。
The virtual
1 contains information that specifies the size or shape of the
32 specifies an object to be arranged (generated) in the
ユーザDB1933は、ネットワーク19に接続される複数のコンピュータ200の各
々のユーザ190を識別するための情報(以下、「ユーザID」とも言う)と、ユーザの
属性情報とを含む。属性情報は、たとえば、年齢、場所(住所など)、性別、趣味などを
含む。パノラマ画像DB1934は、パノラマ画像IDと、パノラマ画像(動画像を含む
)とを関連付けて保持する。
The
学習用DB1935は、検索キーと、当該検索キーにより検索された一以上のパノラマ
画像のうちユーザ190に選択されたパノラマ画像とを互いに関連付けて保持する。ある
局面において、学習用DB1935は、これらの情報にさらにユーザIDを関連付けて保
持してもよい。パノラマ画像DB1934および学習用DB1935のデータ構造は後述
される。
The learning
学習モデル1936は、コンピュータ200から入力された線図データに対応する物体
を特定するためのプログラムを保持する。学習モデル1937は、コンピュータ200か
ら入力されたフェイストラッキングデータに対応するユーザ190の感情を判断するため
のプログラムを保持する。一例として、学習モデル1936,1937は、入力層、複数
の中間層、および出力層を含むニューラルネットワークである。学習部1926は、学習
用DB1935に保持される学習用データに基づいて、学習モデル1936、1937の
各ノード間の重み係数を更新する。学習部1926は、一例として、誤差逆伝播法に従い
重み係数を更新する。
The learning model 1936 holds a program for identifying an object corresponding to the diagram data input from the
(パノラマ画像DB1934)
図20は、パノラマ画像DB1934のデータ構造の一例を表す。パノラマ画像DB1
934は、パノラマ画像IDと、画像データと、タイトルと、タグとを互いに関連付けて
保持する。
(Panorama image DB1934)
FIG. 20 shows an example of the data structure of the
The 934 holds the panoramic image ID, the image data, the title, and the tag in association with each other.
画像データは、動画像データを含み得る。画像データは、たとえば、コンピュータ20
0のユーザ、またはサーバ150の管理者によりサーバ150に投稿(登録)される。タ
イトルは、画像データの投稿者によって設定される。タグは、画像データの投稿者、また
はパノラマ画像の視聴者によって設定される。タグは、パノラマ画像のジャンル、パノラ
マ画像に含まれる物体などを特定する。タグはさらに、感情タグを含み得る。感情タグは
、ユーザ190がパノラマ画像を視聴することにより得られると推定される感情を表す。
一例として、コメディ動画像のパノラマ画像には、「楽しい」、「リラックス」、「満足
」などの感情タグが設定される。
The image data may include moving image data. The image data is, for example, the
It is posted (registered) to the
As an example, emotion tags such as "fun", "relaxation", and "satisfaction" are set in the panoramic image of the comedy moving image.
(学習用DB1935)
図21は、学習用DB1935のデータ構造の一例を表す。学習用DB1935は、テ
ーブル2110,2120,2130を含む。テーブル2110は、線図データとしての
検索キーと、線図により表される物体と、当該検索キーにより検索された一以上のパノラ
マ画像のうちユーザ190に選択されたパノラマ画像のパノラマ画像IDとを互いに関連
付けて保持する。テーブル2120は、フェイストラッキングデータとしての検索キーと
、フェイストラッキングデータにより表される感情と、当該検索キーにより検索された一
以上のパノラマ画像のうちユーザ190に選択されたパノラマ画像のパノラマ画像IDと
を互いに関連付けて保持する。テーブル2130は、音声信号から抽出された文字列とし
ての検索キーと、当該検索キーにより検索された一以上のパノラマ画像のうちユーザ19
0に選択されたパノラマ画像のパノラマ画像IDとを互いに関連付けて保持する。
(DB1935 for learning)
FIG. 21 shows an example of the data structure of the learning
The panoramic image ID of the panoramic image selected as 0 is associated with each other and held.
以下、検索キーとして、ユーザ190が仮想空間2で描いた線図を表す線図データ、ユ
ーザ190の表情を表すフェイストラッキングデータ、ユーザ190の発話に基づく音声
信号から抽出された文字列、を用いる実施形態について説明する。
Hereinafter, as the search key, line diagram data representing a line diagram drawn by the
[線図データを検索キーとして用いる]
図22は、ユーザ190が仮想空間2において線図を描いている様子を表す視界画像2
200である。視界画像2200は、机オブジェクト2210を含む。机オブジェクト2
210の上には、コンピュータ200がユーザ190から線図の入力を受け付けるための
入力オブジェクト2220が配置されている。入力オブジェクト2220の形状は、平ら
な面を有する略直方体である。
[Use diagram data as search key]
FIG. 22 is a field of
It is 200. The field of
An
ある局面において、机オブジェクト2210の上にペンオブジェクト2230が配置さ
れている。また、入力オブジェクト2220の近傍に、入力オブジェクト2220への線
図の入力を促すメッセージオブジェクト2240が配置されている。
In one aspect, the
図22に示される例において、ハンドオブジェクト810とペンオブジェクト2230
とが関連付けられている。たとえば、コンピュータ200のプロセッサ10は、ハンドオ
ブジェクト810とペンオブジェクト2230とが接触したことを検出して、これらのオ
ブジェクトを互いに関連付ける。
In the example shown in FIG. 22, the
Is associated with. For example, the
ユーザ190は、これらのオブジェクトが関連付けられた状態でコントローラ160を
動かす。プロセッサ10はハンドトラッキングモジュール227として、コントローラ1
60の動きをハンドオブジェクト810に反映する。これにより、ペンオブジェクト22
30がハンドオブジェクト810に連動して動く。
The movement of 60 is reflected in the
30 moves in conjunction with the
ユーザ190は、ペンオブジェクト2230を用いて入力オブジェクト2220に線図
を入力する。より具体的には、プロセッサ10は、ペンオブジェクト2230と入力オブ
ジェクト2220との接点の軌跡を表す軌跡オブジェクト2250を入力オブジェクト2
220上に配置する。これにより、ユーザ190は、自身が描いた線図(に対応する軌跡
オブジェクト2250)を認識できる。ある実施形態において、プロセッサ10は、コン
トローラ160の予め定められたボタンが押下されている間のみ、ペンオブジェクト22
30と入力オブジェクト2220との接点の軌跡をトラッキングするように構成されても
よい。
The
Place on 220. As a result, the
It may be configured to track the trajectory of contact between 30 and the
コンピュータ200は、軌跡オブジェクト2250のデータ(ユーザ190が描いた線
図を表す線図データ)を検索キーとして、サーバ150に送信する。
The
サーバ150のプロセッサ1920は、物体特定部1924として、コンピュータ20
0から入力された線図データが表す物体の候補を特定する。より具体的には、物体特定部
1924は、学習モデル1936の各入力層に線図データを入力し、各出力層から出力さ
れた値に基づいて、線図データが表す物体の候補を特定する。一例として、物体特定部1
924は、予め定められた閾値を超える値を出力した出力層に対応する物体を、線図デー
タが表す物体の候補として特定する。物体特定部1924は、特定された物体の候補を表
す情報(例えば文字列)を検索エンジン1923に出力する。
The
The candidate of the object represented by the diagram data input from 0 is specified. More specifically, the
924 specifies an object corresponding to an output layer that outputs a value exceeding a predetermined threshold value as a candidate for an object represented by the diagram data. The
検索エンジン1923は、物体特定部1924から入力された情報に基づいて、パノラ
マ画像DB1934に格納される複数のパノラマ画像の中から一以上のパノラマ画像を検
索する。たとえば、検索エンジン1923は、物体特定部1924から「ねこ」、「いぬ
」の文字列の入力を受け付ける。検索エンジン1923は、入力された文字列を用いて、
パノラマ画像DB1934の中から、タイトルまたはタグに「ねこ」または「いぬ」の文
字列を含むパノラマ画像を検索する。プロセッサ1920は、検索されたパノラマ画像の
画像データからサムネイルを生成する。プロセッサ1920は、生成したサムネイルと、
当該サムネイルに対応するパノラマ画像IDとをコンピュータ200に送信する。
The
A panoramic image containing the character string "cat" or "dog" in the title or tag is searched from the
The panoramic image ID corresponding to the thumbnail is transmitted to the
図23は、ユーザ190がパノラマ画像を選択する様子を表す視界画像2300である
。視界画像2300は、ユーザ190により入力された検索キーを表すスクリーン231
0と、サーバ150から受信したサムネイル2320〜2350とを含む。
FIG. 23 is a field of
0 and
ユーザ190は、サムネイル2320〜2350のうち一のサムネイル(パノラマ画像
)をハンドオブジェクト810で選択する。コンピュータ200は、選択されたサムネイ
ルに対応するパノラマ画像IDをサーバ150に送信する。サーバ150は、受信したパ
ノラマ画像IDに対応する画像データをコンピュータ200に送信する。コンピュータ2
00は、受信した画像データを仮想空間2に展開する。これにより、ユーザ190は、所
望のパノラマ画像を視聴できる。なお、パノラマ画像が動画像である場合、コンピュータ
200は、当該パノラマ画像を予めダウンロードしてから仮想空間2に展開してもよいし
、当該パノラマ画像をストリーミング再生してもよい。
The
00 expands the received image data into the
サーバ150のプロセッサ1920は、コンピュータ200から受信したパノラマ画像
IDに関連付けられたタグに基づいて、検索キーにより表される物体を特定する。プロセ
ッサ1920は、検索キー(線図データ)と、検索キーにより表される物体と、パノラマ
画像IDとを検索用DB1935のテーブル2110に格納する。ある局面において、プ
ロセッサ1920は、学習部1926として、線図データと当該線図データにより表され
る物体とに基づいて、学習モデル1936の学習(教師あり学習)を実行する。
The
上記によれば、サーバ150は、ユーザ190の描いた線図に基づいて、ユーザ190
が所望するパノラマ画像の候補をユーザ190に提供できる可能性を高め得る。また、図
23の視界画像2300に示されるように、ユーザ190は、自分で入力した検索キー(
線図)と、検索キーにより検索されたパノラマ画像(のサムネイル)とを一緒に提示され
るため、自身が思い浮かべていた検索キー(線図ではなく文字列)に対応するパノラマ動
画を正確に選択し得る。その結果、サーバ150は、質の高い学習用データを取得でき、
学習効率を高め得る。
According to the above, the
Can increase the possibility that the
Since the panoramic image (thumbnail) searched by the search key is presented together, the panoramic video corresponding to the search key (character string instead of the line diagram) that you have in mind is accurately selected. Can be done. As a result, the
Learning efficiency can be improved.
ある局面において、視界画像2300は、検索キーに対応する物体が何であるかをユー
ザ190に問い合わせるための質問オブジェクト2360を含む。たとえば、質問オブジ
ェクト2360は、検索キーに対応する物体が、最も大きな値を出力した出力層に対応す
る物体(つまり、ユーザが意図している物体である確率が最も高い物体)であるか否かを
問い合わせる。質問オブジェクト2360は、当該問い合わせに対する回答の入力を受け
付けるための回答オブジェクト2370,2380を含む。ユーザ190は、ハンドオブ
ジェクト810で回答オブジェクト2370,2380のいずれか一方を選択する。コン
ピュータ200は、当該問い合わせに対するユーザ190の回答結果をサーバ150に送
信する。サーバ150のプロセッサ1920は、受信した回答結果と線図データとに基づ
いて学習モデル1936を学習してもよい。
In one aspect, the field of
(線図に基づくパノラマ画像の変更処理の制御構造)
図24は、線図に基づいてパノラマ画像を変更するための処理を表すフローチャートで
ある。図24に示される処理は、コンピュータ200のプロセッサ10およびサーバ15
0のプロセッサ1920によって実現される。
(Control structure for panoramic image change processing based on diagram)
FIG. 24 is a flowchart showing a process for changing a panoramic image based on a diagram. The processing shown in FIG. 24 is the
It is realized by the
ステップS2405にて、プロセッサ10は、仮想空間定義モジュール231として、
仮想空間2にパノラマ画像を展開する。ステップS2410にて、プロセッサ10は、仮
想空間2に、入力オブジェクト、ペンオブジェクト、操作オブジェクトとして機能するハ
ンドオブジェクト、仮想カメラなどの各種オブジェクトを配置する。
In step S2405, the
A panoramic image is developed in the
ステップS2415にて、プロセッサ10は、操作オブジェクトとペンオブジェクトと
が接触したか否かを判断する。プロセッサ10は、これらのオブジェクトが接触したと判
断した場合(ステップS2415でYES)、これらのオブジェクトを関連付ける。また
、プロセッサ10は、これらのオブジェクトが接触したことを、パノラマ画像を変更する
ためのトリガとして受け付ける。そうでない場合(ステップS2415でNO)、プロセ
ッサ10は、トリガを受け付けるまで待機する。
In step S2415, the
ステップS2420にて、プロセッサ10は、入力オブジェクトに対する線図(例えば
、ペンオブジェクトと入力オブジェクトとの接点の軌跡)を検索キーとして受け付ける。
ステップS2425にて、プロセッサ10は、操作オブジェクトとペンオブジェクトとの
関連付けが解除されたか否かを判断する。たとえば、ユーザ190は、コントローラ16
0に設けられた予め定められたボタンを押下することにより、上記関連付けを解除する。
プロセッサ10は、操作オブジェクトとペンオブジェクトとの関連付けが解除されたと判
断した場合(ステップS2425でYES)、ステップS2420で入力された線図デー
タをサーバ150に送信する(ステップS2430)。そうでない場合(ステップS24
25でNO)、プロセッサ10は、ステップS2420の処理を再び実行する。
In step S2420, the
In step S2425, the
By pressing a predetermined button provided at 0, the above association is released.
When the
No at 25), the
ステップS2435にて、プロセッサ1920は、コンピュータ200から線図データ
(検索キー)を受信する。ステップS2440にて、プロセッサ1920は、線図データ
に基づいて物体(例えば、物体を表す文字列)を特定する。ステップS2445にて、プ
ロセッサ1920は、特定した物体を表す文字列に基づいて、パノラマ画像DB1934
に格納される複数のパノラマ画像の中から一以上のパノラマ画像を検索する。ステップS
2450にて、プロセッサ1920は、検索した一以上のパノラマ画像の各々についてサ
ムネイルを生成し、サムネイルとパノラマ画像IDとをコンピュータ200に送信する。
In step S2435, the
Search for one or more panoramic images from multiple panoramic images stored in. Step S
At 2450, the
ステップS2455にて、プロセッサ10は、サーバ150からサムネイルとパノラマ
画像IDとを受信する。ステップS2460にて、プロセッサ10は、検索されたパノラ
マ画像を特定するための情報として機能するサムネイルを仮想空間2に提示する。ステッ
プS2465にて、プロセッサ10は、ユーザ190から、一以上のパノラマ画像(サム
ネイル)の中から一のパノラマ画像(サムネイル)の選択を受け付ける。ステップS24
70にて、プロセッサ10は、選択されたサムネイルに対応するパノラマ画像IDをサー
バ150に送信する。
In step S2455, the
At 70, the
ステップS2475にて、プロセッサ1920は、パノラマ画像IDをコンピュータ2
00から受信する。ステップS2480にて、プロセッサ1920は、パノラマ画像DB
1934を参照して、受信したパノラマ画像IDに対応する画像データをコンピュータ2
00に送信する。
In step S2475, the
Receive from 00. In step S2480, the
With reference to 1934, the image data corresponding to the received panoramic image ID is input to the
Send to 00.
ステップS2485にて、プロセッサ10は、仮想空間定義モジュール231として、
受信した画像データを仮想空間2を構成する天球に展開する。これにより、ユーザ190
は、自身の所望するパノラマ画像を視認できる。
In step S2485, the
The received image data is expanded into the celestial sphere that constitutes the
Can visually recognize the panoramic image desired by itself.
ステップS2490にて、プロセッサ1920は、学習部1926として、検索キーと
して入力された線図データと、当該線図データにより表される物体とに基づいて、学習モ
デル1936を学習(更新)する。
In step S2490, the
(立体的な線図に基づく検索)
上記の例では、コンピュータ200は、平坦な入力オブジェクトに対してユーザが描く
平面的な線図の入力を受け付けるように構成されている。他の局面において、コンピュー
タ200は、ユーザが描く立体的な線図を検索キーとして受け付けるように構成されても
よい。
(Search based on a three-dimensional diagram)
In the above example, the
図25は、立体的な線図の入力を受け付ける様子を表す視界画像2500である。視界
画像2500は、入力オブジェクト2510を含む。図25に示される例において、入力
オブジェクト2510は、立方体であって、立方体を構成する各辺が破線で表示されてい
る。
FIG. 25 is a field of
ユーザ190は、ペンオブジェクト2230が関連付けられたハンドオブジェクト81
0を操作して、入力オブジェクト2510に囲まれる領域に立体的な線図を描くことがで
きる。図25に示される例において、飛行機2520が描かれている。
By manipulating 0, a three-dimensional diagram can be drawn in the area surrounded by the
コンピュータ200は、飛行機2520(3次元の線図)を2次元化する。より具体的
には、入力オブジェクト2510を構成する立方体の各平面に飛行機2520を転写する
。入力オブジェクト2510は、仮想空間2に設定されている各軸に平行に配置されてい
るとする。係る場合、コンピュータ200は、図26に示されるように、飛行機2520
を、XY平面、YZ平面、およびZX平面にそれぞれ転写する。図26(A)は、飛行機
2520をXY平面に転写した線図である。図26(B)は、飛行機2520をYZ平面
に転写した線図である。図26(C)は、飛行機2520をZX平面に転写した線図であ
る。
The
Is transferred to the XY plane, the YZ plane, and the ZX plane, respectively. FIG. 26 (A) is a diagram in which the
コンピュータ200は、得られた2次元の線図データを検索キーとしてサーバ150に
送信する。その後の処理は上述の通りであるので、当該処理の説明は、繰り返さない。
The
上記によれば、ユーザ190は、仮想空間2上に描いた立体的な線図を検索キーとして
コンピュータ200およびサーバ150に入力できる。ある局面において、ユーザ190
は、仮想空間2を介して他のユーザと通信する場合がある。係る場合、ユーザ190は、
ユーザ190が意図する物体を、サーバ150が入力された線図に基づいて正しく認識で
きているのか否かを、他のユーザとともにゲーム感覚で楽しむことができる。
According to the above, the
May communicate with other users via the
Whether or not the
[フェイストラッキングデータを検索キーとして用いる]
次に、フェイストラッキングデータ、つまり、ユーザ190の表情を検索キーとして用
いる場合の実施形態について説明する。
[Use face tracking data as a search key]
Next, an embodiment in the case where the face tracking data, that is, the facial expression of the
図27は、フェイストラッキングデータに基づいてパノラマ画像を変更するための処理
を表すフローチャートである。なお、図27に示される処理のうち図24の処理と同じ処
理については同じ符号を付している。そのため、その処理についての説明は繰り返さない
。
FIG. 27 is a flowchart showing a process for changing a panoramic image based on face tracking data. Of the processes shown in FIG. 27, the same processes as those in FIG. 24 are designated by the same reference numerals. Therefore, the description of the process will not be repeated.
ステップS2710にて、コンピュータ200のプロセッサ10は、仮想空間2に展開
されているパノラマ画像を変更するためのトリガを受け付けたか否かを判断する。たとえ
ば、プロセッサ10は、コントローラ160に設けられた予め定められたボタンが押下さ
れたことに応じて、上記トリガを受け付ける。
In step S2710, the
ステップS2720にて、プロセッサ10は、フェイストラッキングデータを取得する
。このとき、プロセッサ10は、ユーザ190に今の感情(気分)、またはパノラマ画像
を視聴することにより得たい感情を問い合わせてもよい。ユーザ190は、当該問い合わ
せに応じて表情を作る。第1カメラ116および第2カメラ117は、そのときのユーザ
190の顔の画像を生成する。プロセッサ10はフェイストラッキングモジュール228
として、入力された顔の画像に基づいてフェイストラッキングデータを生成する。ステッ
プS2730にて、プロセッサ10は、生成されたフェイストラッキングデータを検索キ
ーとしてサーバ150に送信する。
In step S2720, the
To generate face tracking data based on the input face image. In step S2730, the
ステップS2740にて、サーバ150のプロセッサ1920は、コンピュータ200
からフェイストラッキングデータの入力を受け付ける。ステップS2750にて、プロセ
ッサ1920は、感情判断部1925として、入力されたフェイストラッキングデータが
表すユーザ190の感情の候補を特定する。より具体的には、感情判断部1925は、学
習モデル1937の各入力層にフェイストラッキングデータを入力し、各出力層から出力
された値に基づいて、フェイストラッキングデータが表す感情の候補を特定する。一例と
して、感情判断部1925は、予め定められた閾値を超える値を出力した出力層に対応す
る感情を、フェイストラッキングデータが表す感情の候補として特定する。ステップS2
760にて、プロセッサ1920は、パノラマ画像DB1934に格納されている複数の
パノラマ画像の中から、特定された感情の感情タグを含む一以上のパノラマ画像を検索す
る。
In step S2740, the
Accepts face tracking data input from. In step S2750, the
At 760, the
ステップS2790にて、プロセッサ1920は、学習部1926として、検索キーと
して入力されたフェイストラッキングデータと、当該フェイストラッキングデータにより
表される感情とに基づいて、学習モデル1937を学習(更新)する。
In step S2790, the
上記によれば、ユーザ190は、表情を作る(たとえば、笑う)だけで、自身の気分(
感情)に合わせたパノラマ画像の候補を受けることができる。また、サーバ150は、ユ
ーザ190の表情(を表すフェイストラッキングデータ)に基づいて、ユーザ190が所
望するパノラマ画像の候補をユーザ190に提供できる可能性を高め得る。
According to the above, the
You can receive candidates for panoramic images that match your emotions. Further, the
なお、上記の例では、サーバ150は、フェイストラッキングデータに基づいてユーザ
190の感情を推定するように構成されているが、他の局面において他のデータに基づい
てユーザ190の感情を推定するように構成されてもよい。たとえば、サーバ150は、
ユーザ190の発話に基づく音声信号をコンピュータ200から受け付け、当該音声信号
に基づいてユーザ190の感情を推定してもよい。たとえば、サーバ150は、音声信号
から文字列を抽出して、当該文字列から感情を推定する。このような処理は、たとえば、
メタデータ社が提供する「感情解析API」により実現され得る。他の局面において、サ
ーバ150は、音声信号の波形から感情を推定する。このような処理は、たとえば、AG
I社が提供する「ST Emotion SDK」により実現され得る。なお、これらの処
理は、サーバ150ではなくコンピュータ200が実行するように構成されてもよい。係
る場合、コンピュータ200は、推定した感情を特定する情報をサーバ150に送信する
。
In the above example, the
An audio signal based on the utterance of the
It can be realized by the "emotion analysis API" provided by Metadata. In another aspect, the
It can be realized by "ST Emotion SDK" provided by Company I. Note that these processes may be configured to be executed by the
[音声信号から抽出される文字列を検索キーとして用いる]
次に、ユーザ190の発話に対応する音声信号から抽出される文字列を検索キーとして
用いる場合の実施形態について説明する。
[Use the character string extracted from the audio signal as the search key]
Next, an embodiment in the case where a character string extracted from the voice signal corresponding to the utterance of the
図28は、ユーザ190が発話により検索キーを入力する様子を表す視界画像2800
である。視界画像2800は、机オブジェクト2210を含む。机オブジェクト2210
の上には、スピーカオブジェクト2810が配置されている。また、スピーカオブジェク
ト2810に重畳するようにポインタオブジェクト2820が配置されている。
FIG. 28 is a field of
Is. The field of
A
ポインタオブジェクト2820は、ユーザ190の仮想空間2における視点を表す。プ
ロセッサ10は視線検出モジュール226として、注視センサ140の出力に基づいて現
実空間におけるユーザ190の視線を検出する。視線検出モジュール226は、現実空間
におけるユーザ190の視線を、仮想カメラ1の位置および傾き(基準視線)に基づいて
、仮想空間2における視線に変換する。仮想オブジェクト生成モジュール232は、仮想
空間2における視線と、オブジェクトとが衝突する位置にポインタオブジェクト2820
を配置する。
The
To place.
ある局面において、ユーザ190は、スピーカオブジェクト2810を選択することで
、仮想空間2に展開されているパノラマ画像を変更するためのトリガをコンピュータ20
0に入力する。一例として、ユーザ190は、ハンドオブジェクト810と、スピーカオ
ブジェクト2810とを接触させることで、スピーカオブジェクト2810を選択する。
他の例として、ユーザ190は、スピーカオブジェクト2810を予め定められた時間に
わたり注視する、つまり、ポインタオブジェクト2820を予め定められた時間にわたり
スピーカオブジェクト2810に重畳することにより、スピーカオブジェクト2810を
選択する。
In one aspect, the
Enter 0. As an example, the
As another example, the
コンピュータ200のプロセッサ10は、ユーザ190に対してトリガが入力されたこ
とを通知する。たとえば、プロセッサ10は、「検索したい内容を話してください」等の
、ユーザ190の発話を促す音声またはメッセージを出力する。これに従い、ユーザ19
0は、検索したい内容を発話する。プロセッサ10は、マイク119から音声信号を受け
付け、当該音声信号から文字列を抽出する。一例として、プロセッサ10は、音声信号の
先頭から所定時間単位(たとえば、10msec単位)で区切られる波形データと、スト
レージ12に格納される音響モデル(図示しない)とを照合して、文字列を抽出する。音
響モデルは、母音や子音などの音素ごとの特徴量を表す。一例として、プロセッサ10は
、隠れマルコフモデルに基づき、音声信号と音響モデルとを照合する。プロセッサ10は
、抽出した文字列をサーバ150に送信する。
The
0 speaks the content to be searched. The
サーバ150のプロセッサ1920は、パノラマ画像DB1934に格納されている複
数のパノラマ画像の中から、タイトルまたはタグに入力された文字列(または当該文字列
に含まれる単語)を含むパノラマ画像を検索する。その後の処理は上述の処理と同じであ
るので繰り返さない。
The
上記によれば、ユーザ190は、単に発話するだけで検索キーをコンピュータ200に
入力できる。また、現実世界においてスピーカ機能を有するデバイス(たとえば、アマゾ
ンエコー(登録商標))とユーザとの間での音声コミュニケーションが一般的になってい
る。そのため、ユーザ190は、スピーカの形状を有するスピーカオブジェクトが音声入
力および出力機能を有すると容易に想像し得る。なお、他の局面において、スピーカオブ
ジェクトに替えて、マイクの形状を有するマイクオブジェクトが配置されていてもよい。
According to the above, the
(制御構造)
図29は、音声信号から抽出される文字列に基づいてパノラマ画像を切り替えるための
処理を表すフローチャートである。なお、図29に示される処理のうち図24の処理と同
じ処理については同じ符号を付している。そのため、その処理についての説明は繰り返さ
ない。
(Control structure)
FIG. 29 is a flowchart showing a process for switching a panoramic image based on a character string extracted from an audio signal. Of the processes shown in FIG. 29, the same processes as those in FIG. 24 are designated by the same reference numerals. Therefore, the description of the process will not be repeated.
ステップS2910にて、コンピュータ200のプロセッサ10は、仮想空間2に展開
されているパノラマ画像を変更するためのトリガを受け付けたか否かを判断する。たとえ
ば、プロセッサ10は、スピーカオブジェクトがユーザ190に選択された場合に、上記
トリガを受け付けて、ステップS2920の処理を実行する。そうでない場合(ステップ
S2910でNO)、プロセッサ10は、トリガを受け付けるまで待機する。
In step S2910, the
ステップS2920にて、プロセッサ10は、マイク119からユーザ190の発話に
対応する音声信号の入力を受け付ける。ステップS2930にて、プロセッサ10は、音
声信号から文字列を抽出し、抽出された文字列を検索キーとしてサーバ150に送信する
。なお、他の局面において、プロセッサ10は音声信号をサーバ150に送信し、サーバ
150が音声信号から文字列を抽出するように構成されてもよい。
In step S2920, the
ステップS2940にて、サーバ150のプロセッサ1920は、検索キーとしての文
字列をコンピュータ200から受信する。
In step S2940, the
上記によれば、ユーザ190は、発話するだけで、自身の所望するパノラマ画像の候補
を受けることができる。
According to the above, the
(他のユーザと連携してパノラマ画像を検索)
上述のように、ユーザ190は、ネットワーク19を介して仮想空間2上で他のユーザ
とコミュニケーションできる。このとき、ユーザ190と他のユーザは、同じパノラマ画
像を視聴している。ある局面において、ユーザ190は、他のユーザと相談しながらパノ
ラマ画像の変更を行ないたいと考え得る。その理由は、ユーザ190が勝手にパノラマ画
像22を変更することで、他のユーザが驚くことを抑制するためである。そこで、以下に
、複数のユーザの入力に基づいてパノラマ画像を変更する処理について説明する。
(Search panoramic images in collaboration with other users)
As described above, the
図30は、複数のユーザが仮想空間を共有している場合のネットワーク19を説明する
図である。図30に示される例において、ネットワーク19にコンピュータ200A、2
00Bが接続されている。コンピュータ200AはHMDシステム1400Aに含まれ、
コンピュータ200BはHMDシステム1400Bに含まれる。HMDシステム1400
AおよびHMDシステム1400Bの構成は、上述のHMDシステム1400と同じ構成
である。以下、HMDシステム1400Aのユーザをユーザ190A、HMDシステム1
400Bのユーザをユーザ190Bとする。また、HMDシステム1400Aに関する各
構成要素の参照符号にAが付され、HMDシステム1400Bに関する各構成要素の参照
符号にBが付される。
FIG. 30 is a diagram illustrating a
00B is connected. The
The
The configurations of A and the HMD system 1400B are the same as those of the above-mentioned
Let the user of 400B be the user 190B. Further, A is added to the reference code of each component related to the HMD system 1400A, and B is added to the reference code of each component related to the HMD system 1400B.
図30に示される例において、コンピュータ200Aによって提供される仮想空間2A
と、コンピュータ200Bによって提供される仮想空間2Bとは同じデータによって構成
されている。換言すれば、コンピュータ200Aとコンピュータ200Bとは同じ仮想空
間を共有していることになる。仮想空間2Aおよび仮想空間2Bには、ユーザ190Aに
対応するアバターオブジェクト3000Aと、ユーザ190Bに対応するアバターオブジ
ェクト3000Bとが存在する。なお、仮想空間2Aにおけるアバターオブジェクト30
00Aおよび仮想空間2Bにおけるアバターオブジェクト3000BがそれぞれHMDを
装着しているが、これは説明を分かりやすくするためのものであって、実際にはこれらの
オブジェクトはHMDを装着していない。
In the example shown in FIG. 30, the
And the
The
コンピュータ200Aは、アバターオブジェクト3000Aの目の位置に仮想カメラ1
Aを配置する。これにより、ユーザ190Aは、仮想空間2Aにおけるアバターオブジェ
クト3000Aの視界を共有する。コンピュータ200Bは、アバターオブジェクト30
00Bの目の位置に仮想カメラ1Bを配置する。これにより、ユーザ190Bは、仮想空
間2Bにおけるアバターオブジェクト3000Bの視界を共有する。仮想空間2Aおよび
仮想空間2Bにおいて、アバターオブジェクト3000Aとアバターオブジェクト300
0Bとは互いに向かい合っている。そのため、ユーザ190Aはユーザ190Bに対応す
るアバターオブジェクト3000Bを視認し、ユーザ190Bはユーザ190Aに対応す
るアバターオブジェクト3000Aを視認する。この状態において、ユーザ190Aとユ
ーザ190Bとはコミュニケーションを行なう。
The
Place A. As a result, the user 190A shares the field of view of the
The virtual camera 1B is placed at the eye position of 00B. As a result, the user 190B shares the field of view of the
They face each other with 0B. Therefore, the user 190A visually recognizes the
たとえば、コンピュータ200Bは、コントローラ160Bが動いたことを検出すると
、コントローラ160Bの動きを表すデータをサーバ150を介してコンピュータ200
Aに送信する。コンピュータ200Aは、受信したデータをアバターオブジェクト300
0Bの手に反映する。これにより、ユーザ190Aは、アバターオブジェクト3000B
を介してユーザ190Bの動きを認識できる。
For example, when the
Send to A. The
Reflect in the hand of 0B. As a result, the user 190A can use the
The movement of the user 190B can be recognized via.
図31は、ユーザ190Aが視認する視界画像3100を表す。視界画像3100は、
コンピュータ200Aに接続されているモニタ112Aに表示される。視界画像3100
は、机オブジェクト2210と、机オブジェクト2210の上に配置されるスピーカオブ
ジェクト2810と、アバターオブジェクト3000Bと、サムネイル群3110とを含
む。
FIG. 31 represents a field of
It is displayed on the
Includes a
ある局面において、ユーザ190Bはスピーカオブジェクト2810を選択した後に「
動物」と発話することで検索キーをコンピュータ200Bに入力する。サーバ150は、
コンピュータ200Bから入力された検索キーに基づいて検索された複数のパノラマ画像
に対応するサムネイル群3110を、検索キーの受信元のコンピュータ200Bと、コン
ピュータ200Bと仮想空間を共有するコンピュータ200Aとに対して送信する。
In one aspect, the user 190B selects the
Enter the search key into the
コンピュータ200Aは、受信したサムネイル群3110を仮想空間2Aに提示する。
これにより、ユーザ190Aは、ユーザ190Bがコンピュータ200Bに入力した検索
キーによって検索されたパノラマ画像を表すサムネイル群3110を視認する。
The
As a result, the user 190A visually recognizes the
ユーザ190Aは、これらサムネイル群3110が表す複数のパノラマ画像をさらに限
定するための検索キーをコンピュータ200Aに入力できる。たとえば、ユーザ190A
は、自身の注視点を表すポインタオブジェクト3120を予め定められた時間にわたりス
ピーカオブジェクト2810に重畳し、スピーカオブジェクト2810を選択する。その
後、ユーザ190Aは、「ねこ」と発話することで検索キーをコンピュータ200Aに入
力する。
The user 190A can input a search key for further limiting the plurality of panoramic images represented by the
Superimposes the
サーバ150は、コンピュータ200Aから他の検索キーの入力を受け付けると、動物
に関する複数のパノラマ画像のなかから、ねこに関する一以上のパノラマ画像を検索する
。サーバ150は、検索された一以上のパノラマ画像の各々のサムネイルを生成し、コン
ピュータ200Aおよび200Bに送信する。
When the
コンピュータ200Aは、サーバ150から新たに一以上のサムネイルを受信すると、
現在提示しているサムネイル群3110に替えて、新たに受信した一以上のサムネイルを
表示する。コンピュータ200Bもコンピュータ200Aと同様の動作を行なう。
When the
Instead of the currently presented
ユーザ190Aまたは190Bのいずれか一方が、仮想空間に提示されている一以上の
サムネイルの中から一のサムネイルを選択する。これにより、仮想空間2Aおよび2Bに
、選択されたサムネイルに対応するパノラマ画像が展開される。
Either user 190A or 190B selects one thumbnail from one or more thumbnails presented in the virtual space. As a result, panoramic images corresponding to the selected thumbnails are developed in the
上記によれば、仮想空間を共有するユーザ190Aおよび190Bは、コミュニケーシ
ョンを図りながら変更するパノラマ画像を決定できる。
According to the above, the users 190A and 190B sharing the virtual space can determine the panoramic image to be changed while communicating.
[構成]
以上に開示された技術的特徴は、以下のように要約され得る。
[Constitution]
The technical features disclosed above can be summarized as follows.
(構成1) HMD110によって仮想空間2を提供するためにコンピュータ200で
実行されるプログラムが提供される。このプログラムはコンピュータ200に、複数のパ
ノラマ画像に含まれる一のパノラマ画像を仮想空間2に展開するステップ(ステップS2
405)と、HMD110のユーザ190から、仮想空間2に展開されているパノラマ画
像を他のパノラマ画像に変更するためのトリガの入力を受け付けるステップ(ステップS
2415)と、トリガの入力を受け付けた後に、ユーザ190から検索キーの入力を受け
付けるステップ(ステップS2420)と、複数のパノラマ画像の中から、検索キーによ
り検索された一以上のパノラマ画像を特定するための情報を仮想空間2に提示するステッ
プ(ステップS2460)と、ユーザ190から、一以上のパノラマ画像の中から一のパ
ノラマ画像を選択する入力を受け付けるステップ(ステップS2465)と、選択された
一のパノラマ画像を仮想空間2に展開するステップ(ステップS2485)とを実行させ
る。
(Structure 1) The
405) and the step (step S) of receiving the input of the trigger for changing the panoramic image developed in the
2415), the step of accepting the input of the search key from the
上記の例において、サーバ150がパノラマ画像の検索を行なう処理について説明した
が、他の実施形態において、コンピュータ200が検索を行なってもよい。例えば、コン
ピュータ200は、ストレージ12に格納される複数のパノラマ画像の中から、検索キー
に基づいて一以上のパノラマ画像を検索してもよい。
In the above example, the process of searching the panoramic image by the
上記の例において、コンピュータ200は、パノラマ画像を特定するための情報として
、当該パノラマ画像から生成されるサムネイルを仮想空間2に提示する処理を説明したが
、他の例として、パノラマ画像に関連付けられるタイトル、タグを仮想空間2に提示して
もよい。
In the above example, the
上記によれば、コンピュータ200は、ユーザ190に入力された検索キーに関連する
一以上のパノラマ画像、換言すれば、ユーザ190が所望するパノラマ画像(を特定する
情報)をユーザ190に提示できる。
According to the above, the
(構成2) ある実施形態において、上記のプログラムはコンピュータ200に、入力
された検索キーと、選択された一のパノラマ画像のパノラマ画像IDとを、コンピュータ
200と通信可能なサーバ150に送信するステップ(ステップS2430、ステップS
2470)とを実行させる。
(Structure 2) In a certain embodiment, the above program transmits the input search key and the panoramic image ID of one selected panoramic image to the
2470) and is executed.
(構成3) 上記の検索キーは、ユーザ190が仮想空間2で描いた線図を含む。
上記によれば、ユーザ190は、例えば、興味のある物体の名称を知らない、または忘
れた場合であっても、当該物体の線図を仮想空間上で描くことによって、コンピュータ2
00に当該興味のある物体に関する検索キーを入力できる。
(Structure 3) The above search key includes a diagram drawn by the
According to the above, even if the
You can enter a search key for the object of interest in 00.
(構成4) ある実施形態において、プログラムはコンピュータ200に、ユーザ19
0の手の動きを検出するステップをさらに実行させる。上記のユーザ190から検索キー
の入力を受け付けるステップは、ユーザ190の手の動きに基づく線図を検索キーとして
受け付けることを含む。
(Structure 4) In one embodiment, the program is on the
Further execution of the step of detecting the movement of the hand of 0. The step of accepting the input of the search key from the
ある局面において、コンピュータ200は、コントローラ160の動きをユーザ190
の手の動きとして検出する。他の局面において、コンピュータ200は、図示しない赤外
線カメラによりユーザ190の手を撮影し、撮影結果に基づいてユーザ190の手の動き
を検出してもよい。このような技術は、例えば、Leap Motion社が提供するL
eap Motion(登録商標)によって実現され得る。上記によれば、ユーザ190
は、仮想空間2上で容易に線図を描くことができる。
In one aspect, the
Detected as the movement of the hand. In another aspect, the
It can be realized by eep Motion®. According to the above,
Can easily draw a diagram on the
(構成5) 上記の検索キーの入力を受け付けるステップは、仮想空間2に配置された
入力オブジェクトに対してユーザ190が描いた線図を検索キーとして受け付けることを
含む。
(Structure 5) The step of accepting the input of the search key includes accepting a diagram drawn by the
(構成6) 上記の検索キーをの入力受け付けるステップは、仮想空間2における予め
定められた空間内(例えば、入力オブジェクト2510により囲まれる空間)にユーザ1
90が形成した立体オブジェクト(例えば、飛行機2520)の入力を受け付けることと
、立体オブジェクトを2次元化して得られる線図を検索キーとして受け付けることとを含
む。
(Structure 6) The step of accepting the input of the above search key is performed by the
It includes accepting an input of a three-dimensional object (for example, an airplane 2520) formed by 90, and accepting a diagram obtained by making the three-dimensional object two-dimensional as a search key.
上記によれば、ユーザ190は、立体的な線図を検索キーとしてコンピュータ200に
入力できる。さらに、サーバ150またはコンピュータ200は、平面的な線図よりも情
報量の多い立体的な線図に基づいて検索を行なうことが出来るため、ユーザ190が所望
するパノラマ画像をユーザ190に提示できる可能性を高め得る。
According to the above, the
(構成7) ある実施形態に従うプログラムはコンピュータ200に、ユーザ190の
表情を表すフェイストラッキングデータを検出するステップ(ステップS2720)をさ
らに実行させる。検索キーは、ユーザ190のフェイストラッキングデータを含む。
(Structure 7) A program according to an embodiment causes the
ある局面において、コンピュータ200は、仮想空間2に仮想的なキーボードを配置し
、当該仮想的なキーボードに基づいてユーザ190から検索キーの入力を受け付けること
も考えられる。しかしながら、仮想的なキーボードは触感がないため現実空間におけるハ
ードウェアキーボードと使用感が異なる。そのため、ユーザ190は、仮想的なキーボー
ドに対してうまく検索キーを入力できない場合もある。これに対し、ユーザ190は、単
に表情を作るだけでコンピュータ200に検索キーを入力できる。
In a certain aspect, it is conceivable that the
(構成8) 上記の検索キーの入力を受け付けるステップは、ユーザ190の音声の入
力を受け付けることと、ユーザ190の音声から抽出された文字列を検索キーとして受け
付けることとを含む。
(Structure 8) The step of accepting the input of the search key includes accepting the input of the voice of the
上記によれば、ユーザ190は、単に発話するだけでコンピュータ200に検索キーを
入力できる。
According to the above, the
(構成9) ある実施形態に従うプログラムはコンピュータ200に、スピーカオブジ
ェクトまたはマイクオブジェクトを仮想空間2に配置するステップをさらに実行させる。
トリガの入力を受け付けるステップは、スピーカオブジェクトまたはマイクオブジェクト
に対するユーザ190の予め定められた動作をトリガとして受け付けることを含む。
(Structure 9) A program according to an embodiment causes the
The step of accepting the input of the trigger includes accepting a predetermined action of the
ある局面において、コンピュータ200は、ユーザ190の手の動きに連動するハンド
オブジェクトと、スピーカオブジェクトまたはマイクオブジェクトとが接触した場合に、
上記トリガの入力を受け付ける。他の局面において、コンピュータ200は、ユーザ19
0がスピーカオブジェクトまたはマイクオブジェクトを予め定められた時間にわたり見つ
めたことを検出した場合に、上記トリガの入力を受け付ける。
In a certain aspect, when the
Accepts the input of the above trigger. In another aspect, the
When it is detected that 0 has stared at the speaker object or the microphone object for a predetermined time, the input of the trigger is accepted.
(構成10) 上記の一以上のパノラマ画像を仮想空間2に提示するステップは、検索
キーまたは当該検索キーに基づく情報と、一以上のパノラマ画像とを仮想空間2に提示す
ることを含む。
(Structure 10) The step of presenting one or more panoramic images to the
上記によれば、ユーザ190は、自分で入力した検索キーと、検索キーにより検索され
たパノラマ画像(のサムネイル)とを一緒に提示されるため、一以上のパノラマ画像の中
から自分が意図したパノラマ動画を正確に選択し得る。その結果、サーバ150またはコ
ンピュータ200は、質の高い学習用データを取得でき、学習効率を高め得る。
According to the above, since the
検索キーに基づく情報は、検索キーに基づいて検索された複数の内容(物体、感情など
)のうちユーザ190が意図する可能性が最も高い内容が、検索キーに対応するか否かを
ユーザ190に問い合わせる情報であり得る。当該問い合わせに対するユーザ190の回
答を得ることで、サーバ150またはコンピュータ200は、質の高い学習用データを取
得でき、学習効率を高め得る。
The information based on the search key indicates whether or not the content most likely intended by the
(構成11) ある実施形態において、プログラムはコンピュータ200Aに、コンピ
ュータ200Bのユーザ190Bに対応するアバターオブジェクト3000Bを仮想空間
2に配置するステップと、複数のパノラマ画像の中から、コンピュータ200Bのユーザ
190がコンピュータ200Bに入力した検索キーにより検索された一以上のパノラマ画
像を仮想空間2に提示するステップとをさらに実行させる。
(Structure 11) In a certain embodiment, the program includes a step of arranging an
上記によれば、コンピュータ200Aのユーザ190Aは、仮想空間を共有するユーザ
190Bが入力した検索キーに対する検索結果を確認できる。これにより、コンピュータ
200Aは、ユーザ190Aが意図せずにパノラマ画像が変更された場合に、ユーザ19
0Aが驚くことを抑制し得る。
According to the above, the user 190A of the
0A can suppress surprises.
(構成12) 上記の検索キーの入力を受け付けるステップは、コンピュータ200B
のユーザ190Bによって入力された検索キーにより検索された一以上のパノラマ画像に
対する検索キーの入力を受け付けることを含む。
(Structure 12) The step of accepting the input of the above search key is the
Includes accepting the input of a search key for one or more panoramic images searched by the search key input by the user 190B of.
上記によれば、仮想空間を共有するユーザ190Aおよび190Bは、パノラマ画像を
変更する処理において、互いの合意形成を行ないながら、パノラマ画像を変更し得る。
According to the above, the users 190A and 190B sharing the virtual space can change the panoramic image while forming a consensus with each other in the process of changing the panoramic image.
(構成13) ある実施形態に従うと、上記のいずれかに記載のプログラムを格納した
ストレージ12と、当該プログラムを実行するためのプロセッサ10とを備えるコンピュ
ータ200が提供される。
(Structure 13) According to a certain embodiment, a
(構成14) ある実施形態に従うと、HMD110によって仮想空間2を提供するた
めにコンピュータ200で実行される方法が提供される。この方法は、複数のパノラマ画
像に含まれる一のパノラマ画像を仮想空間2に展開するステップ(ステップS2405)
と、HMD110のユーザ190から、仮想空間2に展開されているパノラマ画像を他の
パノラマ画像に変更するためのトリガの入力を受け付けるステップ(ステップS2415
)と、トリガの入力を受け付けた後に、ユーザ190から検索キーの入力を受け付けるス
テップ(ステップS2420)と、複数のパノラマ画像の中から、検索キーにより検索さ
れた一以上のパノラマ画像を特定するための情報を仮想空間2に提示するステップ(ステ
ップS2460)と、ユーザ190から、一以上のパノラマ画像の中から一のパノラマ画
像を選択する入力を受け付けるステップ(ステップS2465)と、選択された一のパノ
ラマ画像を仮想空間2に展開するステップ(ステップS2485)とを備える。
(Structure 14) According to certain embodiments, the
And the step of receiving the input of the trigger for changing the panoramic image developed in the
), The step of accepting the input of the search key from the
(構成15) ある実施形態において、HMD110に仮想空間2を提供するコンピュ
ータ200と通信可能なサーバ150によって実行されるプログラムが提供される。この
プログラムはサーバ150に、HMD110のモニタ112に展開されるパノラマ画像を
変更するための検索キーの入力をコンピュータ200から受け付けるステップ(ステップ
S2435)と、サーバ150のストレージ1930のパノラマ画像DB1934に格納
される複数のパノラマ画像の中から、検索キーに基づいて一以上のパノラマ画像を検索す
るステップ(ステップS2445)と、検索した一以上のパノラマ画像を特定するための
情報(例えば、サムネイル)をコンピュータ200に送信するステップ(ステップS24
50)と、一以上のパノラマ画像の中から選択された一のパノラマ画像のパノラマ画像I
Dの入力をコンピュータ200から受け付けるステップ(ステップS2475)と、パノ
ラマ画像の識別情報と検索キーとに基づいて、検索のための学習を行なうステップ(ステ
ップS2490)とを実行させる。
(Structure 15) In one embodiment, a program executed by a
50) and the panoramic image I of one panoramic image selected from one or more panoramic images.
The step of accepting the input of D from the computer 200 (step S2475) and the step of learning for the search based on the identification information of the panoramic image and the search key (step S2490) are executed.
上記によれば、サーバ150は、検索キーに従い、コンピュータ200のユーザ190
が所望するパノラマ画像の候補をユーザ190に提供できる。また、サーバ150は、検
索キーと、ユーザ190に選択されたパノラマ画像に関連づけられた情報(例えば、タグ
、タイトル)とに基づいて学習を行なうことにより、入力された検索キーに対してユーザ
190が所望するパノラマ画像をユーザ190に提供できる可能性を高め得る。
According to the above, the
Can provide the
(構成16) 上記の検索するステップは、検索キーから文字列を検出することと、パ
ノラマ画像DB1934に格納される複数のパノラマ画像の中から、検出された文字列が
関連付けられた一以上のパノラマ画像を検索することとを含む。
(Structure 16) The above search step is to detect a character string from a search key and one or more panoramas in which the detected character string is associated with a plurality of panoramic images stored in the
(構成17) 上記の検索キーは、コンピュータ200のユーザ190のフェイストラ
ッキングデータを含む。上記の検索するステップは、ユーザ190のフェイストラッキン
グデータからユーザ190の感情を推測することと、推測された感情に基づいて一以上の
パノラマ画像を検索することとを含む。
(Structure 17) The search key includes face tracking data of
(構成18) ある実施形態に従うと、(構成15)〜(構成17)のいずれかに記載
のプログラムを格納したストレージ1930と、当該プログラムを実行するためのプロセ
ッサ1920とを備えるサーバ150が提供される。
(Configuration 18) According to an embodiment, a
(構成19) ある実施形態に従うと、HMD110に仮想空間2を提供するコンピュ
ータ200と通信可能なサーバ150によって実行される方法が提供される。この方法は
、HMD110のモニタ112に展開されるパノラマ画像を変更するための検索キーの入
力をコンピュータ200から受け付けるステップ(ステップS2435)と、サーバ15
0のストレージ1930のパノラマ画像DB1934に格納される複数のパノラマ画像の
中から、検索キーに基づいて一以上のパノラマ画像を検索するステップ(ステップS24
45)と、検索した一以上のパノラマ画像を特定するための情報(例えば、サムネイル)
をコンピュータ200に送信するステップ(ステップS2450)と、一以上のパノラマ
画像の中から選択された一のパノラマ画像のパノラマ画像IDの入力をコンピュータ20
0から受け付けるステップ(ステップS2475)と、パノラマ画像の識別情報と検索キ
ーとに基づいて、検索のための学習を行なうステップ(ステップS2490)とを備える
。
(Structure 19) According to an embodiment, there is provided a method executed by a
A step of searching for one or more panoramic images based on a search key from a plurality of panoramic images stored in the
45) and information (eg, thumbnails) for identifying one or more searched panoramic images.
To the computer 200 (step S2450), and input the panoramic image ID of one panoramic image selected from one or more panoramic images to the
It includes a step of accepting from 0 (step S2475) and a step of learning for searching based on the identification information of the panoramic image and the search key (step S2490).
今回開示された実施の形態はすべての点で例示であって制限的なものではないと考えら
れるべきである。本発明の範囲は上記した説明ではなくて特許請求の範囲によって示され
、特許請求の範囲と均等の意味および範囲内でのすべての変更が含まれることが意図され
る。
It should be considered that the embodiments disclosed this time are exemplary in all respects and not restrictive. The scope of the present invention is shown by the scope of claims rather than the above description, and it is intended to include all modifications within the meaning and scope equivalent to the scope of claims.
1 仮想カメラ、2 仮想空間、5 基準視線、10,1920 プロセッサ、11
メモリ、12,1930 ストレージ、19 ネットワーク、22 パノラマ画像、10
0,1400 HMDシステム、112 モニタ、114 センサ、115 スピーカ、
116 第1カメラ、117 第2カメラ、119 マイク、120 HMDセンサ、1
30 モーションセンサ、140 注視センサ、150 サーバ、160 コントローラ
、190 ユーザ、200 コンピュータ、220 表示制御モジュール、221 仮想
カメラ制御モジュール、222 視界領域決定モジュール、223 視界画像生成モジュ
ール、224 基準視線特定モジュール、225 音声制御モジュール、226 視線検
出モジュール、227 ハンドトラッキングモジュール、228 フェイストラッキング
モジュール、230 仮想空間制御モジュール、231 仮想空間定義モジュール、23
2 仮想オブジェクト生成モジュール、233 手オブジェクト制御モジュール、240
メモリモジュール、241 空間情報、242 オブジェクト情報、243 ユーザ情
報、244 顔情報、810 ハンドオブジェクト1120,2810 スピーカオブジ
ェクト、1130 検索キー、1140,1210,1260,2320,2350 サ
ムネイル、1200,2200,2300,2500,2800,3100 視界画像、
1923 検索エンジン、1924 物体特定部、1925 感情判断部、1926 学
習部、1934 パノラマ画像DB、1935 学習用DB、1936,1937 学習
モデル、2220,2510 入力オブジェクト、2230 ペンオブジェクト、224
0 メッセージオブジェクト、2250 軌跡オブジェクト、2310 スクリーン、2
520 飛行機、2820,3120 ポインタオブジェクト、3000A,3000B
アバターオブジェクト。
1 virtual camera, 2 virtual space, 5 reference line of sight, 10,1920 processor, 11
Memory, 12, 1930 storage, 19 networks, 22 panoramic images, 10
0,1400 HMD system, 112 monitors, 114 sensors, 115 speakers,
116 1st camera, 117 2nd camera, 119 microphone, 120 HMD sensor, 1
30 motion sensor, 140 gaze sensor, 150 server, 160 controller, 190 users, 200 computers, 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, 225 Voice control module, 226 line-of-sight detection module, 227 hand tracking module, 228 face tracking module, 230 virtual space control module, 231 virtual space definition module, 23
2 Virtual object generation module, 233 Hand object control module, 240
Memory module, 241 spatial information, 242 object information, 243 user information, 244 face information, 810
1923 search engine, 1924 object identification part, 1925 emotion judgment part, 1926 learning part, 1934 panoramic image DB, 1935 learning DB, 1936, 1937 learning model, 2220, 2510 input object, 2230 pen object, 224
0 Message object, 2250 Trajectory object, 2310 screen, 2
520 airplane, 2820, 3120 pointer object, 3000A, 3000B
Avatar object.
Claims (13)
予め定められた複数のパノラマ画像に含まれる一のパノラマ画像を前記仮想空間に展開するステップと、
前記仮想空間に第1のユーザに対応する第1のアバターオブジェクトと、第2のユーザに対応する第2のアバターオブジェクトとを配置するステップと、
前記第1のユーザから、前記仮想空間に展開されているパノラマ画像を他のパノラマ画像に変更するためのトリガの入力を受け付けるステップと、
前記トリガの入力を受け付けた後に、前記第1のユーザから検索キーの入力を受け付けるステップと、
前記複数のパノラマ画像の中から、前記検索キーにより検索された一以上のパノラマ画像を特定するための情報を含む表示用オブジェクトを、前記複数のユーザにより共有される前記仮想空間に提示するステップと、
前記表示用オブジェクトに含まれる前記検索された一以上のパノラマ画像を特定するための情報に対し、前記第1のユーザが動かす前記第1のアバターオブジェクトの動き、および、前記第2のユーザが動かす前記第2のアバターオブジェクトの動きに応答して、前記一以上のパノラマ画像の中から一のパノラマ画像を選択する入力を受け付けるステップと、
前記選択された一のパノラマ画像を前記仮想空間に展開するステップとを実行させる、プログラム。 A program that is executed on a computer to provide a virtual space shared by a plurality of users.
A step of developing one panoramic image included in a plurality of predetermined panoramic images in the virtual space, and
A step of arranging a first avatar object corresponding to the first user and a second avatar object corresponding to the second user in the virtual space, and
A step of accepting an input of a trigger for changing a panoramic image developed in the virtual space to another panoramic image from the first user, and
After accepting the input of the trigger, the step of accepting the input of the search key from the first user, and
A step of presenting a display object including information for identifying one or more panoramic images searched by the search key from the plurality of panoramic images in the virtual space shared by the plurality of users. ,
The movement of the first avatar object moved by the first user and the movement of the second user with respect to the information for identifying the searched one or more panoramic images included in the display object. A step of accepting an input for selecting one panoramic image from the one or more panoramic images in response to the movement of the second avatar object.
A program that executes a step of developing the selected panoramic image in the virtual space.
前記ユーザから検索キーの入力を受け付けるステップは、前記ユーザの手の動きに基づく線図を前記検索キーとして受け付けることを含む、請求項3に記載のプログラム。 The program causes the computer to further perform a step of detecting the movement of the user's hand.
The program according to claim 3, wherein the step of accepting the input of the search key from the user includes accepting a diagram based on the movement of the user's hand as the search key.
前記仮想空間における予め定められた空間内に前記ユーザが形成した立体オブジェクトの入力を受け付けることと、
前記立体オブジェクトを2次元化して得られる線図を前記検索キーとして受け付けることとを含む、請求項3または4に記載のプログラム。 Input accepting step of the search key is
Accepting the input of the three-dimensional object formed by the user in the predetermined space in the virtual space,
The program according to claim 3 or 4, wherein a diagram obtained by converting the three-dimensional object into two dimensions is accepted as the search key.
前記検索キーは、前記ユーザの表情を表すデータを含む、請求項1または2に記載のプログラム。 The program causes the computer to further perform a step of detecting data representing the user's facial expression.
The program according to claim 1 or 2, wherein the search key includes data representing the facial expression of the user.
前記ユーザの音声の入力を受け付けることと、
前記ユーザの音声から抽出された文字列を前記検索キーとして受け付けることとを含む、請求項1または2に記載のプログラム。 The step of accepting the input of the search key is
Accepting the user's voice input
The program according to claim 1 or 2, comprising accepting a character string extracted from the user's voice as the search key.
前記トリガの入力を受け付けるステップは、前記スピーカオブジェクトまたは前記マイクオブジェクトに対する前記ユーザの予め定められた動作を前記トリガとして受け付けることを含む、請求項8に記載のプログラム。 The program causes the computer to further perform a step of placing a speaker object or a microphone object in the virtual space.
The program according to claim 8, wherein the step of accepting the input of the trigger includes accepting a predetermined action of the user with respect to the speaker object or the microphone object as the trigger.
前記プログラムを実行するためのプロセッサとを備える、情報処理装置。 A memory in which the program according to any one of claims 1 to 11 is stored, and
An information processing device including a processor for executing the program.
予め定められた複数のパノラマ画像に含まれる一のパノラマ画像を前記仮想空間に展開するステップと、
前記仮想空間に第1のユーザに対応する第1のアバターオブジェクトと、第2のユーザに対応する第2のアバターオブジェクトとを配置するステップと、
前記第1のユーザから、前記仮想空間に展開されているパノラマ画像を他のパノラマ画像に変更するためのトリガの入力を受け付けるステップと、
前記トリガの入力を受け付けた後に、前記第1のユーザから検索キーの入力を受け付けるステップと、
前記複数のパノラマ画像の中から、前記検索キーにより検索された一以上のパノラマ画像を特定するための情報を含む表示用オブジェクトを、前記複数のユーザにより共有される前記仮想空間に提示するステップと、
前記表示用オブジェクトに含まれる前記検索された一以上のパノラマ画像を特定するための情報に対し、前記第1のユーザが動かす前記第1のアバターオブジェクトの動き、および、前記第2のユーザが動かす前記第2のアバターオブジェクトの動きに応答して、前記一以上のパノラマ画像の中から一のパノラマ画像を選択する入力を受け付けるステップと、
前記選択された一のパノラマ画像を前記仮想空間に展開するステップと、
前記入力された検索キーと、前記選択された一のパノラマ画像の識別情報とを、前記コンピュータと通信可能な情報処理端末に送信するステップとを備える、方法。 A method performed on a computer to provide a virtual space shared by multiple users.
A step of developing one panoramic image included in a plurality of predetermined panoramic images in the virtual space, and
A step of arranging a first avatar object corresponding to the first user and a second avatar object corresponding to the second user in the virtual space, and
A step of accepting an input of a trigger for changing a panoramic image developed in the virtual space to another panoramic image from the first user, and
After accepting the input of the trigger, the step of accepting the input of the search key from the first user, and
A step of presenting a display object including information for identifying one or more panoramic images searched by the search key from the plurality of panoramic images in the virtual space shared by the plurality of users. ,
The movement of the first avatar object moved by the first user and the movement of the second user with respect to the information for identifying the searched one or more panoramic images included in the display object. A step of accepting an input for selecting one panoramic image from the one or more panoramic images in response to the movement of the second avatar object.
A step of expanding the selected panoramic image into the virtual space,
A method comprising the steps of transmitting the input search key and the identification information of the selected panoramic image to an information processing terminal capable of communicating with the computer.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2019040931A JP6911070B2 (en) | 2017-09-04 | 2019-03-06 | Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2017169613A JP6495399B2 (en) | 2017-09-04 | 2017-09-04 | Program and method executed by computer to provide virtual space, and information processing apparatus for executing the program |
JP2019040931A JP6911070B2 (en) | 2017-09-04 | 2019-03-06 | Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2017169613A Division JP6495399B2 (en) | 2017-09-04 | 2017-09-04 | Program and method executed by computer to provide virtual space, and information processing apparatus for executing the program |
Publications (3)
Publication Number | Publication Date |
---|---|
JP2019135655A JP2019135655A (en) | 2019-08-15 |
JP2019135655A5 JP2019135655A5 (en) | 2021-04-22 |
JP6911070B2 true JP6911070B2 (en) | 2021-07-28 |
Family
ID=67624207
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2019040931A Active JP6911070B2 (en) | 2017-09-04 | 2019-03-06 | Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP6911070B2 (en) |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH05314240A (en) * | 1992-05-11 | 1993-11-26 | Sony Corp | Three-dimensional shape data display method |
JPH0785084A (en) * | 1993-09-10 | 1995-03-31 | Toshiba Corp | Picture storage system and picture retrieval system |
JP4367663B2 (en) * | 2007-04-10 | 2009-11-18 | ソニー株式会社 | Image processing apparatus, image processing method, and program |
JP2009087034A (en) * | 2007-09-28 | 2009-04-23 | Sega Corp | Virtual space presenting system, server, method, and program |
JP5104743B2 (en) * | 2008-12-16 | 2012-12-19 | 富士通株式会社 | Image search program, image search method, and recording medium |
JP2010211172A (en) * | 2009-02-10 | 2010-09-24 | Nippon Telegr & Teleph Corp <Ntt> | Speech recognition communication support system and speech recognition communication support method |
JP2013055606A (en) * | 2011-09-06 | 2013-03-21 | Nikon Corp | Image display system, image display device and program |
-
2019
- 2019-03-06 JP JP2019040931A patent/JP6911070B2/en active Active
Also Published As
Publication number | Publication date |
---|---|
JP2019135655A (en) | 2019-08-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP6244593B1 (en) | Information processing method, apparatus, and program for causing computer to execute information processing method | |
US10341612B2 (en) | Method for providing virtual space, and system for executing the method | |
JP6263252B1 (en) | Information processing method, apparatus, and program for causing computer to execute information processing method | |
US10453248B2 (en) | Method of providing virtual space and system for executing the same | |
US20180165862A1 (en) | Method for communication via virtual space, program for executing the method on a computer, and information processing device for executing the program | |
US10545339B2 (en) | Information processing method and information processing system | |
US20190026950A1 (en) | Program executed on a computer for providing virtual space, method and information processing apparatus for executing the program | |
US10894211B2 (en) | Information processing method, apparatus, and system for executing the information processing method | |
US20180196506A1 (en) | Information processing method and apparatus, information processing system, and program for executing the information processing method on computer | |
JP6290467B1 (en) | Information processing method, apparatus, and program causing computer to execute information processing method | |
US20190005732A1 (en) | Program for providing virtual space with head mount display, and method and information processing apparatus for executing the program | |
JP6201028B1 (en) | Information processing method, apparatus, and program for causing computer to execute information processing method | |
JP7394158B2 (en) | Program and method executed on a computer and information processing apparatus for providing a virtual space via a head-mounted device | |
US20180190010A1 (en) | Method for providing virtual space, program for executing the method on computer, and information processing apparatus for executing the program | |
US20190043263A1 (en) | Program executed on a computer for providing vertual space, method and information processing apparatus for executing the program | |
US20180189555A1 (en) | Method executed on computer for communicating via virtual space, program for executing the method on computer, and computer apparatus therefor | |
JP6470387B1 (en) | Method executed by computer to provide information via head-mounted device, program causing computer to execute the method, and information processing apparatus | |
JP6495399B2 (en) | Program and method executed by computer to provide virtual space, and information processing apparatus for executing the program | |
JP2018124981A (en) | Information processing method, information processing device and program causing computer to execute information processing method | |
JP2018125003A (en) | Information processing method, apparatus, and program for implementing that information processing method in computer | |
JP2019030638A (en) | Information processing method, device, and program for causing computer to execute information processing method | |
JP6911070B2 (en) | Programs and methods that are executed on a computer to provide virtual space, and information processing devices that execute the programs. | |
JP2018092592A (en) | Information processing method, apparatus, and program for implementing that information processing method on computer | |
US20180246579A1 (en) | Method executed on computer for communicating via virtual space, program for executing the method on computer, and computer apparatus therefor | |
JP2018092635A (en) | Information processing method, device, and program for implementing that information processing method on computer |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20200828 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20210304 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20210615 |
|
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: 20210629 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20210707 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 6911070 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |