Je veux afficher le bouton flèche arrière dans mon application, mais l'application se bloque lorsque je mets cela dans mon code:
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);
style.xml
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/PrimaryColor</item>
<item name="colorPrimaryDark">@color/PrimaryColorDark</item>
<item name="colorAccent">@color/PrimaryColor</item>
<item name="colorControlHighlight">@color/ControlHighlight</item>
<item name="Android:statusBarColor" tools:targetApi="21">@Android:color/transparent</item>
</style>
<style name="ActionBarPopupThemeOverlay" parent="ThemeOverlay.AppCompat.Light" >
<item name="Android:textColor">#000000</item>
</style>
<style name="MyCustomTabLayout" parent="Widget.Design.TabLayout">
<item name="tabIndicatorColor">#FFFFFF</item>
<item name="tabIndicatorHeight">3dp</item>
<item name="tabTextAppearance">@style/MyCustomTabTextAppearance</item>
</style>
<style name="MyCustomTabTextAppearance" parent="TextAppearance.Design.Tab">
<item name="Android:textColor">#FFFFFF</item>
</style>
toolbar.xml
<Android.support.v7.widget.Toolbar xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:app="http://schemas.Android.com/apk/res-auto"
Android:layout_height="@dimen/abc_action_bar_default_height_material"
Android:elevation="0dp"
Android:layout_width="match_parent"
Android:id="@+id/toolbar"
Android:background="@color/PrimaryColor"
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:popupTheme="@style/ActionBarPopupThemeOverlay"/>
Classe (pas Fragment):
public class WebViewCanale extends AppCompatActivity {
Toolbar toolbar;
TextView textView;
WebView webView;
ProgressBar progressBar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.webview_canali);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);
//Toolbar
toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
//FindViewById
webView = (WebView) findViewById(R.id.webview);
textView = (TextView) findViewById(R.id.textView);
progressBar = (ProgressBar) findViewById(R.id.progressBar);
//Impostazioni WebView
WebSettings webSettings = webView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setLoadsImagesAutomatically(true);
webView.loadUrl(this.getIntent().getDataString());
webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
webView.getSettings().setAppCacheEnabled(false);
//Titolo Toolbar
webView.setWebChromeClient(new WebChromeClient() {
@Override
public void onReceivedTitle(WebView view, String title) {
super.onReceivedTitle(view, title);
if (!TextUtils.isEmpty(title)) {
WebViewCanale.this.setTitle(title);
}
}
});
}
}
Je me demande pourquoi il n'y a pas de réponse complète à cela sur SO, mais finalement j'ai résolu le problème par moi-même:
Utilisez l'extrait de code suivant pour avoir bouton retour dans la barre d'outils dans un AppCompatActivity:
toolbar = (Toolbar) findViewById(R.id.hack_toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);
toolbar.setNavigationOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
//do something you want
}
});
Vous pouvez également simplement déclarer dans le Manifest
un ParentActivity
avec: <activity Android:name=".ThisActivity" Android:parentActivityName=".TheActivityThatCalledThisOne"> </activity>
@BindView(R.id.toolbar)
Toolbar toolbar;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_user_events);
ButterKnife.bind(this);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
}
@Override
public boolean onSupportNavigateUp() {
onBackPressed();
return true;
}
onSupportNavigateUp()
Cette méthode est appelée chaque fois que l'utilisateur choisit de remonter dans la hiérarchie d'activité de votre application à partir de la barre d'actions.
onBackPressed();
Prenez soin de faire sauter la pile de fragments arrière ou de terminer l'activité selon le cas.
ajoutez ce thème:
<style name="AppTheme2" parent="Theme.AppCompat.Light">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
<item name="colorPrimary">@color/appColor</item>
<item name="colorControlNormal">@color/whiteColor</item>
<item name="colorControlActivated">@color/appColor</item>
</style>
et dans votre activité:
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
Vous devez d'abord définir la barre d'action de support avant de pouvoir l'obtenir. alors placez le code suivant
toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
Avant ce code
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);