5

私は取り組んでいCustom Progress Dialogます。このSOの質問で行ったようにスタイルを設定しました。カスタムプログレスダイアログでのスピニングホイールの配置プログレスダイアログにアニメーションがまったく表示されません。に変更するbackgroundblack、ブラックボックスのみが表示されていました。進行状況ダイアログをアニメーション化する必要があります。

活動中、私はこのようなことをしています

 public MyProgressDialog(Context context) {
        super(context, R.style.NewDialog);
    }

NewDialogは次のとおりです。

<style name="NewDialog" parent="@android:style/Theme.Dialog">

    <item name="android:windowFrame">@null</item>
    <item name="android:windowBackground">@android:color/transparent</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowContentOverlay">@null</item>
    <item name="android:windowTitleStyle">@null</item>
    <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
    <item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
    <item name="android:backgroundDimEnabled">true</item>
    <item name="android:width">50dip</item>
    <item name="android:height">50dip</item>
    <item name="android:background">@android:color/transparent</item>

</style>

どんな助けでも事前に感謝します

4

2 に答える 2

11
import android.app.ProgressDialog;
import android.content.Context;
import android.view.animation.Animation;

public class MyProgressDialog extends ProgressDialog {

    public MyProgressDialog(Context context) {
        super(context,R.style.NewDialog);

        // TODO Auto-generated constructor stub
    }

}

//リソーススタイルファイルres->values->mydialog.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
   <style name="NewDialog" parent="@android:style/Theme.Dialog">

    <item name="android:windowFrame">@null</item>
    <item name="android:windowBackground">@android:color/transparent</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowContentOverlay">@null</item>
    <item name="android:windowTitleStyle">@null</item>
    <item name="android:colorBackground">#ffffff</item>
    <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
    <item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
    <item name="android:backgroundDimEnabled">true</item>
    <item name="android:width">600dip</item>
    <item name="android:height">100dip</item>
     <item name="android:textColor">#FF0000</item>

</style>
</resources>

//そして、このコードをアプリケーションのどこでも使用して、カスタムプログレスダイアログを取得します

MyProgressDialog pd = new MyProgressDialog(YouActivity.this);
pd.setMessage("Loading. Please wait...");
pd.show();

問題が発生しているかどうかをテストするためだけにコードを実行したので、コードと私のコードに違いはありませんが、問題を探すことができるように投稿しています。

ありがとう :)

于 2012-07-24T12:15:00.467 に答える
2
public class TransparentProgressDialog extends Dialog {

 private ImageView iv;

 public TransparentProgressDialog(Context context, int resourceIdOfImage) {

     super(context, R.style.TransparentProgressDialog);
  WindowManager.LayoutParams wlmp = getWindow().getAttributes();
  wlmp.gravity = Gravity.CENTER_HORIZONTAL;
  getWindow().setAttributes(wlmp);
  setTitle(null);
   setCancelable(false);
   setOnCancelListener(null);
   resourceIdOfImage = R.drawable.loading_spinner_icon;
  LinearLayout layout = new LinearLayout(context);
   layout.setOrientation(LinearLayout.VERTICAL);
  LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(
   LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT);
  iv = new ImageView(context);
  iv.setImageResource(resourceIdOfImage);
  layout.addView(iv, params);
  addContentView(layout, params);
  }

  }

ここでアニメーションの完全な例を取得します

于 2015-02-20T09:39:54.197 に答える