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 메시지 를 탭할 때 대화 상자를 표시 합니다. 일반 showDialog 및 AlertDialog 위젯을 사용하여 새 대화 상자 위젯을 만듭니다. 코드는 다음과 같습니다.
// 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 − 위젯 내에서 사용 가능한 콘텐츠 스크롤을 지원합니다.