ピアノで遊ぶアプリPiano Manをやってみた

pianoman.png
Piano Manと言えば、イギリスの海岸で発見されて話題を呼んだ男性。このアプリを使えば、彼のようにいろんな曲が弾けるようになる・・・かもしれません。Wikipedia: ピアノマン

このPiano Man、鍵盤が光る電子ピアノみたいに、指示されたタイミングでタッチすることで伴奏に合わせて曲が弾けるというアプリです。実に多くの曲が登録されているようです。115円という価格でいろんな曲が楽しめるので悪くないかなと思ってポチリました。以下、スクリーンショットでご紹介。

▼左側から曲を選びます。For elise(エリーゼのために)を選んでみます。
IMG_0034.PNG

▼曲を選んだ後は、Modeでスピードを選びます。
IMG_0035.PNG
▼落ちてくるボールに合わせて鍵盤をタップして伴奏にぴったり・・・と言いたいところですが。。。エリーゼ、ちょーむずwwww
IMG_0034.PNG

▼最後に点数が出ます。低っ・・・。
IMG_0036.PNG

▼ランキング登録するとSafariが開いて、曲・難易度別の順位が出ます。なんと”エリーゼのために”のノーマルで二位になってしまいました。横で聞いていた嫁はあまりの下手さに爆笑だったんですけどね・・・。曲によってはランキングエントリー数が多いのかもしれません。アニソンとか2008年ドラマ主題歌とか盛りだくさんみたいで、今度はそちらも試してみようと思います。
IMG_003x.PNG

以上、疲れてたのでこんなアプリ買ってみました。めざせピアノマン!

アプリ開発雑記[7] SQLiteBooks その2

前回の続きです。
TabBarの中に、サンプルコード"SQLiteBooks"を埋め込んだ手順をまとめてます。

(4) やったこと(後編)

(4-1) Xcodeで作業します。SQLiteBooksからコピーしてきたコードに手を加えます。まずはAppDelegate.hから。プロジェクトに元々あったHogehogeAppDelegate
を使用するよりソースコードの編集量が少なくて済むのでこちらを使います。ハイライトしている部分が編集した部分で、コメントアウトされているのが変更前です。

UIApplicationDelegateプロトコルとUITabBarControllerDelegateプロトコルに従います。もとのAppDelegateがなぜにUIApplicationDelegateに準拠してないのかは謎。他の変更はもとのソースがNavigationControllerを持っているのをTabBarControllerに変えるのに伴ったものです。実に簡単な変更です。


#import <UIKit/UIKit.h>
// This includes the header for the SQLite library.
#import <sqlite3.h>

// Inform the compiler that the following classes are defined in the project:
@class Book, MasterViewController, DetailViewController, AddViewController, EditingViewController;

//@interface AppDelegate : NSObject {
@interface AppDelegate : NSObject <UIApplicationDelegate, UITabBarControllerDelegate> {
    IBOutlet UIWindow *window;
    //IBOutlet UINavigationController *navigationController;

  IBOutlet UITabBarController *tabBarController;
    NSMutableArray *books;
    // Opaque reference to the SQLite database.
    sqlite3 *database;
}

@property (nonatomic, retain) UIWindow *window;
//@property (nonatomic, retain) UINavigationController *navigationController;
@property (nonatomic, retain) IBOutlet UITabBarController *tabBarController;

// Makes the main array of book objects available to other objects in the application.
@property (nonatomic, retain) NSMutableArray *books;

// Removes a book from the array of books, and also deletes it from the database. There is no undo.
– (IBAction)removeBook:(Book *)book;
// Creates a new book object with default data. 
– (void)addBook:(Book *)book;

 

@end



(4-2) 次はAppDelegate.m。長いソースですが変更箇所はわずかです。ここもTabBarControllerに絡む変更のみ。


#import "AppDelegate.h"
#import "MasterViewController.h"
#import "DetailViewController.h"
#import "AddViewController.h"
#import "EditingViewController.h"
#import "Book.h"

// Private interface for AppDelegate – internal only methods.
@interface AppDelegate (Private)
– (void)createEditableCopyOfDatabaseIfNeeded;
– (void)initializeDatabase;
@end

@implementation AppDelegate

// Instruct the compiler to create accessor methods for the property. It will use the internal 
// variable with the same name for storage.
//@synthesize books, window, navigationController;
@synthesize books, window, tabBarController;

– (void)applicationDidFinishLaunching:(UIApplication *)application {
    // The application ships with a default database in its bundle. If anything in the application
    // bundle is altered, the code sign will fail. We want the database to be editable by users, 
    // so we need to create a copy of it in the application's Documents directory.     
    [self createEditableCopyOfDatabaseIfNeeded];
    // Call internal method to initialize database connection
    [self initializeDatabase];
    // Add the navigation controller's view to the window
    //[window addSubview:navigationController.view];
[window addSubview:tabBarController.view];

    [window makeKeyAndVisible];
}

– (void)applicationDidReceiveMemoryWarning:(UIApplication *)application {
    // "dehydrate" all data objects – flushes changes back to the database, removes objects from memory
    [books makeObjectsPerformSelector:@selector(dehydrate)];
}

– (void)dealloc {
    //[navigationController release];   
    [tabBarController release];   
[window release];
    [books release];
    [super dealloc];
}

(中略)

@end



(4-3) 次にもうひとつだけInterface Builderで作業をします。ApplicationDelegateになるクラスをもともとプロジェクト作成時にデフォルトで生成されていたクラスからAppDelegateクラスに変更したので、それを教えてあげなければなりません。本当は昨日加えた変更とまとめてやってしまって良いのですが、昨日書くのを忘れていたのでここで書きます(汗)。まぁ、今日関連する作業をXcodeでやった後なので、あながち悪くないのですが。

TableTry_MainWindowxib2.png
<fig. 5>
(4-4) 最後にビルドですが、もうひとつ、SQLiteを使用するには専用のフレームワークを読み込まなければなりません。グループとファイルの下のFrameworksを右クリックして”追加”から”既存のフレームワーク”を選び、数あるフレームワークの中から、libsqlite3.0.dylibを追加します。
(4-5) ビルドして実行!で完成です。わたしは実機にインストールしてます。実機だと達成感があります。
IMG_0034.PNG
<fig. 6>
(5) 最後に
今日、なにげにもう一度なにも見ずに最初からやってみましたが、またひっかかりました。ひっかかりやすいポイントをあげるならば以下の3点でしょうか。
  • NavigationViewController.xibでFile's OwnerにTable Viewを接続し忘れる
  • ApplicationDelegateをMainWindow.xibで古いままにしている(今回追記したポイントw)
  • libsqlite3.0.dylibフレームワークを追加し忘れている

3つ目はコンパイル時にエラーが出るのでわかりますが、上2つはでません。アプリの動作が止まっ
たらコンソールで確認するとヒントがでてます。

以上!

<<免責事項>>
ここに紹介した方法を参考にしてアプリケーション開発を行ったことで発生しうる如何なる問題についても、当ブログ管理者は一切責任を負いません。

アプリ開発雑記[6] SQLiteBooks(その1)

今日は、前回記事までの成果であるNavigation ControllerをTab Bar内のタブに実装したものの発展系として、Navigation Controller以下にサンプルコード"SQLiteBooks"を埋め込むことにトライしました。作りたいアプリではユーザーが入力したデータを追加したり、削除したりする機能がある予定でして、SQLiteが唯一の方策かどうかはさっぱりわかりませんが、サンプルコードにあるようなデータの管理をイメージしていたので取り入れてみることにしました。備忘のために、作業内容+αをまとめます!
前回記事:アプリ開発雑記[5] Navigation Controller + TabBar その3
続きを読む

アプリ開発雑記[5] NavigationController + Tabbar その3

NavigationContollerをTabBarに埋め込む件の続き。

やっとスマートに解決できました。

前々回は、Interface Builderを使っては実現できないと言っていたものの、
前回、早速それを否定するチュートリアルを見つけた、というところまでご報告してました。

それで、前回紹介したチュートリアル通りにやってみました。

しかし、なぜかうまく行かない。今日もまた2時間近く浪費して途方に暮れてました。
三たび改めてGoogleさんに聞いてみたところ、親切なチュートリアルを見つけました。
しかも、前回紹介したものよりかなりスマートです。
続きを読む

アプリ開発雑記[4] NavigationController + TabBar その2

昨日からNavigationControllerをTabBarに埋め込む方法で悩んでいます。

昨日の記事で書いた方法は、記事UP後に試してみたところ、とりあえずNavigationControllerがTabBarに入ることまで確認できました。しかしながら、xib無しでprogramaticallyにテーブルをwindowに配置したり、datasourceを紐付けるのがうまくいかず、中身は空っぽのまま。サンプルコード”TheElement”を落ち着いて読み直さなければいけません。難しい。

というわけで、上記はややハードルが高そうなので、もう一度Googleさんに聞いてみました。すると、別なものを見つけました。今度はxib(Interface Builder)を使う方法です。こちらの方がわかりやすそう。TableViewも今まで通り扱える・・・かな。

http://twilloapp.blogspot.com/2009/03/how-to-embed-navigation-controller.html

今日はGW明けで仕事が忙しすぎて疲れました。明日試そうと思います。とりあえず備忘のためにメモです。