为PreferenceFragmentCompat安装支持库

sir*_*r77 23 android preferencefragment preference-v7

我是Android Studio的新手,也是Android编程的初学者.我看了看,我找不到合适的事情.

我想要的是安装一个库来使用PreferenceFragmentCompat或任何替换android.app.PreferenceFragment的类,这样我的应用程序就可以在API 11及更低版本中运行.

任何人都可以给我一些细节,比如我应该使用哪个库以及如何在我的AS项目中安装它.

编辑:所以我开始使用android.support.v4android.support.v7库来开发这个应用程序来处理片段,所以我可以在API 11和更低版本上运行它.

这是我的MainActivity.java.

package com.example.myapplication;

import android.app.Activity;
import android.content.Intent;
import android.net.Uri;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.app.ActionBar;

import android.content.Context;
import android.os.Build;
import android.os.Bundle;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.support.v4.widget.DrawerLayout;
import android.widget.ArrayAdapter;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity
        implements NavigationDrawerFragment.NavigationDrawerCallbacks {

    /**
     * Fragment managing the behaviors, interactions and presentation of the navigation drawer.
     */
    private NavigationDrawerFragment mNavigationDrawerFragment;

    /**
     * Used to store the last screen title. For use in {@link #restoreActionBar()}.
     */
    private CharSequence mTitle;

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

        mNavigationDrawerFragment = (NavigationDrawerFragment)
                getSupportFragmentManager().findFragmentById(R.id.navigation_drawer);
        mTitle = getTitle();

        // Set up the drawer.
        mNavigationDrawerFragment.setUp(
                R.id.navigation_drawer,
                (DrawerLayout) findViewById(R.id.drawer_layout));
    }

    @Override
    public void onNavigationDrawerItemSelected(int position) {
        Fragment mainFragment = null;

        switch(position) {
            case 0: // home fragment
                mainFragment = new HomeFragment();
                break;
            case 1: // favorites list
                mainFragment = new FaveFragment();
                break;
            case 2: // rate app
                /* visit app TODO put application package id in the link */
                Intent visitStore = new Intent(Intent.ACTION_VIEW);
                visitStore.setData(Uri.parse("market://details?id=com.google.android.apps.maps"));
                startActivity(visitStore);
                break;
            case 3: // settings
                mainFragment = new SettingsFragment();
                break;
            case 4: // about
                mainFragment = new AboutFragment();
                break;

        }

        if(position != 2) {
            // update the main content by replacing fragments
            FragmentManager fragmentManager = getSupportFragmentManager();
            fragmentManager.beginTransaction()
                    .replace(R.id.container, mainFragment)
                    .commit();
        }
    }

    public void onSectionAttached(int number) {
        String[] stringArray = getResources().getStringArray(R.array.section_titles);
        if (number >= 1) {
            mTitle = stringArray[number - 1];
        }
    }

    public void restoreActionBar() {
        ActionBar actionBar = getSupportActionBar();
        actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_STANDARD);
        actionBar.setDisplayShowTitleEnabled(true);
        actionBar.setTitle(mTitle);
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        if (!mNavigationDrawerFragment.isDrawerOpen()) {
            // Only show items in the action bar relevant to this screen
            // if the drawer is not showing. Otherwise, let the drawer
            // decide what to show in the action bar.
            getMenuInflater().inflate(R.menu.main, menu);
            restoreActionBar();
            return true;
        }
        return super.onCreateOptionsMenu(menu);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }

    /**
     * A placeholder fragment containing a simple view.
     */
    public static class PlaceholderFragment extends Fragment {
        /**
         * The fragment argument representing the section number for this
         * fragment.
         */
        private static final String ARG_SECTION_NUMBER = "section_number";

        /**
         * Returns a new instance of this fragment for the given section
         * number.
         */
        public static PlaceholderFragment newInstance(int sectionNumber) {
            PlaceholderFragment fragment = new PlaceholderFragment();
            Bundle args = new Bundle();
            args.putInt(ARG_SECTION_NUMBER, sectionNumber);
            fragment.setArguments(args);
            return fragment;
        }

        public PlaceholderFragment() {
        }

        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                                 Bundle savedInstanceState) {
            View rootView = inflater.inflate(R.layout.fragment_main, container, false);
            return rootView;
        }

        @Override
        public void onAttach(Activity activity) {
            super.onAttach(activity);
            ((MainActivity) activity).onSectionAttached(
                    getArguments().getInt(ARG_SECTION_NUMBER));
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

现在这是我的SettingsFragment.java:

package com.example.myapplication;

import android.os.Bundle;
import android.preference.PreferenceFragment;

public class SettingsFragment extends PreferenceFragment {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        addPreferencesFromResource(R.xml.settings);
    }
}
Run Code Online (Sandbox Code Playgroud)

我在这里遇到的真正问题是这一行:在MainActivity.javamainFragment = new SettingsFragment();中的onNavigationDrawerItemSelected(int position)方法中.

它返回一个错误说:

错误:(70,32)错误:不兼容的类型:SettingsFragment无法转换为Fragment

我该如何解决这个问题,仍然可以在API 11和更低版本上使用我的应用程序?

Der*_*ung 55

添加com.android.support:preference-v7:23.0.1到build.gradle文件后,只需更改该行

public class SettingsFragment extends PreferenceFragment {
Run Code Online (Sandbox Code Playgroud)

public class SettingsFragment extends PreferenceFragmentCompat {
Run Code Online (Sandbox Code Playgroud)

该错误是由您使用支持库类androidx.preference:preference:1.0.0扩展PreferenceFragment而不是android.app.Fragment您需要的.

  • 将`compile'c​​om.android.support:preference-v7:23.0.1'`添加到你的gradle中 (51认同)
  • 我猜是一个菜鸟问题:您在哪里看到哪个库中的信息?我的意思是,您怎么知道要添加特定的编译语句?因为当我通读PreferenceFragmentCompat文档时,并没有说添加此编译语句,我必须去文档中的Support Library并基本上保持最新(如果有什么变化),所以我想知道是否有更直接的方法来知道要编译什么没有太多的挖掘? (2认同)

Pha*_*inh 25

对于任何使用的人androidx,请将其添加到您的依赖项中

dependencies {

    ...
    implementation 'androidx.preference:preference:{your_version}'
    // example: implementation 'androidx.preference:preference:1.1.0-alpha01'
}
Run Code Online (Sandbox Code Playgroud)

  • 首选版本可以在这里找到:https://developer.android.com/jetpack/androidx/releases/preference (5认同)