今回は、iPhone,ipod,ipad に内蔵されている加速度センサーを使って、x,y,zの加速度を取得する方法について説明します。 加速度センサーとは、自由落下に対するデバイスの加速度を計測します。1の値はデバイスに1G の重力がかかっていることを示します(1G の重力は、デバイスが静止状態の時に感じる地球の重力)。加速度センサーはデバイスの加速度を X、Y、および Z の3軸方向で計測します。
912-1 今回作成するアプリは、3軸の加速度を取得し、ラベルに表示します。加えて、デバイスを左右に振る(傾ける)と、現在時刻を表示するというものです。 まず、加速度センサーを扱うには、UIAccelerometerを利用します。 XCode を起動し、View Based Application で新規プロジェクトを作成します。 今回は、「Accelerometer」という名前にしています。 Accelerometer.h を開き、以下のように設定します。

#import <UIKit/UIKit.h>

@interface AccelerometerViewController : UIViewController <UIAccelerometerDelegate> {

 

 IBOutlet UILabel *xLabel;

 IBOutlet UILabel *yLabel;

 IBOutlet UILabel *zLabel;

 

 IBOutlet UILabel *clockLabel;

 double accelX, accelY, accelZ;

}

@end

まず、加速度センサーを利用するために、UIAccelerometerDelegate を定義します。これで、UIAccelerometer のイベントを認識するようになります。 IBOutlet は、view 上にx,y,zの値を表示させるためのラベルと、デバイスが振られた時に、現在時刻を表示するラベルです。 doubel の行は、x,y,z の値を扱うための変数です。 Accelerometer.h を保存してください。 次に、AccelerometerViewController.xib をダブルクリックし、Interface Builder を起動します。 以下の画像のようになるように、ラベルを配置し、Outlet を接続してください。 912-2完了したら、保存して Interface Builder を終了します。 最後に、Accelerometer.m を開き、viewDidLoad メソッドと accelerometer メソッドを以下のように設定してください。

– (void)viewDidLoad {

 UIAccelerometer *accel = [UIAccelerometer sharedAccelerometer];

accel.delegate = self;

accel.updateInterval = 1.0f/10.0f;

 

[super viewDidLoad];

}

– (void)accelerometer:(UIAccelerometer *)acel

didAccelerate:(UIAcceleration *)acceleration {

accelX = acceleration.x;

accelY = acceleration.y;

accelZ = acceleration.z;

 

 

xLabel.text =[NSString stringWithFormat:@”x: %g”, acceleration.x];

yLabel.text = [NSString stringWithFormat:@”y: %g”, acceleration.y];

zLabel.text = [NSString stringWithFormat:@”z: %g”, acceleration.z];

 

NSLog(@”x: %g”, acceleration.x);

NSLog(@”y: %g”, acceleration.y);

NSLog(@”z: %g”, acceleration.z);

 

if (acceleration.y >= –0.5) {

NSDateFormatter *df = [[NSDateFormatter alloc] init];

df.dateFormat  = @”yyyy/MM/dd HH:mm:ss”;

NSString *str = [df stringFromDate:[NSDate date]];

clockLabel.text = str;

}

 

 

}

上記のコードは、viewDidLoad 内で、updateInterval で読み取り間隔を設定しています。 accelerometer 内の acceleration.x によって、x軸の加速度の値を取得し、ラベルに表示させています。取得した各値をそれぞれラベルに表示させています。 さらに、動きを確認するために、NSLogもセットしています。 最後の if文は、acceleration.y が、「-0.5」以上になれば、clockLabel に現在時刻がセットされるようにしています。 これで保存し、デバイス上で、ビルド&実行することで、動作確認出来ます。 現在時刻の取得 http://iphone-tora.sakura.ne.jp/nsdate.html 加速度センサー http://d.hatena.ne.jp/moto_maka/20090510/1241898972 http://japan.internet.com/developer/20100803/26.html

この投稿へのコメント

コメントはまだありません。

コメントを残す

メールアドレスが公開されることはありません。

次のHTML タグと属性が使えます。
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

CAPTCHA


ピックアップ記事

超簡単にキャベツの臭みをとる!

2010年07月22日 過去Blog
超簡単にキャベツの臭みをとる!
WEBとは全然関係ない話題ですが、お店などで出てくる生のキャベツは臭みもなく美味しく食べれるのですが、生のキャベツを家庭で食べようとすると、どうしても臭みがあるので、どうしたものかと調べていると簡単に解決出来る方法がありましたので、メモしておこうと思います。 方法は本当に簡単で、、、、、 「冷水にさらす」 ・・・以上で簡単にキャベツの臭みがなくなりました。 以下のサイトには…
「超簡単にキャベツの臭みをとる!」をはてなブックマークに追加

PHPでPING送信を実装する

2010年03月28日 過去Blog
[php]<?php require_once('XML/RPC.php'); function Ping_Send($blog_title,$blog_url){ $ping = array( 'ping.rss.drecom.jp' => '/', 'api.my.yahoo.co.jp' => '/RPC2', 'blog.goo.n…
「PHPでPING送信を実装する」をはてなブックマークに追加

php 配列の要素から重複を削除し、添え字を再配布する

2009年12月07日 過去Blog
$example_array= array( "green", "red", "green", "blue", "red"); phpで上記のような配列から、重複要素を削除するには $example_array = array_unique($example_array); とすることで重複要素は削除されます。 …
「php 配列の要素から重複を削除し、添え字を再配布する」をはてなブックマークに追加

SQLite で Limit や ORDER BY RANDOM()など

2010年12月16日 過去Blog
SQLite で抽出データを並び替え SELECT * FROM テーブル名 ORDER BY フィールド1 DESC, フィールド2 DESC, フィールド3 ASC ; 上記のようにすることで、「テーブル名」という名前のテーブルの全てのデータを「フィールド1」の降順で並べ、「フィールド1」が同値の場合、次の「フィールド2」を降順に並べ、さらに「フィールド2」も同値の場合、「フィールド3」を基準に昇順に並び替えます。 ASC は結果が昇順に並びかえ、 DESC はそれが降順に並ぶかえることを表します。そのどちらも指定されていない場合、 ASC で並び替えられます。 SQLite でランダムにデータを抽出する まず、SQLite でランダムにデータを取り出す方法 SELECT * FROM entry ORDER BY RANDOM(); SQLite で行数指定(LIMIT)でデータを抽出する SELECT文では、WHERE句などを指定した場合でも条件に一致する全てのデータを取得します。この取得する件数を制限したい場合にはLIMIT句を使います。書式は以下の通りです。 SELECT カラム名, ... FROM テーブル名 LIMIT 行数; …
「SQLite で Limit や ORDER BY RANDOM()など」をはてなブックマークに追加
© graffiti on the web . All rights reserved. WordPress Theme by comfy