iPhone SDK開発のネタ帳 マルチタッチ対応

公開日: : 最終更新日:2010/04/20 iPad, iPhone ,

iPhone SDK開発のレシピにはいろいろ役に立つ内容があったので、同じようなことをブログに書いてみようの活動。

自作アプリおんぷちゃんでは、UIViewn上にUIButtonを置く形でピアノの鍵盤を実現しているが、今まではマルチタッチに対応していなかったので、和音に対応できていなかった。
今回、iPadアプリを作るにあたって、iPadはでかいので実寸に近い形で鍵盤を置くことができるので、今までのおんぷあてやおとあてだけではなく、普通に演奏できるモードも用意したいと思った。
実際にはiPadのグランドオープニングには全く間に合わなかったが、その後も細々と開発を続けている。

で、困っていたのは UIViewの上に複数のUIButtonを置いて、そのUIButtonを複数同時に押しても、どうやらマルチタッチにならない。UIButtonのtouchesBeganやtouchesMovedに [self.nextResponder touchesBegan:touches withEvent:event] を入れても superview にはマルチタッチとして渡らない。

で、今朝調べていたところようやく原因と思われるものを発見。
Apple のこのページに日本語で詳しく書かれていた。

ページの最後の方に、「ところが、マルチタップやマルチタッチは、それらが最初に発生したサブビューに関連付けられているため、スーパービューではこれらのタッチを受け取ること ができません。すべての種類のタッチを確実に受け取れるようにするには、スーパービューでhitTest:withEvent:を オーバーライドして、サブビューではなく自分自身を返すようにします。」と書かれている。

そこで、下記コードを入れてみたところ UIButton にはタッチ情報が渡らなくなり、UIViewの方でマルチタッチを検知できるようになった。

 - (UIView *)hitTest:(CGPoint)point withEvent:(UIEvent *)event {
  if(CGRectContainsPoint(self.bounds, point)) { return self; } 
  return nil; 
} 

これにより、UIButtonが反応しなくなるので、CGRectContainsPoint()などを使ってヒットテストを行って、ボタンを手動でハイライト状態にする必要がある(UIButtonのインスタンス変数 highlighted に YES を入れる)。

UIViewのtouchesBegan:やtouchesMoved:にはUITouchがセットとして複数来るようになるので、ループを回して適切にハンドルする必要がある。

無為空間さんのページも参考にさせてもらいました。

追伸

hitTest:withEvent を使うようになってから、どうもアプリの挙動がおかしいと思っていたら、hidden プロパティを YES にした UIView のhitTest:withEvent が呼ばれていた。これはバグではないのか?これを避けるために、hitTest:withEventの中で、hidden プロパティの値をチェックして、hiddenがYESであればnilを返すようにして回避した。

iPhone SDK開発のレシピ―113個のレシピで学ぶiPhoneアプリ開発の極意
iPhone SDK開発のレシピ―113個のレシピで学ぶiPhoneアプリ開発の極意
秀和システム 2010-03
売り上げランキング : 3758

Amazonで詳しく見る by G-Tools

関連記事

no image

[iOS SDK] SSPieProgressView を使ってみた

iOS オープンソースライブラリ徹底活用 菊田剛著 秀和システム | DevCafeJp で紹介さ

記事を読む

no image

[iOS] iPhone とつながるG-SHOCKの注意すべき仕様

CASIO 腕時計 G-SHOCK ジー・ショック Bluetooth Low Energy対応

記事を読む

no image

iPhone 5 用のケースと保護シートとジャケットを買ってみた

発売日翌日に16GB iPhone 5を入手できたので早速ケースと保護シートとジャケットを買ってみた

記事を読む

PebbleKit iOS SDK dynamic framework 問題

最近 EverLearn の Pebble アプリがiOSアプリと接続できずエラーが表示されるので、

記事を読む

Wi-Fi体重計Withings WS-50 を買ったのでSDKを試してみる

奥さんからの要望でスマホと連携する体重計を検討していたが、いつの間にかWithingsのWS-50が

記事を読む

no image

初代 iPad mini 16GB ブラックスレート注文

予約は10/26(金)16:00 きっかりに開始され、iPad mini 16GB ブラックスレート

記事を読む

Siri Shortcuts に対応

正月休み中なので、ブログ記事が書きやすい。毎年この時期だけはよくブログを書いている気がする。

記事を読む

奥さん用 iPhone 4 購入

奥さんのiPhone 3Gに電源が入らなくなり、再起動したりDFUモードにしたりしても直らず、修理(

記事を読む

no image

[iPhone開発本] iPhoneではじめるOpenGL ESプログラミング

2010/07/13(火)発売。昨日書店で立ち読みしてみたら良さそうな本だった。 パンカクの本も良か

記事を読む

iOS13からpresentViewControllerの挙動が変わっている

    ; を実行してViewControllerを表示していま

記事を読む

Comment

  1. amy より:

    はじめまして、amyと申します。

    私は、UIButtonを複数配置したのですが、6つ以上同時押しをすると
    挙動がおかしくなりました(押された状態で止まる)
    ネットで調べていた所、こちらのサイトにたどり着きました。

    hitTest:withEventを使い、UIButtonのインスタンス変数 highlighted を YESに設定し、
    再び6つ以上同時押しをすると、やはり同じエラーが発生しました。

    tokentokenさんは同じようなことはありませんでしたか?

  2. admin より:

    ちょっと調べてみたところ、iPhone が認識するマルチタッチの最大数は5であるようです。

    http://stackoverflow.com/questions/1202484/how-to-force-iphone-ipod-touch-to-handle-more-than-5-touches-at-the-same-time

    なので、6つ目でエラーが発生するのは仕様なのかも知れません。

    私はiPadで上記を実装していますが、iPadは11点まで認識できるという記事があったので、この制限にはひっからなかったようです。
    (全部の指を使ってひいても10点なので遭遇しなかった)

  3. amy より:

    返信ありがとうございます。

    3つまで同時押しをできるようにしたかったのですが、
    このエラーのせいで、困っていおり、質問しました。

    先ほど、私も調べましたが、iPhone が認識するマルチタッチの最大数は5みたいなので、
    エラーは仕様の可能性が大ですね。

    ただ、試しにiPhone版のおんぷちゃんの方(先ほどDLしました^^)で、
    同時押しをしてみましたが、特に問題ないようなので、
    私のプログラムが何か悪いだけのかもしれません^^;

  4. amy より:

    すいません。

    どうやら、6つ目のタッチでエラーが発生した時、
    highlighted を NOにする処理をしていなかったのが原因でした^^;
    highlighted がずっと YES状態になってただけです。

    6つ目がタッチされた時、touchescancelledが呼び出されるので、そこでhighlighted を NOすれば良かっただけです。
    お騒がせしました。

Message

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

このサイトはスパムを低減するために Akismet を使っています。コメントデータの処理方法の詳細はこちらをご覧ください

Wi-Fi6Eルータ TP-Link AXE5400購入

Wi-Fi6E を試してみたくなり、TP-Link AXE5

児童手当 認定請求書申請 2024 「請求者が養育をする18歳に達する日以降の最初の3月31日までの子の数」とは?

2024年に受給していない人には手紙が届くらしい。 電子申請も

Vision Proアプリ開発本 8/24、8/26に発売

Vision Proアプリ開発入門 P400が 8/24 に発売、V

Developer Strap が日本でも購入可能に

USアカウントでしか購入できなかった Vision Pro 用 De

Vision Pro カバーケースを買ってみた

[itemlink post_id="11629"]

→もっと見る

PAGE TOP ↑