一、preferencefragment加圖片
PreferenceFragment是一個用於管理偏好設置的Fragment,它提供了一個簡單的方法來顯示設置頁面。可以將PreferenceFragment視為一個容器,其中包含一些Preference,可以對其進行訪問和編輯。在Preference界面中,可以添加圖片作為設置項的圖標,使其更具有可讀性和美觀性。以下是向PreferenceFragment中添加圖標的代碼示例:
//在xml文件中設置圖標
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<PreferenceCategory
android:key="general_settings"
android:title="普通設置"
android:summary="設置常規選項">
<Preference
android:key="audio_play"
android:title="播放音樂"
android:summary="勾選該項後,音樂播放時將發出聲音"
android:icon="@drawable/ic_audio" />
</PreferenceCategory>
</PreferenceScreen>
在上述示例中,添加了一個名為「audio_play」的偏好設置項,它的圖標是@drawable/ic_audio。在實際開發中,可以根據需要更改圖標,使其更符合應用程序的設計。
二、preferencefragment 自定義界面
默認情況下,PreferenceFragment會使用系統提供的布局和樣式來顯示偏好設置界面。但是,如果需要自定義偏好設置頁面的外觀和行為,則可以創建自己的布局文件,並在PreferenceFragment中將其設置為視圖。以下是一個自定義偏好設置界面的代碼示例:
//自定義布局文件my_preference.xml
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<PreferenceCategory
android:key="general_settings"
android:title="普通設置"
android:summary="設置常規選項">
<CheckBoxPreference
android:key="audio_play"
android:title="播放音樂"
android:summary="勾選該項後,音樂播放時將發出聲音"
android:defaultValue="true" />
</PreferenceCategory>
</PreferenceScreen>
//自定義PreferenceFragment
public class MyPreferenceFragment extends PreferenceFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.my_preference);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.preference_layout, container, false);
return view;
}
}
//preference_layout.xml文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<TextView
android:text="這是一個自定義的設置界面"
android:textSize="20sp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center" />
<fragment
android:id="@+id/my_preference_fragment"
android:name="com.example.MyPreferenceFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
在上述代碼示例中,MyPreferenceFragment繼承自PreferenceFragment,並在onCreate()方法中指定了自己的布局文件my_preference.xml。在onCreateView()方法中,將preference_layout.xml設置為視圖,並將MyPreferenceFragment添加到布局中。這樣就可以自定義偏好設置頁面的界面,使其更符合應用程序的設計需求。
三、preferencefragment toolbar選取
在支持toolbar的應用程序中,可以將PreferenceFragment與Toolbar結合使用,使其在UI中良好地融合。以下是一個使用Toolbar的代碼示例:
//MainActivity.java
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
getFragmentManager().beginTransaction().replace(R.id.content_frame, new MyPreferenceFragment()).commit();
}
}
//MyPreferenceFragment.java
public class MyPreferenceFragment extends PreferenceFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.my_preference);
}
@Override
public void onViewCreated(View view, Bundle savedInstanceState) {
super.onViewCreated(view, savedInstanceState);
Toolbar toolbar = (Toolbar) view.findViewById(R.id.toolbar);
toolbar.setTitle("偏好設置");
toolbar.setNavigationIcon(R.drawable.ic_back);
toolbar.setNavigationOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
getActivity().onBackPressed();
}
});
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.preference_layout, container, false);
return view;
}
}
//preference_layout.xml文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@color/colorPrimary"
android:elevation="4dp"
android:theme="@style/ThemeOverlay.AppCompat.ActionBar" />
<fragment
android:id="@+id/my_preference_fragment"
android:name="com.example.MyPreferenceFragment"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
在上述代碼示例中,MainActivity中的Toolbar與MyPreferenceFragment的Toolbar進行了關聯。在MyPreferenceFragment中,通過view.findViewById(R.id.toolbar)獲取到布局文件preference_layout.xml中的Toolbar,並設置其標題和返回按鈕。如果需要自定義Toolbar的樣式,可以在styles.xml文件中設置ThemeOverlay.AppCompat.ActionBar樣式。這樣就可以在PreferenceFragment中使用Toolbar,使其在UI中更加美觀和方便。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/153870.html
微信掃一掃
支付寶掃一掃