Возможно ли иметь кнопку в Toast?
В теории, да, потому что вы можете создать пользовательский Toast из макета в XML, но я попытался поместить в него кнопку и не смог заставить его зарегистрировать клик. Кто-нибудь мог сделать что-то подобное?
Возможно ли иметь кнопку в Toast?
В теории, да, потому что вы можете создать пользовательский Toast из макета в XML, но я попытался поместить в него кнопку и не смог заставить его зарегистрировать клик. Кто-нибудь мог сделать что-то подобное?
Нельзя щелкнуть тост. Невозможно зафиксировать клик внутри сообщения тоста. Вам нужно будет создать для этого диалог. Посмотрите Создание диалоговых окон для получения дополнительной информации.
API в Toast состоянии класса, что тост никогда не получит фокус, и поскольку тост не является точкой зрения, нет onClick сообщение. Я бы предположил, что поэтому дети из Тоста не могут быть нажаты.
Тост не может содержать кнопку. За исключением того, что приложение gmail и приложение галереи в желе beans имеют полутост, содержащий кнопку, вот как это сделал Google.
https://gist.github.com/benvd/4090998
Я думаю, это отвечает на ваш вопрос.
Фрагмент показывает реализацию пользовательского Toast, который:
Toast
classDialog
(есть кнопки с кнопками, такие как приложение Gmail)length
в millis
Activity
Ограничения по току:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//...
View toastView = new View(getBaseContext());
//init your toast view
ActivityToast toast = new ActivityToast(this, toastView);
//set toast Gravity ( Gravity.BOTTOM | Gravity.FILL_HORIZONTAL by default)
toast.setGravity(Gravity.CENTER);
toast.setLength(10000); //set toast show duration to 10 seconds (2 seconds by default)
Animation showAnim; // init animation
Animation.AnimationListener showAnimListener; //init anim listener
toast.setShowAnimation(showAnim);
toast.setShowAnimationListener(showAnimListener);
Animation cancelAnim; // init animation
Animation.AnimationListener cancelAnimListener; //init anim listener
toast.setCancelAnimation(showAnim);
toast.setCancelAnimationListener(showAnimListener);
toast.show(); //show toast view
toast.isShowing(); // check if toast is showing now
toast.cancel(); //cancel toast view
toast.getView(); //get toast view to update it or to do something ..
}
import android.app.Activity;
import android.os.Handler;
import android.support.annotation.NonNull;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.widget.FrameLayout;
public class ActivityToast {
public static final long LENGTH_SHORT = 2000;
public static final long LENGTH_LONG = 3000;
public static final int DEFAULT_ANIMATION_DURATION = 400;
private final Activity mActivity;
private FrameLayout.LayoutParams mLayoutParams;
private Handler mHandler = new Handler();
private ViewGroup mParent;
private FrameLayout mToastHolder;
private View mToastView;
private Animation mShowAnimation;
private Animation mCancelAnimation;
private long mLength = LENGTH_SHORT;
private Animation.AnimationListener mShowAnimationListener;
private Animation.AnimationListener mCancelAnimationListener;
private boolean mIsAnimationRunning;
private boolean mIsShown;
/**
* @param activity Toast will be shown at top of the widow of this Activity
*/
public ActivityToast(@NonNull Activity activity, View toastView) {
mActivity = activity;
mParent = (ViewGroup) activity.getWindow().getDecorView();
mToastHolder = new FrameLayout(activity.getBaseContext());
mLayoutParams = new FrameLayout.LayoutParams(
ViewGroup.LayoutParams.WRAP_CONTENT,
ViewGroup.LayoutParams.WRAP_CONTENT,
Gravity.BOTTOM | Gravity.FILL_HORIZONTAL
);
mToastHolder.setLayoutParams(mLayoutParams);
mShowAnimation = new AlphaAnimation(0.0f, 1.0f);
mShowAnimation.setDuration(DEFAULT_ANIMATION_DURATION);
mShowAnimation.setAnimationListener(mHiddenShowListener);
mCancelAnimation = new AlphaAnimation(1.0f, 0.0f);
mCancelAnimation.setDuration(DEFAULT_ANIMATION_DURATION);
mCancelAnimation.setAnimationListener(mHiddenCancelListener);
mToastView = toastView;
mToastHolder.addView(mToastView);
mToastHolder.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent motionEvent) {
if (motionEvent.getAction() == MotionEvent.ACTION_DOWN) {
cancel();
}
return false;
}
});
}
public void show() {
if (!isShowing()) {
mParent.addView(mToastHolder);
mIsShown = true;
if (mShowAnimation != null) {
mToastHolder.startAnimation(mShowAnimation);
} else {
mHandler.postDelayed(mCancelTask, mLength);
}
}
}
public void cancel() {
if (isShowing() && !mIsAnimationRunning) {
if (mCancelAnimation != null) {
mToastHolder.startAnimation(mCancelAnimation);
} else {
mParent.removeView(mToastHolder);
mHandler.removeCallbacks(mCancelTask);
mIsShown = false;
}
}
}
public boolean isShowing() {
return mIsShown;
}
/**
* Pay attention that Action bars is the part of Activity window
*
* @param gravity Position of view in Activity window
*/
public void setGravity(int gravity) {
mLayoutParams.gravity = gravity;
if (isShowing()) {
mToastHolder.requestLayout();
}
}
public void setShowAnimation(Animation showAnimation) {
mShowAnimation = showAnimation;
}
public void setCancelAnimation(Animation cancelAnimation) {
mCancelAnimation = cancelAnimation;
}
/**
* @param cancelAnimationListener cancel toast animation. Note: you should use this instead of
* Animation.setOnAnimationListener();
*/
public void setCancelAnimationListener(Animation.AnimationListener cancelAnimationListener) {
mCancelAnimationListener = cancelAnimationListener;
}
/**
* @param showAnimationListener show toast animation. Note: you should use this instead of
* Animation.setOnAnimationListener();
*/
public void setShowAnimationListener(Animation.AnimationListener showAnimationListener) {
mShowAnimationListener = showAnimationListener;
}
public void setLength(long length) {
mLength = length;
}
public View getView() {
return mToastView;
}
private Runnable mCancelTask = new Runnable() {
@Override
public void run() {
cancel();
}
};
private Animation.AnimationListener mHiddenShowListener = new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
if (mShowAnimationListener != null) {
mShowAnimationListener.onAnimationStart(animation);
}
mIsAnimationRunning = true;
}
@Override
public void onAnimationEnd(Animation animation) {
mHandler.postDelayed(mCancelTask, mLength);
if (mShowAnimationListener != null) {
mShowAnimationListener.onAnimationEnd(animation);
}
mIsAnimationRunning = false;
}
@Override
public void onAnimationRepeat(Animation animation) {
if (mShowAnimationListener != null) {
mShowAnimationListener.onAnimationRepeat(animation);
}
}
};
private Animation.AnimationListener mHiddenCancelListener = new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
if (mCancelAnimationListener != null) {
mCancelAnimationListener.onAnimationStart(animation);
}
mIsAnimationRunning = true;
}
@Override
public void onAnimationEnd(Animation animation) {
mParent.removeView(mToastHolder);
mHandler.removeCallbacks(mCancelTask);
if (mCancelAnimationListener != null) {
mCancelAnimationListener.onAnimationEnd(animation);
}
mIsAnimationRunning = false;
mIsShown = false;
}
@Override
public void onAnimationRepeat(Animation animation) {
if (mCancelAnimationListener != null) {
mCancelAnimationListener.onAnimationRepeat(animation);
}
}
};
}
Мой оригинальный пост на github
Сообщение, которое показывает реализацию пользовательского макета в этом сообщении
Пользовательский вид, передаваемый тосту, может содержать что угодно; однако тосты не могут получать какие-либо сенсорные события, поэтому никакие компоненты, использующие сенсорные события, не будут работать в штоке торта (кнопки, радиокнопки и т.д.). Единственный выбор, который у вас есть, - создать пользовательское представление с помощью кнопки в нем и добавить его в макет. Существует много примеров того, как это сделать, и нескольких библиотек, которые вы можете проверить, чтобы узнать, как это делают другие люди.
UndoBar
MessageBar
Nurik UndoBar
Конечно, вы также можете использовать библиотеку SuperToasts, которую я собрал, но это может быть немного переполненным для одного использования. Способ, которым я это делаю, описан в классе SuperActivityToast.
В этом случае вы можете попробовать SuperToast. Он может создавать тосты с помощью кнопки. Он имеет пользовательскую функцию продолжительности, красочный фон, красочные шрифты, пользовательские шрифты, анимированный эффект. Надеюсь, вам понравится.
Используйте оповещение, если вы хотите добавить кнопку:-). вот несколько примеров Диалоговые окна в Android
Создание окна оверлея системы (всегда сверху)
Это говорит о том, что это можно сделать, мне также нужны кнопки в тосте, поэтому мне еще нужно сделать свою собственную реализацию. Если я найду больше, я добавлю его в свой пост
Вы должны использовать Snackbar
. Он находится в последней библиотеке поддержки Android (в момент ответа) и совместим со старыми уровнями api. Это намного проще реализовать, чем Dialog
или пользовательский View
и имеет возможность иметь кнопку в отличие от Toast
.
Android Support Library
из Extras
в SDK Manager
(версия 22.2.1 или новее).build.gradle
добавьте это в зависимости от класса: com.android.support:design:22.2.0
.Реализовать:
Snackbar.make(this.findViewById(android.R.id.content), "Toast Message", Snackbar.LENGTH_LONG)
.setAction("Click here to activate action", onClickListener)
.setActionTextColor(Color.RED)
.show;
И это все. Никакие проекты и реализация github не похожи на Toast
. Я использовал его в одном из моих проектов, и он отлично работает.