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;
    }
}

2014년 10월 21일 화요일

[ android ] Contextual Action Bar (CAB)




- 길게 누르거나 체크박스를 체크하는 등의 동작을 했을 때 actionbar가 그림과 같이 컨텍스트 메뉴로 변하며 기능을 사용 할 수 있다.

- 왼쪽 상단의 버튼은 CAB를 종료하는 기능이다.

- 중복으로 선택하여 사용하기 위해 MultiChoiceModeListener를 사용했다.











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
41
42
43
44
45
46
47
48
49
50
51
52
53

        getListView().setChoiceMode(ListView.CHOICE_MODE_MULTIPLE_MODAL);
        getListView().setMultiChoiceModeListener(new AbsListView.MultiChoiceModeListener() {
           
           // 생성될 때
            @Override
            public boolean onCreateActionMode(ActionMode mode, Menu menu) {
                MenuInflater inflater = mode.getMenuInflater();
                inflater.inflate(R.menu.menu_contextual_list, menu);
                return true;
            }
            // 종료될 때
            @Override
            public void onDestroyActionMode(ActionMode mode) {
            }
            @Override
            public boolean onPrepareActionMode(ActionMode mode, Menu menu) {
                return false;
            }
           // 아이템을 선택 할 때    
            @Override
            public void onItemCheckedStateChanged(ActionMode mode, int position, long id, boolean checked) {
                //
                final int checkedCount = getListView().getCheckedItemCount();
                
                getListView().setSelected(true);
                mode.setTitle(checkedCount + "선택");
            }
           // actionbar menu를 선택 할때
            @Override
            public boolean onActionItemClicked(ActionMode mode, MenuItem item) {
                // Respond to clicks on the actions in the CAB
                switch (item.getItemId()) {
                    case R.id.menu_delete:
                        SparseBooleanArray selected = getListView().getCheckedItemPositions();
                        for (int i = (selected.size() - 1); i >= 0; i--) {
                            if (selected.valueAt(i)) {
                                m_arrList.remove(selected.keyAt(i)); 
                            }
                        }
                        mode.finish();
                        return true;
                    default:
                        return false;
                }
            }
        });

[ android ] searchview 사용하기.



res/menu/activity_main.xml
1
2
3
4
5
6
7
8
9
10
11
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:id="@+id/menu_search"
        android:actionViewClass="android.widget.SearchView"
        android:icon="@drawable/ic_action_search"
        android:orderInCategory="1"
        android:showAsAction="always"
        android:title="@string/menu_search"/>
</menu>



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
@Override
    public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
        inflater.inflate(R.menu.activity_main, menu); // 옵션메뉴 지정.
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB_MR2) {
            searchView = (SearchView) menu.findItem(R.id.menu_search).getActionView();
            searchView.setQueryHint("두 자 이상 입력하세요");            
            searchView.setOnQueryTextListener(queryTextListener);
            SearchManager searchManager = (SearchManager) getActivity().getSystemService(Context.SEARCH_SERVICE);
            if(null!=searchManager ) {   
                searchView.setSearchableInfo(searchManager.getSearchableInfo(getActivity().getComponentName()));
            }
              // 검색필드를 항상 표시하고싶을 경우false, 아이콘으로 보이고 싶을 경우 true
            searchView.setIconifiedByDefault(true);
        }
        return;
    }
    private OnQueryTextListener queryTextListener = new OnQueryTextListener() {
        @TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH)
        @Override
        public boolean onQueryTextSubmit(String query) {
            InputMethodManager imm= (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
            imm.hideSoftInputFromWindow(searchView.getWindowToken(), 0);
            searchView.setQuery("", false);
            searchView.setIconified(true);
            Toast.makeText(getActivity(), "search 결과", Toast.LENGTH_LONG).show();
            return false;
        }
        @Override
        public boolean onQueryTextChange(String newText) {
            // TODO Auto-generated method stub
            return false;
        }
    };