Android - standardowa wysokość paska narzędzi


83

Chcę utworzyć pasek narzędzi w mojej aplikacji i zastanawiam się, jaka jest standardowa wysokość paska narzędzi w systemie Android?

Chcę, żeby był wystarczająco duży na palec, ale nie duży. Czy jest standardowy rozmiar?

Odpowiedzi:



35

Zalecany minimalny rozmiar elementów, które można dotykać, to 48 dp. Więcej szczegółowych danych można znaleźć na tej stronie .


40
@nrofis Sugerowałbym ustawienie następujących elementów w xml paska narzędzi android:minHeight="?attr/actionBarSize".
Jaison Brooks

2
czy nie powinien być mniejszy w trybie poziomym
Zapnologica

6

Oprócz odpowiedzi @ vedant1811 możesz programowo uzyskać actionBarSizez atrybutów:

TypedValue tv = new TypedValue();
if (context.getTheme().resolveAttribute(android.R.attr.actionBarSize, tv, true))
{
    actionBarHeight = TypedValue.complexToDimensionPixelSize(tv.data, context.getResources().getDisplayMetrics());
}

2

Możesz użyć następującej metody, aby programowo uzyskać wysokość AppBar

private static final int DEFAULT_TOOLBAR_HEIGHT = 56;

private static int toolBarHeight = -1;

public static int getToolBarHeight(Context context) {
        if (toolBarHeight > 0) {
            return toolBarHeight;
        }
        final Resources resources = context.getResources();
        final int resourceId = resources.getIdentifier("action_bar_size", "dimen", "android");
        toolBarHeight = resourceId > 0 ?
                resources.getDimensionPixelSize(resourceId) :
                (int) convertDpToPixel(DEFAULT_TOOLBAR_HEIGHT);
        return toolBarHeight;
    }

public static float convertDpToPixel(Context context, float dp) {
    float scale = context.getResources().getDisplayMetrics().density;
    return dp * scale + 0.5f;
}

2

W przypadku telefonów tak jest, 56dpa dla dużych urządzeń, takich jak tablety, które mają więcej miejsca, może to być64dp


1

możesz użyć widżetu paska narzędzi, który już istnieje w systemie Android i wstawić wysokość wrap_content, więc lepiej będzie uzyskać domyślny rozmiar, który jest z nim dołączony.

tutaj

<android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    android:background="@color/dark_cerulean">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:paddingEnd="16dp"
        android:paddingStart="16dp">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:layout_gravity="end"
        android:gravity="end"
        android:layout_marginEnd="16dp"
        android:textColor="@color/white"
        android:id="@+id/toolbar_title" />

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@drawable/image1"
            android:id="@+id/image"/>

    </LinearLayout>


</android.support.v7.widget.Toolbar>
Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.