반응형
test는 아래 기기에서 진행함.
samsung note 8 (android 9)
xiaomi redmi 9 (android 11)
대량의 텍스트를 사용하여 TextView에 스크롤이 생기게해서 상단바, 하단바가 감춰지는 것을 테스트.
a_text.java
package com.norang.autoactionbar;
import androidx.annotation.NonNull;
import androidx.appcompat.app.ActionBar;
import androidx.appcompat.app.AppCompatActivity;
import androidx.appcompat.widget.Toolbar;
import android.annotation.SuppressLint;
import android.content.Intent;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.webkit.CookieManager;
import android.webkit.GeolocationPermissions;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.TextView;
import android.widget.Toast;
import com.google.android.material.badge.BadgeDrawable;
import com.google.android.material.bottomnavigation.BottomNavigationView;
import com.google.android.material.navigation.NavigationBarView;
public class a_text extends AppCompatActivity {
private String TAG = getClass().getSimpleName();
final Handler handler = new Handler();
private boolean isRedirected = false;
//BottomNavigationView
protected BottomNavigationView bottom_navigation;
protected TextView tvCount;
protected View badge;
//BottomNavigationView
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.a_atext);
initToolBar();
initBottomNavigator();
}
protected void initToolBar()
{
Toolbar toolbar = findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayUseLogoEnabled(true);
actionBar.setDisplayHomeAsUpEnabled(false); //뒤로가기
}
public void btnLogoClick(View view) {
Toast.makeText(getApplicationContext(), "logo click", Toast.LENGTH_SHORT).show();
}
private int count;
@Override
public boolean onCreateOptionsMenu(Menu menu)
{
count = 31;
MenuInflater menuInflater = getMenuInflater();
menuInflater.inflate(R.menu.up_navigation_menu, menu);
badge = menu.findItem(R.id.btnTb02).getActionView();
tvCount = (TextView) badge.findViewById(R.id.tvCount);
updateHotCount(count);
badge.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "badge click1", Toast.LENGTH_SHORT).show();
}
});
return true;
}
public void updateHotCount(final int new_hot_number) {
count = new_hot_number;
runOnUiThread(new Runnable() {
@Override
public void run() {
if (count == 0)
tvCount.setVisibility(View.GONE);
else {
tvCount.setVisibility(View.VISIBLE);
tvCount.setText(Integer.toString(count));
// supportInvalidateOptionsMenu();
}
}
});
}
@Override
public boolean onOptionsItemSelected (MenuItem item) {
Toast toast = Toast.makeText(getApplicationContext(), "", Toast.LENGTH_LONG);
switch (item.getItemId()) {
case R.id.btnTb01:
toast.setText("Select Menu1");
break;
case R.id.btnTb02:
toast.setText("Select Menu2");
break;
case R.id.btnTb03:
toast.setText("Select Menu3");
break;
}
toast.show();
return super.onOptionsItemSelected(item);
}
protected void initBottomNavigator()
{
bottom_navigation = findViewById(R.id.bottom_navigation);
bottom_navigation.setItemIconTintList(null);
bottom_navigation.setOnItemSelectedListener(new NavigationBarView.OnItemSelectedListener() {
@SuppressLint("NonConstantResourceId")
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
return false;
}
});
BadgeDrawable badge = bottom_navigation.getOrCreateBadge(R.id.page_1);
badge.setVisible(true);
// An icon only badge will be displayed unless a number is set:
badge.setNumber(99);
BadgeDrawable badge1 = bottom_navigation.getOrCreateBadge(R.id.page_2);
badge1.setVisible(true);
// An icon only badge will be displayed unless a number is set:
badge1.setNumber(999);
}
@Override
protected void onDestroy() {
super.onDestroy();
}
}
a_atext.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout 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"
tools:context=".a_text">
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
tools:ignore="MissingConstraints">
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/purple_200"
android:minHeight="?attr/actionBarSize"
android:theme="?attr/actionBarTheme"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_scrollFlags="scroll"
>
<ImageView
android:id="@+id/ivLogo"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:srcCompat="@drawable/ic_test03"
android:paddingRight="10dp"
android:onClick="btnLogoClick"
/>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/purple_200"
android:orientation="horizontal">
<androidx.constraintlayout.widget.Guideline
android:id="@+id/toolbar_hg_10"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.15" />
<androidx.constraintlayout.widget.Guideline
android:id="@+id/toolbar_hg_90"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.85" />
<TextView
android:id="@+id/toolBarTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="actionBar"
android:textColor="#FFFFFF"
android:textSize="18sp"
android:textStyle="bold"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.appcompat.widget.Toolbar>
</com.google.android.material.appbar.AppBarLayout>
<androidx.core.widget.NestedScrollView
android:id="@+id/nestedScrollView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fillViewport="true"
android:scrollbars="vertical"
tools:ignore="MissingConstraints,WebViewLayout">
<TextView
android:id="@+id/tv"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="@string/textaa"
android:scrollbars="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
/>
</androidx.core.widget.NestedScrollView>
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottom_navigation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
app:labelVisibilityMode="unlabeled"
app:menu="@menu/bottom_navigation_menu"
app:layout_behavior="com.google.android.material.behavior.HideBottomViewOnScrollBehavior"
tools:ignore="MissingConstraints" />
</androidx.coordinatorlayout.widget.CoordinatorLayout>
반응형
'Android' 카테고리의 다른 글
Android Naver map (111) | 2022.08.05 |
---|---|
android floating Action bar & Bottom Navigation View(5) (156) | 2022.08.02 |
android floating Action bar & Bottom Navigation View(3) (294) | 2022.08.01 |
android floating Action bar & Bottom Navigation View(2) (3) | 2022.07.22 |
android floating Action bar & Bottom Navigation View(1) (1) | 2022.07.16 |
댓글