0

そのため、ロード中およびアクティビティが開始されるmenuitemたびに、リフレッシュをアニメーション化しようとしています。また、必要がないときはいつでもwebviewフォワードを非表示にしようとしています。menuitem次のコードは、webview の読み込み中に反撃するとき、または一度に複数のタスクを実行しようとするとき (多くの履歴をクリックして戻るとき) を除いて、完全に機能します。これが発生するたびに、更新menuitemは複製、アニメーション化、およびオーバーラップする傾向があります。これは forward でも起こりmenuitemます。アニメーション化された更新アイコンが重なる傾向があります。これが起こらないようにする方法はありますか?次のコードは、関連しないものはすべて削除されていることを除いて、正確に私のコードです。誰かがこのバグを克服するのを手伝ってくれますか?

public class TideWeb extends Activity {
    private static WebView webView;
    String name = null;
    MenuItem refresh, forward;
    ActionBar ab;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Intent launchingIntent = getIntent();
        name = launchingIntent.getType().toString();
        setContentView(R.layout.webview);
        webView = (WebView) findViewById(R.id.WebView);
        webView.setWebViewClient(new WebViewClient() {
            public boolean shouldOverrideUrlLoading(WebView webview, String url) {
                    if (refresh != null && refresh.getActionView() == null) {
                        StartAnimation();
                    }
                    ab.setSubtitle("Loading...");
                    webView.loadUrl(url);

                return true;

            }
        });
        webView.setWebChromeClient(new WebChromeClient() {
            public void onProgressChanged(WebView view, int progress) {
                setSupportProgress(progress * 100);
                if (progress == 100) {
                    view.clearCache(true);
                    StopAnimation();
                    ab.setSubtitle(name);
                }
            }
        });
        String url = launchingIntent.getData().toString();

        webView.loadUrl(url);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getSupportMenuInflater().inflate(R.menu.tideweb, menu);
        forward = menu.findItem(R.id.forward_menu);
        if (webView.isFocused() && webView.canGoForward()) {
            forward.setVisible(true);
        } else {
            forward.setVisible(false);
        }
        ab.setSubtitle("Loading...");
        refresh = menu.findItem(R.id.refresh_menu);
        if (refresh != null && refresh.getActionView() == null) {
            StartAnimation();
        }
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
        case R.id.forward_menu:
            webView.goForward();
            invalidateOptionsMenu();
            break;
        case R.id.refresh_menu:
            webView.reload();
            invalidateOptionsMenu();
            break;
        case android.R.id.home:
            Intent intent = new Intent(this, Main.class);
            intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
            startActivity(intent);
            return true;
        }
        return true;
    }

    public void onBackPressed() {
        if (webView.isFocused() && webView.canGoBack()) {
            webView.goBack();
            invalidateOptionsMenu();
        } else {
            super.onBackPressed();
            finish();
        }
    }

    private void StartAnimation() {
    if (refresh != null && refresh.getActionView() == null) {
            final LayoutInflater inflater = (LayoutInflater) getApplication()
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            final RelativeLayout ivRefresh = (RelativeLayout) inflater.inflate(
                R.layout.refresh_view, null);

            final Animation rotation = AnimationUtils.loadAnimation(
                getApplication(), R.anim.rotate);
            ivRefresh.startAnimation(rotation);
            refresh.setActionView(ivRefresh);
        }
    }

    private void StopAnimation() {
        if (refresh != null && refresh.getActionView() != null) {
            refresh.getActionView().clearAnimation();
            refresh.setActionView(null);
        }
    }
}

ロードしてから戻る: ロードしてから戻る

ロードしてから、前後に: ローディング、そして前後

4

1 に答える 1

0

I didn't really find a fix for this, but instead of using an image and animating it, I set the actionview to a progressbar. The overlapping doesn't happen anymore, so I guess it's fixed now.

于 2013-07-28T03:01:29.360 に答える