Android夜间模式主题设置
Android夜间模式主题设置
竹蜻蜓O_0纸飞机 发表于2年前
Android夜间模式主题设置
  • 发表于 2年前
  • 阅读 19
  • 收藏 0
  • 点赞 0
  • 评论 0

移动开发云端新模式探索实践 >>>   

摘要: 设置夜间模式主题,有点瑕疵,就是切换主题的时候,因为重启了activity,所以会有一个瞬间的闪屏

本来是想仿照QQ的夜间模式主题做,但因项目紧急,和我目前的水平短时间内做不出来,所以就有了一下的成果,缺点就是每次主题切换的时候因为要重启Activity所以会闪屏。

首先如果你的项目的value中要有这两个文件 attrs.xml和style.xml,如果没有就自己创建一个。

在styles.xml文件中添加两个主题

    <style name="AppTheme_Blue" parent="AppTheme"><!-- 标准模式 -->
        <item name="theme_background">@color/gree</item>
        <item name="list_item_color">@color/white</item>
        <item name="list_item_text_color1">@color/text_black</item>
        <item name="list_item_text_color2">@color/message_time_gree</item>
        <item name="curse_line_gree">@color/curse_line_gree</item>
    </style>

    <style name="AppTheme_Dark" parent="AppTheme"><!-- 夜间模式 -->
        <item name="theme_background">@color/dark_background</item>
        <item name="list_item_color">@color/dark_list_item</item>
        <item name="list_item_text_color1">@color/dark_list_item_text</item>
        <item name="list_item_text_color2">@color/dark_list_item_text</item>
        <item name="curse_line_gree">@color/dark_gree</item>
    </style>

在attrs.xml文件中添加你要用到的值。跟上面两种模式的名字一样

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <attr name="theme_background" format="reference" /><!-- 界面主背景 -->
    <attr name="list_item_color" format="reference" /><!-- 一级标题颜色 -->
    <attr name="list_item_text_color1" format="reference" /><!-- 一级标题颜色 -->
    <attr name="list_item_text_color2" format="reference" /><!-- 二级标题颜色 -->
    <attr name="curse_line_gree" format="reference" /><!-- 间隔 -->
</resources>

接下来你就可以在所有的layout.xml文件中设置主题颜色了

设置背景颜色:

android:background="?attr/theme_background"

设置文字颜色:

android:textcolor="?attr/list_item_text_color1"

另外,还要设置夜间模式整个屏幕的亮度要暗一些,在你所有Activity继承的基类里,设置整个窗体的alpha值,使其变暗。

public class CommonActivity extends Activity{
    public int mTheme = R.style.AppTheme_Blue;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        if (savedInstanceState == null) {
            mTheme = PreferenceHelper.getTheme(this);
        } else {
            mTheme = savedInstanceState.getInt("theme");
        }
        setTheme(mTheme);
        super.onCreate(savedInstanceState);
//        //透明状态栏
        getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
        //设置夜间模式下,屏幕的亮度变暗,设置整个窗体的alpha值
        if(mTheme == R.style.AppTheme_Dark){
            WindowManager.LayoutParams lp=getWindow().getAttributes();
            lp.alpha=0.5f;
            getWindow().setAttributes(lp);
        }

    }
    @Override
    protected void onResume() {
        super.onResume();
        if (mTheme != PreferenceHelper.getTheme(this)) {
            reload();
        }
    }

    /**
     * 重启Activity,使其加载新的主题
     */
    protected void reload() {
        Intent intent = getIntent();
        overridePendingTransition(0, 0);
        intent.addFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION);
        finish();
        overridePendingTransition(0, 0);
        startActivity(intent);
    }
}

开关设置:这里面涉及一个PreferenceHelper,是用来存储theme数据的。这个忘记是从哪里拷贝过来的了

        switch_btn.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {

            @Override
            public void onCheckedChanged(CompoundButton arg0, boolean checked) {

                if(checked){
                    //选择夜间模式
                    PreferenceHelper.setTheme(getActivity(),
                            R.style.AppTheme_Dark);
                    reload();
                }else{
                    PreferenceHelper.setTheme(getActivity(),
                            R.style.AppTheme_Blue);
                    reload();
                }
            }
        });

PreferenceHelper.java


/**
 * 保存preference数据
 * Created by gaos on 2016/7/20.
 */
public class PreferenceHelper {
    public static final String KEY_THEME			= "theme";
    private static SharedPreferences.Editor mEditor = null;
    private static SharedPreferences mdPreferences = null;

    public PreferenceHelper(Context context) {
    }
    private static SharedPreferences.Editor getEditor(Context paramContext) {
        if (mEditor == null)
            mEditor = PreferenceManager.getDefaultSharedPreferences(paramContext).edit();
        return mEditor;
    }

    private static SharedPreferences getSharedPreferences(Context paramContext) {
        if (mdPreferences == null)
            mdPreferences = PreferenceManager.getDefaultSharedPreferences(paramContext);
        return mdPreferences;
    }
    public static int getTheme(Context context){
        return PreferenceHelper.getSharedPreferences(context).getInt(KEY_THEME, R.style.AppTheme_Blue);
    }

    public static void setTheme(Context context, int theme){
        getEditor(context).putInt(KEY_THEME, theme).commit();
    }

 

  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 5
博文 15
码字总数 3339
×
竹蜻蜓O_0纸飞机
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: