Flutter-제스처 소개

제스처 는 주로 사용자가 모바일 (또는 모든 터치 기반 장치) 애플리케이션과 상호 작용하는 방법입니다. 제스처는 일반적으로 모바일 장치의 특정 제어를 활성화하려는 의도로 사용자의 물리적 동작 / 움직임으로 정의됩니다. 제스처는 모바일 장치의 화면을 탭하여 게임 응용 프로그램에 사용되는 더 복잡한 동작으로 간단합니다.

널리 사용되는 제스처 중 일부가 여기에 언급되어 있습니다.

  • Tap − 손가락 끝으로 장치 표면을 잠시 터치 한 후 손가락 끝을 뗍니다.

  • Double Tap − 짧은 시간에 두 번 두드리기.

  • Drag − 손가락 끝으로 장치 표면을 터치 한 다음 손가락 끝을 안정적으로 움직 인 다음 마지막으로 손가락 끝을 뗍니다.

  • Flick − 드래그와 유사하지만 더 빠른 방식으로 수행합니다.

  • Pinch − 두 손가락을 사용하여 장치 표면을 꼬집습니다.

  • Spread/Zoom − 꼬집음의 반대.

  • Panning − 손가락 끝으로 장치 표면을 터치하고 손가락 끝을 떼지 않고 어떤 방향 으로든 움직입니다.

Flutter는 독점 위젯을 통해 모든 유형의 제스처에 대한 탁월한 지원을 제공합니다. GestureDetector. GestureDetector는 주로 사용자의 제스처를 감지하는 데 사용되는 비 시각적 위젯입니다. 위젯을 대상으로하는 제스처를 식별하기 위해 위젯을 GestureDetector 위젯 내에 배치 할 수 있습니다. GestureDetector는 제스처를 캡처하고 제스처를 기반으로 여러 이벤트를 전달합니다.

일부 제스처와 해당 이벤트는 다음과 같습니다.

  • Tap
    • onTapDown
    • onTapUp
    • onTap
    • onTapCancel
  • 두 번 탭
    • onDoubleTap
  • 길게 누르기
    • onLongPress
  • 수직 드래그
    • onVerticalDragStart
    • onVerticalDragUpdate
    • onVerticalDragEnd
  • 수평 드래그
    • onHorizontalDragStart
    • onHorizontalDragUpdate
    • onHorizontalDragEnd
  • Pan
    • onPanStart
    • onPanUpdate
    • onPanEnd

이제 제스처 감지 기능을 포함하도록 hello world 애플리케이션을 수정하고 개념을 이해해 보겠습니다.

  • 아래와 같이 MyHomePage 위젯 의 본문 내용을 변경하십시오.

body: Center( 
   child: GestureDetector( 
      onTap: () { 
         _showDialog(context); 
      }, 
      child: Text( 'Hello World', ) 
   ) 
),
  • 여기 에서 위젯 계층 구조의 Text 위젯 위에 GestureDetector 위젯 을 배치 하고 onTap 이벤트를 캡처 한 다음 마지막으로 대화 창을 표시했는지 확인합니다.

  • * _showDialog * 함수를 구현하여 사용자가 hello world 메시지 를 탭할 때 대화 상자를 표시 합니다. 일반 showDialogAlertDialog 위젯을 사용하여 새 대화 상자 위젯을 만듭니다. 코드는 다음과 같습니다.

// user defined function void _showDialog(BuildContext context) { 
   // flutter defined function 
   showDialog( 
      context: context, builder: (BuildContext context) { 
         // return object of type Dialog
         return AlertDialog( 
            title: new Text("Message"), 
            content: new Text("Hello World"),   
            actions: <Widget>[ 
               new FlatButton( 
                  child: new Text("Close"),  
                  onPressed: () {   
                     Navigator.of(context).pop();  
                  }, 
               ), 
            ], 
         ); 
      }, 
   ); 
}
  • 응용 프로그램은 Hot Reload 기능을 사용하여 장치에 다시로드됩니다. 이제 Hello World 메시지를 클릭하면 아래와 같은 대화 상자가 나타납니다.

  • 이제 대화 상자에서 닫기 옵션 을 클릭하여 대화 상자를 닫습니다 .

  • 전체 코드 (main.dart)는 다음과 같습니다.

import 'package:flutter/material.dart'; 
void main() => runApp(MyApp()); 

class MyApp extends StatelessWidget { 
   // This widget is the root of your application.    
   @override 
   Widget build(BuildContext context) {
      return MaterialApp(
         title: 'Hello World Demo Application', 
         theme: ThemeData( primarySwatch: Colors.blue,), 
         home: MyHomePage(title: 'Home page'), 
      ); 
   }
}
class MyHomePage extends StatelessWidget {
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
   
   // user defined function 
   void _showDialog(BuildContext context) { 
      // flutter defined function showDialog( 
         context: context, builder: (BuildContext context) { 
            // return object of type Dialog return AlertDialog(
               title: new Text("Message"), 
               content: new Text("Hello World"),   
               actions: <Widget>[
                  new FlatButton(
                     child: new Text("Close"), 
                     onPressed: () {   
                        Navigator.of(context).pop();  
                     }, 
                  ), 
               ],
            );
         },
      );
   }
   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(title: Text(this.title),),
         body: Center(
            child: GestureDetector( 
               onTap: () {
                  _showDialog(context);
               },
            child: Text( 'Hello World', )
            )
         ),
      );
   }
}

마지막으로 Flutter는 Listener 위젯을 통해 저수준 제스처 감지 메커니즘을 제공합니다 . 모든 사용자 상호 작용을 감지하고 다음 이벤트를 전달합니다.

  • PointerDownEvent
  • PointerMoveEvent
  • PointerUpEvent
  • PointerCancelEvent

Flutter는 특정 제스처와 고급 제스처를 수행 할 수있는 작은 위젯 세트도 제공합니다. 위젯은 다음과 같습니다.

  • Dismissible − 위젯을 닫는 제스처를 지원합니다.

  • Draggable − 위젯 이동을위한 드래그 제스처를 지원합니다.

  • LongPressDraggable − 상위 위젯도 드래그 할 수있는 경우 위젯을 이동하는 드래그 제스처를 지원합니다.

  • DragTarget드래그 가능한 위젯을 허용합니다.

  • IgnorePointer − 제스처 감지 프로세스에서 위젯과 그 자식을 숨 깁니다.

  • AbsorbPointer − 제스처 감지 프로세스 자체를 중지하므로 겹치는 위젯도 제스처 감지 프로세스에 참여할 수 없으므로 이벤트가 발생하지 않습니다.

  • Scrollable − 위젯 내에서 사용 가능한 콘텐츠 스크롤을 지원합니다.