[SwiftUI] MagnificationGesture による画像のピンチイン、ピンチアウト

画像を拡大・縮小するにはMagnificationGestureを使うと可能です。Gestureを使うのでピンチイン・ピンチアウトになります。

Xcode 13.4.1

MagnificationGesture

 
最初に、MagnificationGesture にサンプルコードがあるのでそのまま実装してみます。

これを実行してみると、updatingを使っているのでGesture後の状態は保持されず元に戻ります。gestureが終わればリセットするという説明です

 
確かにピンチイン・ピンチアウトができるのですが、これでは画像を拡大縮小したままにはできないので他の機能を使います。
 

 

Callbacks

 
MagnificationGestureで使うCallbackのスペックで、画像を拡大縮小させつつ表示するにはonChangedが使えます。

updating: Gestureが変化したときにgesture state propertyをアップデートする、ただし値は保持されない

onChanged:Gestureが変化したときに実行するアクションを追加

onEnded:Gestureが終わった時のアクションを追加

MagnificationGesture.Value:Gestureの変化の値, CGFloat

 

画像の拡大

 
Gestureを使う前に、
画像を拡大するにはImageのサイズ変更を反映させる必要があるため、中間的に
resizableとscaleEffectを使います。

  • resizable: リサイズ可能なスペースにフィットするようにモードを設定
  • scaleEffect: 指定された垂直および水平のサイズでスケーリング

適当な画像を(sample_img@2x.jpg) Assets.xcassets に配置

ここではボタンでスケーリングさせることを確認します

 
ボタンをタップすることでサイズが増加していきました
 

 

サンプルコード

 
ボタンを使ってサイズを変化させたところをGestureを使います。

ContentView

 

PreviewやSimulatorで確認するときは(option) キーを押しながらマウスを操作するとピンチイン、ピンチアウトが確認できます。あるいは実機
 

 
 
References:
Gestures | Apple Developer Documentation
MagnificationGesture – SwiftUI | Apple Developer
MagnificationGesture – SwiftUI | Apple Developer
onChanged(_:) – MagnificationGesture | Apple Developer
onEnded(_:) – MagnificationGesture | Apple Developer
Image – SwiftUI | Apple Developer Documentation
scaleEffect(_:anchor:) – SecureField | Apple Developer
resizable(capInsets:resizingMode:) – Apple Developer



一人でアプリ開発の限界を感じたら

アプリ開発を始めたけどわからないところがあり、誰かに聞きたいけど周りにはそんな人はいない…あるいは、会社で働いていて日中そんなに時間をとれないなど、オンライン・スクールがいいと思います。


TECH ACADEMY
iPhoneアプリコース


こういうものではアプリ作れないと言う意見もありますが、それは結局本人のやる気があるかないかです。やる気があっても独学では突破しにくいところは教えてもらうのが一番早い。


侍エンジニア塾
侍エンジニア塾 無料体験レッスン




誤字脱字、意味不明などのご意見は 謙: e-mail まで
ブックマークしておくと便利です このエントリーをはてなブックマークに追加
Twitter:


シェアする

  • このエントリーをはてなブックマークに追加

フォローする