私はAndroid Studioと初心者向けのAndroidプログラミング全般です。私は見て、見て、正しいことを見つけることができませんでした。 。
必要なのは、PreferenceFragmentCompatまたはAndroid.app.PreferenceFragmentを置き換える任意のクラスを使用するライブラリをインストールして、アプリがAPI 11以前で動作できるようにすることだけです。
誰がどのライブラリを使用するべきか、ASプロジェクトにどのようにインストールするかなどの詳細を教えてください。
編集:それで、_Android.support.v4
_および_Android.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));
}
}
}
_
これは私の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);
}
}
_
私がここで遭遇する本当の問題は、この行にあります:MainActivity.JavaのmainFragment = new SettingsFragment();
メソッドのonNavigationDrawerItemSelected(int position)
.
次のエラーを返します:
エラー:(70、32)エラー:互換性のないタイプ:SettingsFragmentはFragmentに変換できません
これを修正して、API 11以前でアプリを使用できるようにするにはどうすればよいですか?
Build_gradleファイルにcom.Android.support:preference-v7:23.0.1
を追加した後、次の行を変更するだけです
AndroidXの場合:androidx.preference:preference:1.0.0
public class SettingsFragment extends PreferenceFragment {
に
public class SettingsFragment extends PreferenceFragmentCompat {
このエラーは、サポートライブラリクラスを使用しているため、必要なAndroid.app.Fragment
ではなく、Android.support.v4.app.Fragment
を拡張するPreferenceFragment
が原因です。
androidx
を使用している場合は、これを依存関係に追加します
dependencies {
...
implementation 'androidx.preference:preference:{your_version}'
// example: implementation 'androidx.preference:preference:1.1.0-alpha01'
}