2014년 12월 4일 목요일

[android] 자바스크립트에서 함수 호출 및 자바스크립트 호출하기

[자바스크립트에서 안드로이드 함수 호출]

1. 인터페이스 클래스 생성
targetSdkVersion을 17이상이면 @JavascriptInterface를 꼭 추가해야한다.
추가하지 않으면 함수가 동작하지 않는다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class WebAppInterface {
    Context mContext;
    /** Instantiate the interface and set the context */
    WebAppInterface(Context c) {
        mContext = c;
    }
    /** Show a toast from the web page */
    @JavascriptInterface
    public void showToast(String toast) {
        Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show();
    }
}

2. 웹뷰 생성 및 인터페이스 등록



1
2
3
4
5
6
7
WebView webView = (WebView) findViewById(R.id.webview);
webView.addJavascriptInterface(new WebAppInterface(this), "Android");
WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true);
mWebView.loadUrl("file:///android_asset/testjavascript.html");


3. html파일에서 WebAppInterface클래스의 showToast함수 호출.


1
2
3
4
5
6
7
<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" />
<script type="text/javascript">
    function showAndroidToast(toast) {
        Android.showToast(toast);
    }
</script>


4. Say hello버튼을 누르게 되면 'Hello Android!라는 토스트 메시지를 띄우게 된다.


[안드로이드에서 자바스크립트 함수 호출]

1. 안드로이드에서 호출
WebView명.loadUrl("javascript:함수명()");


1
mWebView.loadUrl("javascript:setViewAndroid()");


2. html파일 자바스크립트 함수 생성


1
2
3
4
5
<script type="text/javascript">
    function setViewAndroid() {
        // 내용
    }
</script>


[proguard 적용시 제대로 작동하지 않는다면!?]

아래의 내용을 추가해보자.

1
2
3
-keepclassmembers class * {
    @android.webkit.JavascriptInterface <methods>;
}





[android] 고유값 생성하기.

UUID uuid = UUID.randomUUID();

2014년 12월 2일 화요일

[android] 폰과 태블릿 구분


1
2
3
4
5
6
7
8
9
10
boolean isTablet () { 
        int portrait_width_pixel=Math.min(this.getResources().getDisplayMetrics().widthPixels, this.getResources().getDisplayMetrics().heightPixels);
        int dots_per_virtual_inch=this.getResources().getDisplayMetrics().densityDpi;
        float virutal_width_inch=portrait_width_pixel/dots_per_virtual_inch;
        if (virutal_width_inch <= 2) {
            return false;
        } else {
           return true;
        }
    }


2014년 11월 18일 화요일

[android] textview에 이미지 넣기



setCompoundDrawablesWithIntrinsicBounds (int left, int top, int right, int bottom)

: 글씨의 왼쪽, 상단, 오른쪽, 아래에 이미지 추가 

setCompoundDrawablePadding (int pad)

: 이미지와 글씨 사이의 간격 설정

1
2
3
4
TextView txtEvent = (TextView)convertView.findViewById(R.id.cell_event);
txtEvent.setCompoundDrawablesWithIntrinsicBounds(R.drawable.event, 0, 0, 0);
txtEvent.setCompoundDrawablePadding(10);
txtEvent.setText("이벤트합니다.");

2014년 11월 13일 목요일

[android] 네트워크 상태가 변경 될 때 마다 실시간 확인 방법. (BroadcastReceiver 사용)

네트워크가 변경되었을 때 실시간으로 앱에서 하고 싶은 동작을 할 수 있다.

[AndroidManifest.xml]
activity와 동등한 단계에 추가.
1
2
3
4
5
<receiver android:name = "appNetwork">
        <intent-filter>
            <action android:name="android.net.conn.BACKGROUND_DATA_SETTING_CHANGED"/>
        </intent-filter>
</receiver>



[appNetwork.java]
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
31
32
33
34
35
36
37
38
39
40
public class appNetwork extends BroadcastReceiver {
    private Activity activity;
    
    public appNetwork() {
        super();
    }
    public appNetwork(Activity activity) {
        this.activity = activity;
    }
    @Override
    public void onReceive(Context context, Intent intent) {
        String action= intent.getAction();
        
        if (action.equals(ConnectivityManager.CONNECTIVITY_ACTION)) {
            try {
                ConnectivityManager connectivityManager = 
                        (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
                NetworkInfo activeNetInfo = connectivityManager.getActiveNetworkInfo();
                NetworkInfo _wifi_network = 
                        connectivityManager.getNetworkInfo(ConnectivityManager.TYPE_WIFI);
                if(_wifi_network != null) {
                     // wifi, 3g 둘 중 하나라도 있을 경우 
                    if(_wifi_network != null && activeNetInfo != null){
                    }
                    // wifi, 3g 둘 다 없을 경우 
                    else{
                    }
                }
            } catch (Exception e) {
                Log.i("ULNetworkReceiver", e.getMessage());
            }   
        }
    }
}



[java 파일]
1
2
3
IntentFilter filter = new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION);
appNetwork receiver = new appNetwork(this);
registerReceiver(receiver, filter);





참고 

2014년 11월 12일 수요일

[ android ] actionbar 높이 변경

styles.xml에 아래 내용 추가.
actionbar높이를 변경하면 tab까지 동일하게 변경됨.

<item name="android:attr/actionBarSize">40dp</item>

2014년 11월 10일 월요일

[android] viewpager PagerAdapter 새로고침



notifyDataSetChanged를 해도 refresh가 안될 때 PagerAdapter에 아래 내용 추가하면 되


1
2
3
4
@Override
    public int getItemPosition(Object item) {
        return POSITION_NONE;
    }



2014년 11월 5일 수요일

[android] fragment 에서 activity 함수 호출하기





Fragment ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// 3. ListFragment 에서 Activity 에 대한 참조
    OnSelectedListener mListener;
    
    // 1. ListFragment 내에 이벤트 인터페이스를 정의
    public interface OnSelectedListener {
        public void onDialogSelected();
    }
// 3.ListFragment 에서 Activity 에 대한 참조
    @Override
    public void onAttach(Activity activity) {
        super.onAttach(activity);
        try {
            mListener = (OnSelectedListener) activity;
        } catch (ClassCastException e) {
            throw new ClassCastException(activity.toString() + " must implement OnArticleSelectedListener");
        }
    }

[Activity]
1
2
3
4
// 2.Activity 에서 Fragment 의 이벤트 인터페이스를 구현
    public void onDialogSelected(){
        showDialog();
    }

ListFragment에서 호출을 원하는 곳에 다음과 같이 사용.
mListener.onDialogSelected(); 

implements fragment.OnSelectedListener 꼭 추가!!!!!!!
추가하지 않을 경우 RuntimeException 발생.

[android] java에서 resource 값 가져오기.


res/values/color.xml파일에 등록된 색상 값 가져오는 방법.


1
2
3
int colorRed = getResources().getColor(R.color.blue);
TextView txtTest = (TextView)findViewById(R.id.txt1);
txtTest.setTextColor(colorRed);

2014년 10월 30일 목요일

[android] AsyncTask 병렬 실행


new TestTask().execute(null,null,null); 
대신
new TestTask().executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
를 사용하면 병렬로 동작하여 하나씩 순차적으로 진행되던 것이 멀티로 가능해진다.

SERIAL_EXECUTOR : 직렬 <- API 11부터 default
THREAD_POOL_EXECUTOR : 병렬 


참고 : https://gist.github.com/benelog/5954649

2014년 10월 22일 수요일

[android] AsyncTask 사용법



android에서는 Main Thread가 UI Thread입니다. (UI관련된 작업은 UI Thread에서만 가능)
동시에 2가지 이상의 할 일이 생겼을때 사용할 수 있는 방법에 대해 설명해드리겠습니다.
1. thread를 생성하여 handler로 Main Thread와 소통할 수 있도록 해주는 방법
2. AsyncTask(Asynchronous Task)를 사용하는 방법

저는 간단하고 쉽게 사용할 수 있는 AsyncTask의 사용법에 대해 설명하겠습니다.
사용방법은 아래와 같습니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
private class TestTask extends AsyncTask <Void,Void,Void>{
        // background 호출 전에 먼저 호출
        @Override
        protected void onPreExecute(){
            bar.setVisibility(View.VISIBLE);
        }
        @Override
        protected Void doInBackground(Void... params) {   
            // background에서 실행될 부분 구현
        }
        protected void onProgressUpdate(Void... progress) {
           // 진행사항을 표시하는데 쓰임, 예)프로그래스바 
        }
    
        // background 호출 후에 호출
        @Override
        protected void onPostExecute(Void result) {
        }
    }

위와 같이 작성 한 후 실행.
1
new TestTask().execute(null, null, null);

[android] FragmentTransaction 사용하기.


replace(int containerViewId, Fragment fragment, String tag)
: container에 tag명으로 추가된 fragment를 삭제하고 동일한 tag명으로 fragment를 추가한다. 

: commit하기 전에 해당 함수를 호출하면 back 버튼을 눌렀을 때 이전 fragment로 이동할 수 있다.

1
2
3
4
5
        appTestListFragment newFragment = new appTestListFragment();        
        FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();
        transaction.replace(R.id.fragment_container,newFragment,"first");
        transaction.addToBackStack(null);
        transaction.commit();

[android] PreferenceActivity 설정 화면 구현하기


PreferenceActivity를 이용해 설정 화면을 간단하게 구현 할 수 있는 방법.

왼쪽과 같은 화면을 구현한 예제.

1. File > New > Other > Android > Android XML File 선택      > Next











2. 그림과 같이 선택.
Resource Type: Preference
File : File 이름 작성 ex)appsetting.xml
Root Element: PreferenceScreen

3. finish를 하면 res/xml/appsetting.xml파일이 생성된 것을 볼 수 있다.











4. Add... 버튼 선택

5. 앱버전, 문의하기와 같이 카테고리를 작성하기 위해서는 PreferenceCategory 를 선택.

6. key 와 Title 작성.
    key : keycateappversion
    Title : 앱버전

7. 안의 3.0.6을 만들기 위해 다시 Add... 선택

8. 이번엔 Preference 선택.

9. key 와 Title 작성.
    key : keyappversion
    Title : 3.0.6

10. 다른 것도 위와 같은 식으로 하면 아래와 같이 작성 된다.
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
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android" >
    <PreferenceCategory
        android:key="keycateappversion"
        android:title="앱버전" >
        <Preference
            android:key="keyappversion"
            android:title="3.0.6" />
    </PreferenceCategory>
    <Preference
        android:key="keyagree"
        android:title="약관 및 취급방침" />
    <PreferenceCategory
        android:key="keycatehelp"
        android:title="문의하기" >
        <Preference
            android:key="keyhelp"
            android:title="도움말" />
        <Preference
            android:key="keycontact"
            android:title="고객센터" />
    </PreferenceCategory>
</PreferenceScreen>

11. 이제 java class를 만들어보자.
      File > New > class > superclass: 의 Browse...선택 >
     Choose a type: preference 작성 > PreferenceActivity 선택 >
     Name 작성 > OK >

12. 생성된 java파일의 oncreate에 addPreferencesFromResource(R.xml.appsetting); 작성

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
31
public class appSetting extends PreferenceActivity implements OnPreferenceClickListener{
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
 
        addPreferencesFromResource(R.xml.setting);
        getActionBar().setTitle("설정");
        
        Preference pAppName = (Preference)findPreference("keyhelp");
        Preference pAppVersion = (Preference)findPreference("keycontact");
 
        pAppName.setOnPreferenceClickListener(this);
        pAppVersion.setOnPreferenceClickListener(this);
    }
 
    @Override
    public boolean onPreferenceClick(Preference preference)
    {
        // 도움말 선택시 
        if(preference.getKey().equals("keyhelp"))
        {
            Intent intent = new Intent(Setting.this, appHelp.class);
            startActivityForResult(intent, 0); 
        }
        else if(preference.getKey().equals("keycontact"))
        {
        }
        return false;
    }
}