|
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | ||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | ||||||||
Objectcom.docomostar.device.location.Compass
public class Compass
電子コンパス機能を提供します。
電子コンパス機能は地磁気センサにより、端末の方位角を取得する機能を提供します。 端末の方位角の値は、磁北を 0 度とし、時計回りを正の方向として取得します。
[Star-1.5 以降]
電子コンパス機能では、現在の方位角を得るワンショット計測の他に、
周期的に連続して方位角を得る周期計測を提供します。
また、計測する方向を PhoneSystem.DEV_EYE_DIRECTION で設定しておくことで、
Star アプリはユーザの視線の方向が反映された方位角を取得できます。
PhoneSystem.DEV_EYE_DIRECTION の設定は、ワンショット計測と周期計測の両方で有効です。
周期計測では、
ユーザの視線の方向を反映した計測結果を実装内部の計測データ蓄積バッファに蓄積します。
周期計測の計測結果は、周期計測中あるいは計測後に蓄積バッファ内から取得できます。
取得できる方位角は、DEGREE 単位で表した値のみとなります。
DMS 単位で表された方位角を取得する場合は、Degree クラスを利用して下さい。
周期計測中は、ユーザの視線の方向を設定することができません。 そのため、ユーザの視線の方向を再設定する前には、周期計測を停止し、 バッファから計測結果を取得しておいて下さい。
| フィールドの概要 | |
|---|---|
static double |
BUFFER_EMPTY
周期計測の最新値を表す定数で、バッファにデータが存在していないことを表します(=-9999.0)。 |
| コンストラクタの概要 | |
|---|---|
protected |
Compass()
アプリケーションが直接このコンストラクタを呼び出して オブジェクトを生成することはできません。 |
| メソッドの概要 | |
|---|---|
void |
disposeData()
周期計測用の蓄積バッファをクリアします。 |
Degree |
getAzimuth()
ワンショット計測により、現在の方位角を取得します。 |
static Compass |
getCompass()
電子コンパス機能のインスタンスを返します。 |
double[] |
getData()
周期計測用の蓄積データバッファから計測結果を取得します。 |
int |
getDataSize()
周期計測用の蓄積データバッファに蓄積されているデータ数を取得します。 |
int |
getIntervalResolution()
周期計測の計測間隔の解像度を取得します。 |
int |
getMaxDataSize()
周期計測において実装内部で蓄積可能な最大データ数を取得します。 |
double |
peekLatestData()
周期計測用の蓄積データバッファから最新の計測値を1つ取得します。 |
void |
setEnabled(boolean enabled)
電子コンパス機能を有効化・無効化します。 |
void |
start(int interval)
周期計測を開始します。 |
void |
stop()
周期計測を停止します。 |
| クラス Object から継承されたメソッド |
|---|
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| フィールドの詳細 |
|---|
public static final double BUFFER_EMPTY
| コンストラクタの詳細 |
|---|
protected Compass()
| メソッドの詳細 |
|---|
public static Compass getCompass()
電子コンパス機能のインスタンスを返します。 複数回呼び出された場合は、常に同じインスタンスを返します。
実装によっては、電子コンパス機能をサポートしていない場合があります。
UnsupportedOperationException -
DeviceException - public Degree getAzimuth()
ワンショット計測により、現在の方位角を取得します。
このメソッドは、電子コンパス機能が有効化された状態で呼び出す必要があります。 無効化された状態で呼び出された場合には例外が発生します。
本メソッドの実行に成功すると、 周期測定用の測定結果蓄積バッファはクリアされます。
IllegalStateException -
DeviceException - public void start(int interval)
指定した間隔毎に周期計測を行います。
実装がサポートしている計測間隔は、
getIntervalResolution()
で得られる解像度の倍数です。
実装サポート値以外の計測間隔を指定した場合、
指定した値以上で最も実装サポート値に近い値が指定されたものとして
扱われます。
周期計測を開始する前に、電子コンパス機能を有効化する必要があります。 無効化された状態で、このメソッドが呼び出された場合には例外が発生します。
周期計測を停止させるためには、
stop()メソッドを使用します。
周期計測中に電子コンパス機能が無効化された場合、
周期計測は停止します。
計測結果は、実装内部の計測結果蓄積バッファに蓄積されていきます。
蓄積可能な最大データ数は、
getMaxDataSize()
により取得できます。
最大データ数を超えると、蓄積されたデータの
古いものから上書きします。
計測結果は、getData()により、
周期計測中および周期計測後に取得できます。
蓄積された計測結果は、
次にワンショット計測、または周期計測を行った場合、
またdisposeData()、
getData()を呼び出した場合、
アプリケーションを終了した場合にクリアされます。
周期計測中にサスペンドが発生した場合、
周期計測は自動的に停止します。
周期計測を再開する場合には、レジュームイベント処理において、
再度本メソッドを呼び出してください。
サスペンド前の計測値は
getData()により取得して下さい。
getAzimuth()メソッド呼び出し中に
別のスレッドからこのメソッドが呼び出された場合、
getAzimuth()呼び出し終了までこの
メソッドの実行は遅延されます。
本メソッドの実行に成功すると、 周期計測用の蓄積バッファはクリアされます。
interval - 周期計測の間隔をミリ秒単位で指定します。IllegalArgumentException -
IllegalStateException -
DeviceException - DeviceException - public void stop()
周期計測中以外に呼ばれた場合、何もしません。
public int getIntervalResolution()
public int getMaxDataSize()
public int getDataSize()
public double[] getData()
このメソッドは、呼び出しの度に新しい配列を生成し、その配列の参照を返します。 戻り値の配列の全要素に有効な計測データが格納されています。
本メソッドの実行に成功すると、 周期計測用の蓄積バッファはクリアされます。
蓄積バッファに計測データが 1 つも蓄積されていない時に本メソッドを呼び出した場合、 null を返します。
周期計測中に計測結果を取得した場合でも引き続き周期的に計測されます。
public double peekLatestData()
本メソッドの実行に成功しても、 周期計測用の蓄積バッファはクリアされません。
蓄積バッファに計測データが 1 つも蓄積されていない時に本メソッドを呼び出した場合、
BUFFER_EMPTY を返します。
public void disposeData()
public void setEnabled(boolean enabled)
電子コンパス機能を有効化・無効化します。 方位角の計測を行うには、電子コンパス機能を有効化する必要があります。
電子コンパス機能が有効化されている間は、通常より多くの電力を消費します。 電子コンパス機能を利用しないときは、このメソッドで無効化して下さい。
電子コンパス機能が既に有効化されている状態で有効化しようとしたり、 既に無効化されている状態で無効化しようとした場合には、何もしません。
電子コンパス機能が有効化されている状態で、このアプリケーションが終了した場合は、 電子コンパス機能は無効化されます。
enabled - 電子コンパス機能を有効化するには true を、
無効化するには false を、それぞれ指定します。
|
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | ||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | ||||||||
NTT DOCOMO,INC.
本製品または文書は著作権法により保護されており、その使用、複製、再頒布および逆コンパイルを制限するライセンスのもとにおいて頒布されます。NTTドコモ(その他に許諾者がある場合は当該許諾者も含めて)の書面による事前の許可なく、本製品および関連する文書のいかなる部分も、いかなる方法によっても複製することが禁じられます。フォントを含む第三者のソフトウェアは、著作権法により保護されており、その提供者からライセンスを受けているものです。
Sun、Sun Microsystems、Java、J2MEおよびJ2SEは、米国およびその他の国における米国 Sun Microsystems,Inc.の商標または登録商標です。サンのロゴマークは、米国 Sun Microsystems, Inc.の登録商標です。
FeliCaは、ソニー株式会社が開発した非接触ICカードの技術方式です。FeliCaは、ソニー株式会社の登録商標です。
「iモード」、「iアプリ/アイアプリ」、「i-αppli」ロゴ、「DoJa」はNTTドコモの商標または登録商標です。
その他記載された会社名、製品名などは該当する各社の商標または登録商標です。