そのため、ロード中およびアクティビティが開始される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);
}
}
}
ロードしてから戻る:
ロードしてから、前後に: