회원가입아이디/비번찾기
홈으로

Service & Notification(알림바띄우기) 이용하기
7년 전
Service
서비스는 백그라운드에서 작동하며 Content Provider 를 업데이트하거나 인텐트를 실행시키거나 Notification(알림)을
실행시키는 등의 여러가지 작업을 자동으로 수행하는 작업을 뜻한다. 하지만 기본적으로 ANR을 막기 위해서 돌아가는
쓰레드의 개념이 아니라 같은 프로세스 안에서 실행되는 개념이다.

(1) 작성과 실행
  Service 클래스를 상속받고, onCreate(서비스가 만들어졌을 경우 실행될 로직 작성),
  onBind(AIDL 이용시 필요) 메소드를 오버라이딩한다.

  <1> onStartCommand 의 오버라이딩과 return
   부가적으로 대부분 onStartCommand 메소드의 오버라이딩이 필요한데 이 메소드를 통해서 startService 메소드
   호출시의 작동 방식을 정의할 수 있다.(2.0 이전은 onStart()에 구현했었다.)
   - START_STICKY : 일반적인 경우 이 값을 리턴하게 되고, 실행도중 서비스가 종료됐다가 다시 시작시
    onStartCommand 메소드가 계속 실행되게 된다.
   - START_NOT_STICKY
   - START_REDELIVER_INTENT

  <2> AndroidManifest.xml 에 설정
            <service android:name="AIDLService">
                <intent-filter>
                    <action android:name="com.kh.service.AIDL" />
                </intent-filter>
            </service>

  <3> 해당서비스를 실행시키고 싶을때 startService(intent)를 통해서 실행하는 것이 가능하다.
         이때 외부 프로그램에서도 실행이 가능한데 이때는 intent에 Action을 intent-filter에 지정했던 action으로
         지정함으로서 외부에서도 서비스를 호출하는 것이 가능하게 된다.


참고 사이트
http://developer.android.com/guide/topics/ui/notifiers/notifications.html - 알림바 띄우기

사용 예제
package com.example.serviceapp;

import android.app.*;
import android.content.*;
import android.os.*;
import android.support.v4.app.*;
import android.support.v4.app.NotificationCompat.*;
import android.util.*;
import android.widget.*;

public class TimeService extends Service {

      @Override
      public IBinder onBind(Intent intent) {
            return null;
      }
    
      @Override
      public void onCreate() {
            Log.d("service","onCreate 실행");
      }

      @Override
      public void onDestroy() {
            Log.d("service","onDestroy 실행");
            mRunning = false;
      }
    
    
      private Handler mHandler = new Handler() {
            public void handleMessage(Message msg) {
//               switch(msg.what) {}
//               Toast.makeText(getApplicationContext(), "알림!", 0).show();
                  NotificationManager manager =
                             (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
                
                  NotificationCompat.Builder builder =
                            new NotificationCompat.Builder(TimeService.this);
                  builder.setSmallIcon(R.drawable.ic_launcher)
                             .setContentTitle("알립니다")
                             .setContentText("왔다네~왔다네~ 내~가 왔다네~")
                             .setAutoCancel(true) // 알림바에서 자동 삭제
                             .setVibrate(new long[]{1000,2000,1000,3000,1000,4000});
                             // autoCancel : 한번 누르면 알림바에서 사라진다.
                             // vibrate : 쉬고, 울리고, 쉬고, 울리고... 밀리세컨
                             // 진동이 되려면 AndroidManifest.xml에 진동 권한을 줘야 한다.
                
                  // 알람 클릭시 MainActivity를 화면에 띄운다.
                  Intent intent = new Intent(getApplicationContext(),MainActivity.class);
                  PendingIntent pIntent = PendingIntent.getActivity(getApplicationContext()
                             , 0
                             , intent
                             , Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT);
                  builder.setContentIntent(pIntent);
                  manager.notify(1, builder.build());
            };
      };
      protected boolean mRunning;
    
    
      // 제일 중요한 메서드! (서비스 작동내용을 넣어준다.)
      @Override
      public int onStartCommand(Intent intent, int flags, int startId) {
            Log.d("service","onStartCommand 실행");
            final int time = intent.getIntExtra("time", 0);
//          Toast.makeText(this, "안녕~ 난 서비스 : "+time, 0).show();
          
            // handler 통한 Thread 이용
            new Thread(new Runnable() {

                  @Override
                  public void run() {
                        mRunning = true;
                        while(mRunning) {
                             SystemClock.sleep(time*1000);
                             mHandler.sendEmptyMessage(0);
                        }
                  }
                
            }).start();
          
          
            return START_STICKY_COMPATIBILITY;
      }
}
추천추천 : 215 추천 목록
번호 제목
1,346
윈도우 서버 2019 취약점 점검 보안
1,345
윈도우 서버 2019 취약점 점검 보안 (windows server 2019)
1,344
Windows 취약점진단 보안가이드라인
1,343
Windows Admin Center를 통한 서버 관리
1,342
윈도우 서버에서 실행되는 서비스 확인
1,341
Chrome NET::ERR CERT REVOKED 해결방법
1,340
cmd 명령어 (명령 프롬프트 명령어) 모음
1,339
Windows10 특정 프로그램(OCS 2007 R2)에서 첨부파일 드래그앤드롭이 안 되는 현상
1,338
윈도우 로그, 관리 이벤트 삭제
1,337
클린 부팅
1,336
Windows 구성 요소 저장소에서 파일 손상 검사
1,335
Windows Defender 검사 기록 삭제하기
1,334
간단한 윈도우 10 정품 인증 (크랙프로그램 필요없음)
1,333
오류난 폴더 강제삭제 방법
1,332
크롬에서 플래시 항상 허용하도록 설정하기 (레지스트리) reg 파일 만들기
1,331
GPT 디스크를 MBR 디스크로 변환
1,330
MBR 디스크를 GPT 디스크로 변환
1,329
구글 검색을 200% 활용하게 해주는 검색 명령어 총정리
1,328
[Jquery] jQuery로 우클릭 방지, 드래그 방지, 선택 방지 (IE10, 파이어폭스, 크롬 확인)
1,327
php 사용자 접속IP, 브라우저정보, os정보, http, https 접속프로토콜 알아오기
1,326
[PHP] IE 브라우저 접속 검출하기
1,325
윈도우10 시스템 예약 파티션 확인 및 삭제
1,324
윈도우10 복구 파티션 삭제 방법
1,323
윈도우10 부팅지연 검은화면에서 몇분간 머무는 현상 해결방법
1,322
삼성노트북 바이오스 진입이 불가능한 경우 바이오스 재설치와 NVRAM 초기화
1,321
익스플로러(IE)의 구글 검색공급자 한글로 변경 방법
1,320
윈도우 10 기본 앱 삭제 및 복구
1,319
meta 태그 http-equiv 설정방법과 차이점
1,318
구글(Google)검색에서 고급연산자를 이용하여 많은 정보를 얻는 방법
1,317
프로그램 없이 하드디스크 복사 및 백업하기
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright ⓒ musictrot All rights reserved.