DrawerLayout이랑 위 상단바? 랑 한꺼번에 몽땅 넣어버렸는데 지효선생님 한 거 보니까 부분부분 나누더라구요,,
헷갈려서 일단 몽땅 한 코드 올릴게요!
<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout
xmlns:android="<http://schemas.android.com/apk/res/android>"
xmlns:app="<http://schemas.android.com/apk/res-auto>"
xmlns:tools="<http://schemas.android.com/tools>"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:id="@+id/drawer_layout"
tools:context=".StartActivity"
>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:background="#476BB3"
android:orientation="vertical">
<ImageButton
android:id="@+id/btn_open"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_margin="20dp"
android:background="#476BB3"
android:scaleType="fitCenter"
android:adjustViewBounds="true"
android:src="@drawable/ic_navigate"
/>
<ImageView
android:id="@+id/l"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_margin="10dp"
android:layout_centerHorizontal="true"
android:src="@drawable/airbts"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:text="Air BTS"
android:textColor="#fff"
android:textSize="25dp"
android:paddingBottom="10dp"
android:textStyle="bold"
android:layout_centerHorizontal="true"
android:layout_below="@+id/l"/>
</RelativeLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="20dp"
android:layout_marginRight="20dp"
android:orientation="horizontal">
<ImageView
android:layout_width="50dp"
android:layout_height="50dp"
android:layout_gravity="center_vertical"
android:src="@drawable/ic_swap" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="20dp"
android:layout_marginRight="20dp"
android:layout_marginTop="20dp"
android:background="@drawable/border"
android:orientation="vertical">
<EditText
android:id="@+id/여기_원래_스피너"
android:layout_width="280dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="10dp"
android:background="@drawable/edit"
android:drawablePadding="10dp"
android:hint="스피너"
android:inputType="text"
android:padding="15dp"
android:textColor="#476BB3" />
<EditText
android:id="@+id/map_textview_dst"
android:layout_width="280dp"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginTop="10dp"
android:background="@drawable/edit"
android:drawablePadding="10dp"
android:hint="도착지 입력"
android:inputType="text"
android:padding="15dp"
android:textColor="#476BB3" />
<Button
android:id="@+id/find"
android:layout_width="100dp"
android:layout_height="40dp"
android:layout_gravity="right"
android:layout_marginTop="10dp"
android:background="@drawable/button_login"
android:text="검색"
android:textColor="#fff" />
</LinearLayout>
</LinearLayout>
<TextView
android:id="@+id/result"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="TextView" />
</LinearLayout>
<include layout="@layout/activity_drawer"/>
</androidx.drawerlayout.widget.DrawerLayout>
drawer은 나중에 커스텀 할 것 같아서 일단 버튼만 만들어놨습니당
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="<http://schemas.android.com/apk/res/android>"
android:layout_width="280dp"
android:layout_height="match_parent"
xmlns:tools="<http://schemas.android.com/tools>"
android:layout_gravity="start"
android:orientation="vertical"
android:id="@+id/drawer"
android:background="#898989">
<Button
android:id="@+id/btn_close"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="메뉴 닫기"
/>
<Button
android:id="@+id/btn_go_Login"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="로그인 페이지"
/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:orientation="vertical">
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="테스트 메뉴"
android:gravity="center"/>
</LinearLayout>
</LinearLayout>
package com.find.bts;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.drawerlayout.widget.DrawerLayout;
import android.content.Intent;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.Button;
import android.widget.ImageButton;
public class StartActivity extends AppCompatActivity {
private DrawerLayout drawerLayout;
private View drawerView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_start);
// 네비게이션 바 관련한 부분
drawerLayout = (DrawerLayout)findViewById((R.id.drawer_layout));
drawerView = (View)findViewById(R.id.drawer);
ImageButton btn_open = (ImageButton)findViewById(R.id.btn_open);
btn_open.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
drawerLayout.openDrawer(drawerView);
}
});
Button btn_close = (Button)findViewById(R.id.btn_close);
btn_close.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
drawerLayout.closeDrawers();
}
});
drawerLayout.setDrawerListener(listener);
drawerView.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
return true;
}
});
// 찾기 버튼을 눌렀을 때
Button find = findViewById(R.id.find);
find.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(StartActivity.this, ShowResultMain.class);
startActivity(intent);
}
});
}
DrawerLayout.DrawerListener listener = new DrawerLayout.DrawerListener() {
@Override
public void onDrawerSlide(@NonNull View drawerView, float slideOffset) {
}
@Override
public void onDrawerOpened(@NonNull View drawerView) {
}
@Override
public void onDrawerClosed(@NonNull View drawerView) {
}
@Override
public void onDrawerStateChanged(int newState) {
}
};
}