'전체 글'에 해당되는 글 171건

  1. 2013.03.11 [android] GCM을 이용해서 push 구현및 browser로 동작하는 방법 5
  2. 2013.03.08 [Android] Eclipse Juno에서 xml 파일 전환시 느릴때 & ini 튜닝정보
  3. 2013.03.07 [scalado] 상상중인 스마트폰 사진앱
  4. 2013.03.07 단말기에(주로 tablet) 설치된 library에 따라 동적으로 처리하기.
  5. 2013.03.07 Android Build Target 설정, AVD의 TargetName 설정 1

[android] GCM을 이용해서 push 구현및 browser로 동작하는 방법

android 2013. 3. 11. 19:10

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

작성일 : 2013-03-11

작성자 : hanburn

 

이 글은 아래의 page를 기초로 해서 작성 되었습니다.

http://developer.android.com/google/gcm/gcm.html

 

여기서는 간한하게 테스트를 위해서 third-party application server가 없이 진행 하도록 하겠습니다. 보통은 서버를 구성하여 push 메시지를 보내고, 전송 상태등을 조회할 수 있는 기능을 만들지만 여기는 GCM-client 위주로 기술하기 때문에 직접 web browser로 메시지를 보내도록 하겠습니다.

 

0. 용어정리  

Registration ID : 단말기를 GCM 서버에 등록하고 나서 받는 key . GCM 서버에서 단말기를 구분하는 값이다. Push 요청을 할 때 이 key를 보내서 특정 단말에만 push 가 가도록 할 수 있다.

Sender ID : 구글 API Console에서 프로젝트를 등록하고 나서 얻을수 있다. 의미상으로는 Sender ID는 메시지를 수신하는 안드로이드 앱을 구분하게 된다.  

Sender Auth Token : push 메시지 전송시(third-party 서버 또는 Browser) 메시지를 보내는 곳을 인증하기 위한 token.  아무나 GCM서버에 push를 보낼 수 없도록 하기 위한 인증장치

 

1. Enabling GCM

GCM을 사용하기 위해서는 Google API console에서 Sender ID를 발급 받아야 한다.

https://code.google.com/apis/console/

 

그림에서 주소창의 project 옆의 숫자가 project ID가 인데, GCM에서는 이 값을 Sender ID로 사용한다. 참고로 API console에서 여러 개의 Google API Project를 만들고 관리 할 수 있는데, 필자는 test_gcm 이라는 project를 만들어서 사용하였다. 복수의  project를 생성할 수 있고 project마다 ID가 독립적이 된다.

 

2. Android 클라이언트 - manifest.xml 파일

 

1. GCM은 안드로이드 2.2 이상에서 지원하므로 최소 버전을 설정해야 한다.

<uses-sdk android:minSdkVersion="8" android:targetSdkVersion="xx"/>

2. GCM 메시지를 받기 위한 permission을 정의 한다. “my_app_package”는 자신의 package ..

<permission android:name="my_app_package.permission.C2D_MESSAGE" android:protectionLevel="signature" />
<uses-permission android:name="my_app_package.permission.C2D_MESSAGE" />

3. 추가로 필요한 permisstion 추가

<!-- GCM messages 수신하기 위해서 -->
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<!-- 인터넷 접속 -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- 구글계정 접근 -->
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<!-- 메시지 수신하려면 절전모드로 가면 안됨 -->
<uses-permission android:name="android.permission.WAKE_LOCK" />

4. Broadcast Receiver 등록 ( gcm.jar 파일에 GCMBroadcastReceiver 라는클래스가 있음. )

<receiver android:name="com.google.android.gcm.GCMBroadcastReceiver" android:permission="com.google.android.c2dm.permission.SEND" >
 
<intent-filter>
   
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
   
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
   
<category android:name="my_app_package" />
 
</intent-filter>
</receiver>

5. Intent service 추가 ( gcm.jar 파일에 GCMIntentService 클래스 있음)

<service android:name=".GCMIntentService" />

 

4,5번에서 사용하는 클래스는 google에서 제공하는 gcm.jar 파일에 정의되어 있으므로 그냥 사용하는게 편하다. 기존 C2DM에서 GCM으로 마이그레이션하는 경우에는 그냥 Sender ID만 변경해 주면 된다.

 

 

3. Android 클라이언트 – GCM서버에 등록

단말기에서는 push를 받기 위해서 GCM서버에 단말기를 등록해야 한다. gcm.jar 파일을 이용하는 경우에는 아래처럼 간단하다.

GCMRegistrar.checkDevice(this);
GCMRegistrar.checkManifest(this);
final String regId = GCMRegistrar.getRegistrationId(this);
if (regId.equals("")) {
 
GCMRegistrar.register(this, SENDER_ID);
} else {
 
Log.v(TAG, "Already registered");
}

 

여기서 GCMRegistrar.register(this, SENDER_ID) 는 실제로는 아래와 같은 동작을 한다.

Intent registrationIntent = new Intent("com.google.android.c2dm.intent.REGISTER");
// sets the app name in the intent
registrationIntent
.putExtra("app", PendingIntent.getBroadcast(this, 0, new Intent(), 0));
registrationIntent
.putExtra("sender", senderID);
startService
(registrationIntent);

위 코드는 C2DM에서 사용하던 방법과 같다. gcm.jar GCM을 구현하는 코드가 정형화 되어 있어서 간단한 library 파일로 제공하는 것이다. 그래서 신규 개발시는 gcm.jar를 이용하면 편리하다.

 

GCM에 등록이 되면 callback으로 GCMIntentService onRegistered() 가 호출된다. 여기에 registrationId가 넘어온다.

 

GCMIntentService class에서 제공하는 다양한 callback 함수들을 아래와 같다. 이름만 보면 대충 언제 호출되는지 알 수 있다.

protected void onRegistered(Context context, String registrationId)

protected void onUnregistered(Context context, String registrationId)

protected void onMessage(Context context, Intent intent)

protected void onDeletedMessages(Context context, int total)

public void onError(Context context, String errorId)

protected boolean onRecoverableError(Context context, String errorId)

 

 

이제, 클라이언트 개발이 완료 되었으므로 실제로 test를 해서 잘 동작하는지 확인해 봐야 한다. GCM 서버는 아래의 url을 통해서 Broswer로 간단하게 테스트 할 수 있다. Browser에서 테스트할때 필요한 Authorization Key google API console에서 얻을 수 있다.

 

 

사진 보면 알겠지만, third-party Server를 사용할 경우에는 “Create new Server Key”를 눌러서 생성할수 있다. 위에서 얻은 키를 이용해서 아래처럼 호출하면 된다.

그리고 registration_ids는 앞에서 String regId = GCMRegistrar.getRegistrationId(this); 을 호출해서 얻은 값이다.

 

URL : https://android.googleapis.com/gcm/send.

Method : POST

Authorization: Key=xxxxx

Content-Type:application/json  

)

Content-Type:application/json
Authorization:key=AIzaSyB-1uEai2WiUapxCs2Q0GZYzPu7Udno5aA

{
 
"registration_ids" : ["APA91bHun4MxP5egoKMwt2KZFBaFUH-1RYqx..."],
 
"data" : {
   
...
 
},
}

 

POST로 호출해야 되므로 Chrome REST-CONSOLE 같은 것으로 전송을 테스트 해보면 된다.

 

보너스

GCM 샘플 소스 : 설치된 android SDK 경로에서 “Extras -> Google -> gcm->samples “ clientserver의 샘플 소스가 있다. Client 샘플은 registrationId를 서버로 전송하므로 해당 부분을 빼고 browser로 테스트 할 수 있도록 변경한 샘플을 첨부 하였다.

 gcm-demo-client.zip

 

 



:

[Android] Eclipse Juno에서 xml 파일 전환시 느릴때 & ini 튜닝정보

개발 2013. 3. 8. 11:29

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

작성일 : 2013-03-07

작성자 : hanburn

 

Eclipse Juno 버전으로 android를 개발하는데, android 리소스 파일인 xml 파일을 열면 시간이 세월아..

좀 짜증이 나던차에 google에서 ADT를 새롭게 배포하고 있더라.

받아서 써보니 뭔가 android 개발에 최적화를 시켜 놓은것 같다. 그러나 Juno base로 개발된것이라서 동일한 문제가 발생하고 있다.

 

1. Juno SR1 patches

1) Help -> Install New Software

2) Select this repository: http://download.eclipse.org/eclipse/updates/4.2

3) Expand Juno SR1 Patches and install Eclipse UI Juno SR1 Optimizations

 

2. ini 파일 튜닝

정리가 잘된 곳이 있어서 링크로 대체

http://www.slipp.net/wiki/pages/viewpage.action?pageId=5177633#Eclipse성능개선최적화-eclipseini설정

 

 

 



:

[scalado] 상상중인 스마트폰 사진앱

IT활용 2013. 3. 7. 17:27

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

 

 

2012 MWC 에서 소개되어서 이미 아시는 분도 있을것 같지만.. 아이디어가 좋아서 공유합니다.

2012년에 발표되었지만, 아이디어가 너무 좋아서 그런지 아직 출시는 하나도 안되었네요 ^^;

 

 

scalado Rewind :  일정 시간동안 사진(동영상)을 찍고 동영상에서 원하는 표정을 선택할수 있음.

 

scalado - Remove : 사진의 배경을 clear 하게 지워주네요.  

  

scalado 3D : 사진으로 3D를 만들고, 3D를 자이로센서를 이용해서 보기 



:

단말기에(주로 tablet) 설치된 library에 따라 동적으로 처리하기.

android 2013. 3. 7. 13:46

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

작성일 : 2013-03-07

작성자 : hanburn

 

안드로이드의 단말기는 참 다양한걸 체감한다. 일본에서 판매되는 LuvPad 라는 안드로이드 타블렛이 있는데, 이 단말기는 google library 가 탑재되어 있지 않다. 모두 알고 있는 것이지만 구글에서 인증받지 않은 단말기는 구글 모듈( 구글 Play, 구글지도등)의 기본 앱들이 설치되어 있지 않다.

앱을 개발하다보면, 위처럼 여러 단말을 고려해서 개발을 해야 하므로 설치는 모두 가능하고 하하 실행할 때 동적으로 단말기에 해당 기능이 있는지 체크해서 처리하면 좋을 것이다.

 

간단한 구글지도를 예로 들어서 설명하겠다.

일단 모두 설치되도록 하려면 AndroidManifest.xml 파일에서 아래처럼 false로 되어 있는지 확인한다.

<uses-library android:name="com.google.android.maps" android:required="false"/>

 

다음으로는 실행되는 순간에 구글지도기능이 있는지 체크해야 한다.  간단하게 아래와 같은 함수를 하나 만들었다.

public boolean hasSystemSharedLibraryInstalled(Context ctx, String libraryName) {

           boolean hasLibraryInstalled = false;

           if (!TextUtils.isEmpty(libraryName)) {

               String[] installedLibraries = ctx.getPackageManager().getSystemSharedLibraryNames();

               if (installedLibraries != null) {

                   for (String s : installedLibraries) {

                       if (libraryName.equals(s)) {

                           hasLibraryInstalled = true;

                           break;

                       }

                   }

               }

           }

           return hasLibraryInstalled;

       }

 

구글지도는 MapActivity를 이용하므로 해당 Activity를 시작하기 전에 아래처럼 체크하면 된다.

hasSystemSharedLibraryInstalled(context, “com.google.android.maps”);

 

 

아래는 getSystemSharedLibraryNames 함수를 이용해서 AVD 개발폰에서 해당정보를 추출해봤다.

  

AVD에 설치된 목록 (android - 4.0 library  API level 14 )

android.test.runner

com.android.location.provider

javax.obex

정말 간단하다.

 

AVD에 설치된 목록 (Google APIs – 4.2 level 17 )

android.test.runner

javax.obex

com.google.android.media.effects

com.google.android.maps

com.android.future.usb.accessory

com.android.location.provider

 Map과 위치정보 제공자 모듈이 추가로 들어있는 것을 알수 있다.

 

HTC desire에 설치된 목록 ( android 2.3 )

com.ecrio.sip

com.htc.transcoder

javax.obex

com.android.future.usb.accessory

com.htc.htcSceneManager

com.htc.framework

android.test.runner

com.htc.android.pimlib

com.htc.lockscreen.fusion

com.scalado.util.ScaladoUtil  -> MWC 2012때 전시된 스칼라도의 라이브러리를 사용했나 ㅋ ?

com.htc.android.easopen

com.google.translate

com.htc.sunny2

com.htc.fusion.fx

com.orange.authentication.simcard

com.google.android.maps

com.android.location.provider

com.htc.android.rosie

~ 정말 많은 것들이 있네~ 

com.htc.xxx 모듈은 제조사에서 android를 커스터마이징하면서 추가한 기능들 같아 보이고,

그외 third-party 의 모듈로 추정되는 것들도 보이네요.

 

 



:

Android Build Target 설정, AVD의 TargetName 설정

android 2013. 3. 7. 13:02

336x280(권장), 300x250(권장), 250x250, 200x200 크기의 광고 코드만 넣을 수 있습니다.

 날짜 : 2013-03-07

작성자 : hanburn

AVD manager에서 AVD를 생성할 때 Target Name을 설정하게 되는데 이것은 무엇을 선택하는 것일까?

 

아래의 그림처럼 API level 별로 2가지 계열로 구분된다 

 

하나는 “Android 4.0 – API level 14”처럼 순수하게 안드로이드 라이브러리(anroid.jar) 파일만 포함된 AVD를 생성하는 것이고, 다른 하나는 “Google APIs(Google Inc.) – API leve 14” 처럼 안드로이드( android.jar ) + 구글 ( maps.jar, usb.jar ) 을 선택할수 있다. 즉 구글계열을 선택하면 구글에서 제공하는 기능들이 포함되게 된다. 구글에서 제공하는 Add-on 기능의 대표적인 기능은 구글 지도가 있다.

 

구글계열을 선택해서 아래 그림처럼 추가로 Maps앱이 추가되어 있다.

  

안드로이드를 개발할 때 프로젝트의 properties에서도 선택할수 있다. 구글 지도기능을 넣을때는 꼭 구글계열의 선택하야 한다. 만약 빌드해서 실행시킬 때 “INSTALL_FAILED_MISSING_SHARED_LIBRARY” 메시지가 뜯다면 프로젝트의 라이브러리와 AVD의 라이브러리가 맞지 않기 때문이다. 이때는 잘 맞춰주면 된다.

이것 말고 또 다른 것은 뭐가 있을까?

 

 



: