をお気軽に。私はこの同じ質問にいくつかの答えを追加しても、私はあなたにもっと明確になるために別の答えとしてこの答えを追加します。
その汚いUI、私はそれが非常にrushy準備。画面の下部にStackBar
が表示されますか? AlertDialog
のOK
ボタンをクリックすると表示されます
ここではどのように行っていますか。
次のコードは、コードがactivity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:id="@+id/rootView"
tools:context="com.stackoverflow.answer.androidcustomdialog.MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!" />
次のコードは、MainActivity.java
に属する属する以下
custom_dialog_layout.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ImageView
android:id="@+id/image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@mipmap/ic_launcher"/>
<TextView
android:id="@+id/text"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:textColor="@android:color/black"
android:text="Sample Test for Custom Dialog"
android:textSize="20sp"
android:layout_toRightOf="@+id/image"
android:layout_alignBottom="@+id/image" />/>
<Button
android:id="@+id/dialogButtonOK"
android:layout_width="100px"
android:layout_height="wrap_content"
android:text=" Ok "
android:layout_below="@+id/text"
android:layout_centerHorizontal="true" />
に属し
package com.stackoverflow.answer.androidcustomdialog;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final View rootView=(View)findViewById(R.id.rootView);
AlertDialog.Builder mAlertDialogBuilder = new AlertDialog.Builder(this);
// inflate the custom dialog view
LayoutInflater inflater=getLayoutInflater();
final View mDialogView = inflater.inflate(R.layout.custom_dialog_layout, null);
// set the View for the AlertDialog
mAlertDialogBuilder.setView(mDialogView);
Button btn = (Button) mDialogView.findViewById(R.id.dialogButtonOK);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
// Pass the RootView to the SnackBar
Snackbar
.make(rootView, "SnackBar in Dialog", Snackbar.LENGTH_LONG)
.show();
}
});
AlertDialog alertDialog = mAlertDialogBuilder.create();
alertDialog.show();
}
}
気軽にお気軽にお問い合わせください。この例では、フラグメントを使用していません。必要ならば私もそれを手伝うことができます。また、必要に応じてプロジェクトを送信することもできます。私にあなたの電子メールを送ってください:)
私が実際にしたことは、RooTレイアウトビューをSnackBar
に渡すだけです。そのような単純です。
もう一つ..
はGoogle Material Design Snackbars & Toasts Usageリファレンス
による配置
スナックバーは、画面上のほとんどの要素の上に表示され、それらはフローティングアクションボタンに 仰角に等しいです。ただし、ダイアログボックス、ボトムシート、およびナビゲーションドロワーよりも低くなります( )。
したがって、Snackbarは常にダイアログよりも高度が低く表示されます。
使用カスタムダイアログ背景を透明にして、アンドロイドのデフォルトのダイアログと同じ感情を持つようにします。 – Drv
上記の画像からのダイアログの幅と高さの値は既に 'match_parent'に設定されています – roroinpho21
自分の答えを編集しましたかチェックできます –