webentwicklung-frage-antwort-db.com.de

Android Multiline Snackbar

Ich versuche, das neue Snackbar aus der Android Design Support Library zu nutzen, um eine mehrzeilige Snackbar anzuzeigen, wie in http://www.google.com/design) gezeigt /spec/components/snackbars-toasts.html#snackbars-toasts-specs :

import Android.support.design.widget.Snackbar;

final String snack = "First line\nSecond line\nThird line";
Snackbar.make(mView, snack, Snackbar.LENGTH_LONG).show();

Es zeigt nur First line... auf meinem Nexus 7. Wie kann ich festlegen, dass alle Zeilen angezeigt werden?

PS: Ich habe Toast ausprobiert und es wurden alle Zeilen angezeigt.

75
Dima Kornilov

Setzen Sie einfach das maxLines Attribut von Snackbars Textview

View snackbarView = snackbar.getView();
TextView textView = (TextView) snackbarView.findViewById(Android.support.design.R.id.snackbar_text);
textView.setMaxLines(5);  // show multiple line
193
Nilesh Senta

Man kann den vordefinierten Wert in der values.xml der App überschreiben

<integer name="design_snackbar_text_max_lines">5</integer>

Dieser Wert wird standardmäßig von der Snackbar verwendet.

27
akd005
Snackbar snackbar =  Snackbar.make(view, "Text",Snackbar.LENGTH_LONG).setDuration(Snackbar.LENGTH_LONG);
View snackbarView = snackbar.getView();
TextView tv= (TextView) snackbarView.findViewById(Android.support.design.R.id.snackbar_text);
tv.setMaxLines(3); 
snackbar.show();
10
Ramesh R

Hier ist meine Erkenntnis dazu:

Android unterstützt zwar mehrzeilige Snackbars, es gibt jedoch eine Obergrenze von 2 Zeilen, die der Gestaltungsrichtlinie entspricht, nach der die Höhe des mehrzeiligen Snackbars 80 dpi (fast 2 Zeilen) betragen soll.

Um dies zu überprüfen, habe ich das Beispielprojekt cheesesquare Android verwendet. Wenn ich folgenden String verwende:

Snackbar.make(view, "Random Text \n When a second snackbar is triggered while the first is displayed", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();

In diesem Fall sehe ich die mehrzeilige Snackbar mit dem Text der 2. Zeile, d. H. "Wenn eine zweite Snackbar ausgelöst wird", aber wenn ich diesen Code in folgende Implementierung ändere:

Snackbar.make(view, "Random Text \n When \n a second snackbar is triggered while the first is displayed", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();

Ich kann nur den "Zufälligen Text\nWenn ..." sehen. Dies bedeutet, dass die Entwurfsbibliothek absichtlich eine Textansicht von maximal 2 Zeilen erzwingt.

10
mudit

Eine Alternative zu den Vorschlägen, bei denen die Ressourcen-ID für die in der Snackbar enthaltene Textansicht fest codiert wird, besteht darin, die Textansicht zu suchen. Auf lange Sicht ist dies sicherer und Sie können die Support-Bibliothek aktualisieren, ohne befürchten zu müssen, dass sich die ID ändert.

Beispiel:

 public static Snackbar getSnackbar(View rootView, String message, int duration) {
    Snackbar snackbar = Snackbar.make(rootView, message, duration);
    ViewGroup snackbarLayout = (ViewGroup) snackbar.getView();

    TextView text = null;

    for (int i = 0; i < snackbarLayout.getChildCount(); i++) {
        View child = snackbarLayout.getChildAt(i);

        // Since action is a button, and Button extends TextView,
        // Need to make sure this is the message TextView, not the 
        // action Button view.
        if(child instanceof TextView && !(child instanceof Button)) {
            text = (TextView) child;
        }
    }

    if (text != null) {
        text.setMaxLines(3);
    }
    return snackbar;
}
3
Chantell Osejo

Anstatt setMaxLines zu verwenden, verwende ich setSingleLine, um die Textansicht auf ihren Inhalt umbrechen zu lassen.

String yourText = "First line\nSecond line\nThird line";
Snackbar snackbar = Snackbar.make(mView, yourText, Snackbar.LENGTH_SHORT);
    TextView textView =
        (TextView) snackbar.getView().findViewById(Android.support.design.R.id.snackbar_text);
    textView.setSingleLine(false);
snackbar.show();
2
medhdj

das funktioniert bei mir

Snackbar snackbar =  Snackbar.make(mView, "Your text string", Snackbar.LENGTH_INDEFINITE);
((TextView) snackbar.getView().findViewById(Android.support.design.R.id.snackbar_text)).setSingleLine(false);
snackbar.show();
2
techSquats

Spät, aber vielleicht hilfreich für jemanden:

public void showSnackBar(String txt, View view){
    final Snackbar snackbar = Snackbar.make(view,txt,Snackbar.LENGTH_INDEFINITE)
        .setAction("OK", new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //do something
            }
        });
    View view = snackbar.getView();
    TextView textView = (TextView) view.findViewById(Android.support.design.R.id.snackbar_text);
    textView.setMaxLines(5);
    snackbar.show();
}
1
Adeeb karim

Eine Möglichkeit, die nicht abstürzt, falls sich in neueren Versionen der Bibliothek etwas ändert:

Snackbar.make(...).setAction(...) {
    ...
}.apply {
    (view.findViewById<View?>(R.id.snackbar_text) as? TextView?)?.setSingleLine(false)
}.show()

Und eine Möglichkeit, dies ohne Verwendung von IDs zu tun, indem alle TextViews in der Snackbar so eingestellt werden, dass sie unbegrenzt viele Zeilen enthalten:

@UiThread
fun setAllTextViewsToHaveInfiniteLinesCount(view: View) {
    when (view) {
        is TextView -> view.setSingleLine(false)
        is ViewGroup -> for (child in view.children)
            setAllTextViewsToHaveInfiniteLinesCount(child)
    }
}

Snackbar.make(...).setAction(...) {
    ...
}.apply {
    setAllTextViewsToHaveInfiniteLinesCount(view)
}.show()

Dieselbe Funktion in Java:

@UiThread
public static void setAllTextViewsToHaveInfiniteLines(@Nullable final View view) {
    if (view == null)
        return;
    if (view instanceof TextView)
        ((TextView) view).setSingleLine(false);
    else if (view instanceof ViewGroup)
        for (Iterator<View> iterator = ViewGroupKt.getChildren((ViewGroup) view).iterator(); iterator.hasNext(); )
            setAllTextViewsToHaveInfiniteLines(iterator.next());
}
1

Für Material Design lautet die Referenz com.google.Android.material.R.id.snackbar_text

val snack = Snackbar.make(myView, R.string.myLongText, Snackbar.LENGTH_INDEFINITE).apply {
                view.findViewById<TextView>(com.google.Android.material.R.id.snackbar_text).maxLines = 10
            }
            snack.show()
0
rmirabelle

In Kotlin können Sie einfach tun

Snackbar.make(rootView, "Yo!", Snackbar.LENGTH_LONG).apply {
    view.snackbar_text.setSingleLine(false)
    show()
}

Sie können setSingleLine(false) durch maxLines = 3 Ersetzen, wenn Sie möchten.

Android Studio sollte Sie zum Hinzufügen auffordern

import kotlinx.Android.synthetic.main.design_layout_snackbar_include.view.*
0
Gumby The Green