今回は、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


ピックアップ記事

PHP 小数点の管理 round

2010年06月02日 過去Blog
小数点以下第2位で四捨五入 $num2 = round($num1,2); echo $num2; これで$num2は小数点第二位まで表示されます。(12.22、5053.35など)
「PHP 小数点の管理 round」をはてなブックマークに追加

SQLite について

2010年12月07日 過去Blog
iPhoneアプリ開発でSQLiteを使う必要があるので、概要を簡単にまとめてみます。 もっと詳しく知りたい方は、SQLite などを参考にしてください。 SQLデータベースの主な役割は、SQLステートメントに従って、データを扱うことです。この目的を達成するために、開発者は2つのことを知っておく必要があります。 …
「SQLite について」をはてなブックマークに追加

phpでRSSを取得後の日付表示方法を変更する

2009年12月05日 過去Blog
FC2ブログからRSSを取得すると、日付は以下のようになる。 <dc:date>2009-12-24T00:20:00+09:00</dc:date> このままでは、少しかっこが悪いので、以下のように修正。 $date ="2009-12-05T05:55:00+09:00"; $date = strtotime($date); $date = date('Y/m/d …
「phpでRSSを取得後の日付表示方法を変更する」をはてなブックマークに追加

iPhoneアプリをAppStoreに公開する手順(編集中)

2011年02月05日 過去Blog
iTunes Connectを利用してアプリケーションを送信し、App Storeでの公開を依頼するには、 以下のものが必要です。 ■ アプリケーションのバイナリ ■ iOS用のバイナリ:iPhoneおよびiPod touch用の57ピクセルのアイコンとオプションの114 ピクセルの高解像度アイコン、またはiPad用の50ピクセルのアイコンと72ピクセルのアイコン を含む パソコン用のApp…
「iPhoneアプリをAppStoreに公開する手順(編集中)」をはてなブックマークに追加

[3]:Interface Builder と Xcode を接続する方法

2010年11月30日 過去Blog
今回は、Interface Builder を使って、UITextField, UILabel, そして ボタンを配置し、Xcode で書いたコードと接続し、動作させてみます。 アプリケーションの仕様 ユーザーがテキストボックスをタップすると入力用のキーボードが表示される ユーザーは自分の名前(任意の文字列)を入力する 実行ボタンを押す ボタンを押すとラベルが、「Hello! ユーザー名!」のような表示に更新される もし、テキストボックスが空のまま実行されると、警告を表示させる …
「[3]:Interface Builder と Xcode を接続する方法」をはてなブックマークに追加
© graffiti on the web . All rights reserved. WordPress Theme by comfy