如何在 Android 中显示动画弹出窗口
How to show animated popup in Android
我正在寻找一种方法来制作弹出窗口(而不是 Dialog
),就像在 Whatsapp 中单击个人资料图片时那样。
像这样。这在 Android 中是如何工作的?我在寻找什么?
如果用户单击我的 ListView 中的 ImageView,我想显示一些信息 Header。
到目前为止,如果单击 ImageView
,我会打开一个新的 Activity。
holder.projectImageImageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent(context1, JobInfo.class);
intent.putExtra("projectInfo", projectItems);
intent.putExtra("distributorInfo", distributorItems);
intent.putExtra("contractorInfo", contractorItems);
context1.startActivity(intent);
}
});
此代码位于扩展 BaseAdapter
.
的 CustomAdapter 中
有什么方法可以做我想做的事吗?
亲切的问候!
您可以为自定义 Dialog
创建一个 Layout
,您需要 TextView
<?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" >
<TextView
android:id="@+id/text"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:textColor="#FFF"
android:layout_toRightOf="@+id/image"/>
<Button
android:id="@+id/dialogButtonOK"
android:layout_width="100px"
android:layout_height="wrap_content"
android:text=" Ok "
android:layout_marginTop="5dp"
android:layout_marginRight="5dp"
/>
</RelativeLayout>
在你的Activity
,在onClick()
final Dialog dialog = new Dialog(context);
dialog.setContentView(R.layout.custom);
dialog.setTitle("Title...");
// set the custom dialog components - text and button
TextView text = (TextView) dialog.findViewById(R.id.text);
text.setText("Your Text");
Button dialogButton = (Button) dialog.findViewById(R.id.dialogButtonOK);
// if button is clicked, close the custom dialog
dialogButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
dialog.show();
你可以设置dialog window风格的进入动画和退出动画并且可以在dialog中使用这个设置-
<style name="animationdialog">
<item name="@android:windowEnterAnimation">@anim/dialog_in</item>
<item name="@android:windowExitAnimation">@anim/dialog_out</item>
</style>
dialog = new Dialog(getActivity(),android.R.style.Theme_Holo_Dialog_NoActionBar);
dialog.setContentView(R.layout.custom_layout_dialog);
dialog.getWindow().getAttributes().windowAnimations = R.style.animationdialog;
dialog_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:duration="500"
android:fromXScale="0.3"
android:fromYScale="0.3"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="1.0"
android:toYScale="1.0" />
<alpha
android:duration="500"
android:fromAlpha="0.0"
android:interpolator="@android:anim/decelerate_interpolator"
android:toAlpha="1.0" />
</set>
dialog_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<scale
android:duration="500"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="0.0"
android:toYScale="0.0" />
<alpha
android:duration="500"
android:fromAlpha="1.0"
android:interpolator="@android:anim/decelerate_interpolator"
android:toAlpha="0.0" />
</set>
我正在寻找一种方法来制作弹出窗口(而不是 Dialog
),就像在 Whatsapp 中单击个人资料图片时那样。
像这样。这在 Android 中是如何工作的?我在寻找什么?
如果用户单击我的 ListView 中的 ImageView,我想显示一些信息 Header。
到目前为止,如果单击 ImageView
,我会打开一个新的 Activity。
holder.projectImageImageView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent(context1, JobInfo.class);
intent.putExtra("projectInfo", projectItems);
intent.putExtra("distributorInfo", distributorItems);
intent.putExtra("contractorInfo", contractorItems);
context1.startActivity(intent);
}
});
此代码位于扩展 BaseAdapter
.
有什么方法可以做我想做的事吗?
亲切的问候!
您可以为自定义 Dialog
创建一个 Layout
,您需要 TextView
<?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" >
<TextView
android:id="@+id/text"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:textColor="#FFF"
android:layout_toRightOf="@+id/image"/>
<Button
android:id="@+id/dialogButtonOK"
android:layout_width="100px"
android:layout_height="wrap_content"
android:text=" Ok "
android:layout_marginTop="5dp"
android:layout_marginRight="5dp"
/>
</RelativeLayout>
在你的Activity
,在onClick()
final Dialog dialog = new Dialog(context);
dialog.setContentView(R.layout.custom);
dialog.setTitle("Title...");
// set the custom dialog components - text and button
TextView text = (TextView) dialog.findViewById(R.id.text);
text.setText("Your Text");
Button dialogButton = (Button) dialog.findViewById(R.id.dialogButtonOK);
// if button is clicked, close the custom dialog
dialogButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
}
});
dialog.show();
你可以设置dialog window风格的进入动画和退出动画并且可以在dialog中使用这个设置-
<style name="animationdialog">
<item name="@android:windowEnterAnimation">@anim/dialog_in</item>
<item name="@android:windowExitAnimation">@anim/dialog_out</item>
</style>
dialog = new Dialog(getActivity(),android.R.style.Theme_Holo_Dialog_NoActionBar);
dialog.setContentView(R.layout.custom_layout_dialog);
dialog.getWindow().getAttributes().windowAnimations = R.style.animationdialog;
dialog_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:duration="500"
android:fromXScale="0.3"
android:fromYScale="0.3"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="1.0"
android:toYScale="1.0" />
<alpha
android:duration="500"
android:fromAlpha="0.0"
android:interpolator="@android:anim/decelerate_interpolator"
android:toAlpha="1.0" />
</set>
dialog_out.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<scale
android:duration="500"
android:fromXScale="1.0"
android:fromYScale="1.0"
android:pivotX="50%"
android:pivotY="50%"
android:toXScale="0.0"
android:toYScale="0.0" />
<alpha
android:duration="500"
android:fromAlpha="1.0"
android:interpolator="@android:anim/decelerate_interpolator"
android:toAlpha="0.0" />
</set>