Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- Image.network
- Load Image
- ListTile
- HTTP
- navigator
- Flutter 앱 배포
- Column Widget
- Networking
- node.js
- Hello World
- ListView.builder
- Scaffold
- Flutter Example
- sqlite
- Row
- Snackbar
- CrossAxisAlignment
- Row Widget
- Flutter Tutorial
- Flutter 강좌
- flutter
- Flutter 예제
- WillPopScope
- MainAxisAlignment
- AppBar
- listview
- Cached Image
- 반석천
- InkWell
- FutureBuilder
Archives
- Today
- Total
꿈꾸는 시스템 디자이너
AppWidget에서 View에 onClick 이벤트 처리 (setOnClickPendingIntent) 본문
Development/Android
AppWidget에서 View에 onClick 이벤트 처리 (setOnClickPendingIntent)
독행소년 2013. 8. 27. 14:42앞선 포스트(AppWidget에서의 View 제어)에서는 언급한 것과 같이 AppWidget에서는 각각의 View객체를 직접 생성해서 이용할 수 없으므로, remoteViews.setInt(View객체ID, "제어메소드명",제어값) 방식으로 View객체를 제어한다.
이 View 객체에 onClick 이벤트를 적용하기 위해서는 setOnClickPendingIntent() 메소드를 이용한다.
void android.widget.RemoteViews.setOnClickPendingIntent(int viewId, PendingIntent pendingIntent) |
일반적으로 아래와 같은 방식으로 이용한다.
remoteViews.setOnClickPendingIntent(R.id.rightButtonsRight, getPendingSelfIntent(context, moveToRightPage));
그리고 getPendingSelfIntent() 메소드의 구현은 아래와 같다.
// 클릭 이벤트 public PendingIntent getPendingSelfIntent(Context context, String action) { Intent intent = new Intent(context, MainWidget.class); intent.setAction(action); return PendingIntent.getBroadcast(context, 0, intent, 0); }
새로운 Intent 객체를 만들어 Action을 설정하고 브로드캐스트리시버를 연결하여 PendingIntent로 반환한다.
그럼 R.id.rightButtonsRight에 해당하는 버튼이 클릭되면 미리 연결했던 PendingIntenet가 호출된다. 이 인텐트가 AppWidget의 onReceiver()로 전달된다.
'Development > Android' 카테고리의 다른 글
AppWidget에서 ProgressDialog 사용법 (0) | 2013.09.10 |
---|---|
setOnClickPendingIntent를 가지는 AppWidget 예제 (0) | 2013.08.29 |
AppWidget에서의 View 제어 (0) | 2013.08.27 |
View 롤오버 처리(텍스트 색상, 배경 색상) (0) | 2013.08.07 |
프레그먼트(Fragment)간 통신(Communication) 예제 (0) | 2013.08.02 |
Comments