您的位置:首页 > 其它

Snackbar 的简单使用

2015-12-20 19:45 411 查看
在 Android Design Support Library 中有个
Snackbar 。

Snackbar 提供了一个类似于 Toast 的组件,该组件存在于屏幕的底部靠左边的位置,Snackbar 出现在屏幕上的所有其他元素之上,且只有一个只有一个可以同时显示。

Snackbar 的
setAction(CharSequence,
android.view.View.OnClickListener)。方法能够有点击事件,有些类似于 AlertDialog。


Snackbar 也可以自定义,其自定义方式和 Toast 类似 (自定义的 Toast 如前文:/article/10639755.html),只是 Snackbar
只显示在屏幕底部的左下角。

其效果如下:



首先添加支持库(其中design:23.1.1可修改):



content_main.xml :
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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:gravity="center_horizontal"
android:orientation="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context="com.crazy.androiddesigntest.MainActivity"
tools:showIn="@layout/activity_main">

<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Snackbar 默认的显示" />

<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Snackbar 自定义的显示"/>
</LinearLayout>


MainActivity.java :
package com.crazy.androiddesigntest;

import android.graphics.Color;
import android.os.Bundle;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Gravity;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

private Button button1, button2;
private Snackbar snackbar = null;
private Toast toast = null;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);

button1 = (Button)findViewById(R.id.button);
button2 = (Button)findViewById(R.id.button2);

button1.setOnClickListener(this);
button2.setOnClickListener(this);

}

@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.button:
buttonClick(v);
break;
case R.id.button2:
buttonClickTwo(v);
break;
}
}

private void buttonClick (View v){
Snackbar.make(v, "点击显示新的组件 Snackbar ", Snackbar.LENGTH_LONG)
.setAction("你还可以点击此处", new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(MainActivity.this,
"Toast的内容",Toast.LENGTH_SHORT).show();
}
}).show();
}

private void buttonClickTwo(View v){
snackbar = Snackbar.make(v, "自定义的 Snackbar", Snackbar.LENGTH_LONG);
LinearLayout layout = (LinearLayout) snackbar.getView();

ImageView image = new ImageView(this);
image.setImageResource(R.drawable.tools);

layout.addView(image, 0);
snackbar.setAction("点击此处", new View.OnClickListener() {
@Override
public void onClick(View v) {
clickForToast();
}
});
snackbar.show();
}

private void clickForToast(){
toast = new Toast(this);
toast.setGravity(Gravity.CENTER, 50, -100);

ImageView image = new ImageView(this);
image.setImageResource(R.drawable.tools);

LinearLayout ll = new LinearLayout(this);
ll.addView(image);

TextView textView = new TextView(this);
textView.setText("带图片的Toast显示");
textView.setTextSize(24);
textView.setTextColor(Color.RED);
ll.addView(textView);

// 设置 Toast 显示自定义 View
toast.setView(ll);
toast.setDuration(Toast.LENGTH_LONG);
toast.show();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: