アプリに戻る矢印ボタンを表示したいのですが、これをコードに追加するとアプリがクラッシュします。
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"/>
クラス(フラグメントではない):
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);
}
}
});
}
}
SOでこれに対する完全な答えがないのはなぜかと思いますが、最終的に自分で問題を解決しました。
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
}
});
Manifest
a ParentActivity
で宣言することもできます:<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()
このメソッドは、ユーザーがアクションバーからアプリケーションのアクティビティ階層内を上に移動することを選択するたびに呼び出されます。
onBackPressed();
フラグメントのバックスタックをポップするか、必要に応じてアクティビティを終了するよう注意してください。
このテーマを追加します。
<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>
そしてあなたの活動で:
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
取得する前に、まずサポートアクションバーを設定する必要があります。次のコードを配置します
toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
このコードの前
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);