일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- UWP
- Java
- Django REST Android
- 프로그래머스
- C/C++
- kodility
- Kotlin
- 알고리즘
- Rxjava2
- FLUTTER
- dart
- C
- flutter firestore
- Django REST framework
- livedata
- android push
- Django REST
- 안드로이드 구글맵
- android architecture component
- RxAndroid
- mfc
- Python
- NDK
- 안드로이드
- C++
- Android P
- RxJava
- 코틀린
- Android
- Flutter TextField
- Today
- Total
개발하는 두더지
안드로이드 toolbar 중복 코드 지우기 본문
포스팅 이유
서비스 앱 개발이나 토이 프로젝트를 진행하면서 빠르게 초기 스켈레톤 구조를 구성하기 위해 포스팅을 합니다.
저는 아래와 같은 상황일 때 코드를 줄이기 위해 사용합니다.
1. ActionBar 대신 Toolbar를 사용할 때
2. Toolbar를 xml, activity 마다 정의해서 코드가 중복될 때
프로젝트 시작시 자주 쓰는 스켈레톤 구조
style.xml
Custom Toolbar를 사용하기 위해 기본 AppTheme을 NoActionBar로 적용
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
BaseActivity.java
BaseActivity를 상속받은 Activity들은 toolbar 이름, 뒤로가기 버튼이 활성화된다.
abstract public class BaseActivity extends AppCompatActivity {
private Toolbar toolbar;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(getLayoutResource());
configureToolbar();
}
protected abstract void initLayout();
protected abstract void setDefaultSettings();
protected abstract int getLayoutResource();
protected abstract int getTitleToolBar();
private void configureToolbar() {
toolbar = (Toolbar) findViewById(R.id.toolbar);
if (toolbar != null) {
setSupportActionBar(toolbar);
getSupportActionBar().setTitle(getTitleToolBar());
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
}
}
}
toolbar.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:minHeight="?attr/actionBarSize"
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
android:background="?attr/colorPrimary">
</android.support.v7.widget.Toolbar>
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto">
<!--Custom Toolbar-->
<include layout="@layout/toolbar" />
</android.support.constraint.ConstraintLayout>
MainActivity.java
onCreate에 setContentView(R.layout.activity_main); 이 BaseActivity로 이동함.
public class MainActivity extends BaseActivity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
initLayout();
setDefaultSettings();
}
@Override
protected void initLayout() {
//UI 초기화
}
@Override
protected void setDefaultSettings() {
//UI 외에 기본으로 설정되어야할 동작 초기화
}
@Override
protected int getLayoutResource() {
return R.layout.activity_main;
}
@Override
protected int getTitleToolBar() {
return R.string.app_name;
}
}
'Java,Android' 카테고리의 다른 글
[Android] DI, Dagger2 란? (0) | 2018.04.22 |
---|---|
[Android] DrawerLayout, NavigationView 사용하기 (1) | 2018.04.21 |
[Android] Dalvik , ART 란 ? (0) | 2017.12.18 |
[Android] ADB ( Android Debug Bridge ) 란? (0) | 2017.12.18 |
[Android] compileSdkVersion, targetSdkVersion 등 SDK 버전 설정 이해하기 (2) | 2017.12.08 |