ロリポッププレイストアで引き出しインジケータ

? Jason Hocker @ | Original: StackOverFlow

私はAndroid 5.0のプレビュービルドでネクサス7を使用しています。

このページでは  http://developer.android.com/tools/support-library/index.html

I see

V7 AppCompatのライブラリの変更点:更新された「 ____ 」 、その   メニュー·ツー·矢印アニメーションが含まれています

これは、Googleがアプリの使用をプレイとは何ですか?私はこの文にあまりにも多く読んでいる?私は、この動作を取得するために変更する必要がない - 私はAPIドキュメントでそれを見つけることができません。



Top 5 Respuesta

1Damian Piwowarski @

それは非常に簡単です。

DrawerLayoutであなたのレイアウトはいつもと同じように見える。あなたはandroid.support.v4.widget.DrawerLayoutを使用して、引き出しやコンテンツ領域を作成します。

ActionBarDrawerToggle

主な変更点は、Javaコードである。あなたが引き出しのレイアウトを使用どこにあなたの活動では、あなたはV7からActionBarActivityのためにそれを拡張する必要があります。その後、 DrawerLayoutとActionBarDrawerToggleための変数を作成する。あなたの輸入は次のようになります。

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawerLayout"
android:layout_width="match_parent"
android:layout_height="match_parent" >

<RelativeLayout
    android:id="@+id/content_frame"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ff0"
    android:orientation="vertical" >
</RelativeLayout>

<ListView
    android:id="@+id/leftDrawer"
    android:layout_width="290dp"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    android:background="#f0f"
    android:choiceMode="singleChoice"
    android:clickable="true"
    android:divider="@null"
    android:dividerHeight="0dp"
    android:scrollbars="none" />

そして、ちょうど、すべてを接続します。アイコンを持っていない、新しい引き出しレイアウトを覚えておいてください!あなたはちょうどあなたが普通にあるべき場所にそれを渡すいけない。私の活動のためのコード:

import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.ActionBarActivity;

そして、それは動作するはずです。



2Pierre-Antoine LaFayette @

私はプレイストアのスタイルアニメーションのアイコンとアクションバーを提供するために、新しいツールバークラスとActionBarToggleを使用して、ここでサンプルアプリを掲載しました:

https://github.com/03lafaye/LollipopDrawerToggle

無-V7 -サポート·ブランチは、フレームワークの活動とツールバーとActionBarToggleを使用しています。 masterブランチは、 V7のツールバーとActionBarActivityを使用しています。

ActionBarActivityを使用しないためのセットアップは次のようになります。

import android.content.res.Configuration;
import android.os.Bundle;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.ActionBarActivity;
import android.view.MenuItem;

public class MainActivity extends ActionBarActivity {

    DrawerLayout drawerLayout;
    ActionBarDrawerToggle drawerToggle;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        drawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout);
        drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, R.string.app_name, R.string.app_name) {};

        drawerLayout.setDrawerListener(drawerToggle);

        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setHomeButtonEnabled(true);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (drawerToggle.onOptionsItemSelected(item)) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        drawerToggle.syncState();
    }

    @Override
    public void onConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        drawerToggle.onConfigurationChanged(newConfig);
    }

}

あなたがそうのようなあなたのテーマで、ウィンドウアクションバーとタイトルバーを無効にする必要があることに注意してください:

package com.plafayette.lollipop;

import android.app.Activity;
import android.support.v4.widget.DrawerLayout;
import android.os.Bundle;
import android.support.v7.app.ActionBarDrawerToggle;
import android.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;

public class ToolbarActivity extends Activity {
    private ActionBarDrawerToggle toggle;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_toolbar);

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setActionBar(toolbar);

        DrawerLayout drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
        toggle = new ActionBarDrawerToggle(this, drawerLayout, R.string.open, R.string.close);
        toggle.setDrawerIndicatorEnabled(true);
        drawerLayout.setDrawerListener(toggle);
    }

    @Override
    protected void onPostCreate(Bundle savedInstanceState) {
        super.onPostCreate(savedInstanceState);
        toggle.syncState();
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (toggle.onOptionsItemSelected(item))
            return true;

        int id = item.getItemId();
        return id == R.id.action_settings || super.onOptionsItemSelected(item);
    }
}

私は、最新のV7 AppCompatのライブラリ用のサンプルコードは、このポストが廃止されたことすぐに十分リリースされます想像する。

広場からクリスRenkeアップアイコンのアニメーションの代わりのバックポートを発表した。コードはここGitHubの上にあり: https://github.com/ChrisRenke/DrawerArrowDrawable 、彼はhttp://chrisrenke.com/drawerarrowdrawableでそれについてのブログを書きました。

3TWiStErRob @

あなたは、 https://developer.android.com/training/implementing-navigation/nav-drawer.htmlはかなり良いですしない場合、私は、それを読むように作業引き出しを持っているようだ。

メニュー·ツー·矢印アニメーションが含まれている更新されたActionBarDrawerToggle 、

ロリポッププレイストアで引き出しインジケータ

上記の引用は指しhttps://github.com/android/platform_frameworks_support/commit/058467cbd6dd0acdfaec61e65ab9e352868ec5c9コミット。 関連一つとして、「 ____ 」で追加されましたhttps://github.com/android/platform_frameworks_support/commit/239e759c480945ee5c164c7c75cb30ff164caa91 。

だから、 「 ____ 」と使用して呼び出されていない「 ____ 」を確認してください

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="AppTheme" parent="android:Theme.Material.Light">
        <item name="android:windowActionBar">false</item>
        <item name="android:windowNoTitle">true</item>
    </style>
</resources>

instead of

setDrawerIndicatorEnabled

これとにかく非推奨の警告からかなり明白であるべきである:

@deprecatedサポート-V7 - AppCompatのでActionBarDrawerToggleを使用してください。

おそらくも必要

setDrawerIndicatorEnabled
4nirav kalola @

まず、あなたが最新のSDKにアップデートを確認してください。 Gradleの依存関係としてあなたのbuid.gradleで+ 。 AppCompatの- v7.21.0を追加し、アンドロイドStudioで新しいプロジェクトを作成してAppCompatの- v4.21.0 。 +ライブラリ。

false

あなたのcolor.xmlファイルでのprimaryColorとprimarycolorDarkを追加します。

import android.support.v7.app.ActionBarDrawerToggle;

あなたのstrings.xmlファイルで引き出しオープン/クローズ文字列値を追加します。

import android.support.v4.app.ActionBarDrawerToggle;

あなたのactivity_my.xmlレイアウトファイルは次のようになります。

// <item name="displayOptions">showHome|homeAsUp</item>
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);

あなたのtoolbar.xmlレイアウトファイルは次のようになります。

compile 'com.android.support:appcompat-v7:21.0.2'
compile 'com.android.support:support-v4:21.0.2'

あなたのMyActivity.javaは次のようになります。 ここにあなたの活動必見ActionBarActivityを拡張し、サポート·アクションバーとしてあなたのツールバーを設定する。

<resources>
<color name="primaryColor">#2196F3</color>
<color name="primaryColorDark">#0D47A1</color>
</resources>

アンドロイドロリポップ用でstyle.xmlファイルを作成した値を、 21フォルダ

<resources>
<string name="app_name">Lollipop Drawer</string>
<string name="action_settings">Settings</string>
<string name="drawer_open">open</string>
<string name="drawer_close">close</string>
</resources>

古いバージョンその後アンドロイドロリポップの値フォルダ内のあなたのstyle.xmlファイルを作成します

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:orientation="vertical"
android:layout_height="match_parent"
tools:context=".MainActivity">

<include layout="@layout/toolbar" />


<android.support.v4.widget.DrawerLayout
    android:layout_width="match_parent"
    android:id="@+id/drawerLayout"
    android:layout_height="match_parent">

    <!-- activity view -->
    <RelativeLayout
        android:layout_width="match_parent"
        android:background="#fff"
        android:layout_height="match_parent">

        <TextView
            android:layout_centerInParent="true"
            android:layout_width="wrap_content"
            android:textColor="#000"
            android:text="Activity Content"
            android:layout_height="wrap_content" />
    </RelativeLayout>

    <!-- navigation drawer -->
    <RelativeLayout
        android:layout_gravity="left|start"
        android:layout_width="match_parent"
        android:background="#fff"
        android:layout_height="match_parent">

        <ListView
            android:id="@+id/left_drawer"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:divider="#eee"
            android:background="#fff"
            android:dividerHeight="1dp" />
    </RelativeLayout>

</android.support.v4.widget.DrawerLayout>

</LinearLayout>

あなたのAndroidManifest.xmlでは次のようになります。

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/toolbar"
android:minHeight="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:layout_width="match_parent"
android:layout_height="wrap_content">

</android.support.v7.widget.Toolbar>

参考のためにのみ: http://www.nkdroid.com/2014/11/Android-Lollipop-Navigation-Drawer-Example-Using-Appcompat-21.html :あなたはここから完全なソースコードをダウンロードすることができます

5Naruto @

https://github.com/kanytu/android-material-drawer-templateをチェックしてください

ロリポッププレイストアで引き出しインジケータ

MainActivity.java :

import android.content.res.Configuration;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;

public class MyActivity extends ActionBarActivity {

private Toolbar toolbar;
private DrawerLayout drawerLayout;
private ActionBarDrawerToggle drawerToggle;
private ListView leftDrawerList;
private ArrayAdapter<String> navigationDrawerAdapter;
private String[] leftSliderData = {"Home", "Android", "Sitemap", "About", "Contact Me"};

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_my);
    nitView();
    if (toolbar != null) {
        toolbar.setTitle("Navigation Drawer");
        setSupportActionBar(toolbar);
    }
    initDrawer();
}

private void nitView() {
    leftDrawerList = (ListView) findViewById(R.id.left_drawer);
    toolbar = (Toolbar) findViewById(R.id.toolbar);
    drawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout);
    navigationDrawerAdapter=new ArrayAdapter<String>( MyActivity.this, android.R.layout.simple_list_item_1, leftSliderData);
    leftDrawerList.setAdapter(navigationDrawerAdapter);
}

private void initDrawer() {

    drawerToggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.drawer_open, R.string.drawer_close) {

        @Override
        public void onDrawerClosed(View drawerView) {
            super.onDrawerClosed(drawerView);

        }

        @Override
        public void onDrawerOpened(View drawerView) {
            super.onDrawerOpened(drawerView);

        }
    };
    drawerLayout.setDrawerListener(drawerToggle);
}

@Override
protected void onPostCreate(Bundle savedInstanceState) {
    super.onPostCreate(savedInstanceState);
    drawerToggle.syncState();
}

@Override
public void onConfigurationChanged(Configuration newConfig) {
    super.onConfigurationChanged(newConfig);
    drawerToggle.onConfigurationChanged(newConfig);
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.my, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    int id = item.getItemId();
    if (id == R.id.action_settings) {
        return true;
    }
    if (drawerToggle.onOptionsItemSelected(item)) {
        return true;
    }
    return super.onOptionsItemSelected(item);
}
}

activity_main.xml :

<?xml version="1.0" encoding="utf-8"?>
<resources>

<style name="myAppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <item name="colorPrimary">@color/primaryColor</item>
    <item name="colorPrimaryDark">@color/primaryColorDark</item>
    <item name="android:statusBarColor">@color/primaryColorDark</item>

    <item name="drawerArrowStyle">@style/DrawerArrowStyle</item>
</style>

<style name="DrawerArrowStyle" parent="Widget.AppCompat.DrawerArrowToggle">
    <item name="spinBars">true</item>
    <item name="color">@android:color/black</item>
</style>

</resources>