自定義dialog(仿照APP啟動時的dialog廣告頁面)
阿新 • • 發佈:2019-02-12
是一個從下面彈出的動畫效果
感覺現在app都有這種dialog了,於是學學唄。
專案的完整程式碼,點選我朋友部落格連結,下邊有,雖然還要一積分,哈哈
主要貼圖二的程式碼,
自定義一個dialog整合dialog
package nan.dialogview;
import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.annotation.StyleRes;
import android.view.View;
import android.widget.ImageView;
/**
* Created by NanFeiLong on 2017/4/16.
*/
public class MyCloseDialog extends Dialog implements View.OnClickListener{
private ImageView img_back;
private Context mContext;
public MyCloseDialog(@NonNull Context context, @StyleRes int themeResId) {
super(context, themeResId);
this.mContext = context;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.dialog_closeicon_layout);
img_back=(ImageView) findViewById(R.id.close);
img_back.setOnClickListener(this );
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.close:
MyCloseDialog.this.dismiss();
break;
default:
break;
}
}
}
下邊貼布局
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center_horizontal"
android:layout_centerInParent="true">
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_margin="12dp"
android:gravity="center"
android:orientation="vertical">
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/im" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="5dp"
android:gravity="center"
android:text="點選領取更多"
android:textColor="@android:color/white"
android:textSize="26sp"
android:textStyle="bold" />
</LinearLayout>
<ImageView
android:id="@+id/close"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:background="@drawable/close" />
</RelativeLayout>
</LinearLayout>
這就是dialog 的全部程式碼,
下邊貼下mainActivity
package nan.dialogview;
import android.app.Dialog;
import android.graphics.drawable.ColorDrawable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private Button button;
private Button btnClose;
private Dialog mDialog;
private MyCloseDialog myCloseDialog;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button = (Button) findViewById(R.id.button);
button.setOnClickListener(this);
btnClose = (Button) findViewById(R.id.btn_close_dialog);
btnClose.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.button:
mDialog = DialogUtil.ShowBabyShowSendDialog(MainActivity.this,this,this);
mDialog.show();
break;
case R.id.iv_send_picture:
Toast.makeText(this,"點選了圖片",Toast.LENGTH_SHORT).show();
mDialog.dismiss();
break;
case R.id.iv_send_vedio:
Toast.makeText(this,"點選了視訊",Toast.LENGTH_SHORT).show();
mDialog.dismiss();
break;
case R.id.btn_close_dialog:
//若想讓彈出的dialog之外的背景為半透明,第二個引數傳0 或者自定義樣式
myCloseDialog = new MyCloseDialog(this,0);
myCloseDialog.requestWindowFeature(Window.FEATURE_NO_TITLE);//程式碼中取消標題欄
myCloseDialog.getWindow().setBackgroundDrawable(new ColorDrawable(android.graphics.Color.TRANSPARENT));
myCloseDialog.show();
myCloseDialog.setCancelable(false);
break;
default:
break;
}
}
}
好了,就這麼多,需要用的,直接cv走就好