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 사용하기.
: 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;
}
};
|
피드 구독하기:
글 (Atom)