|
|
/*
|
|
|
* Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
|
|
|
*
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
* You may obtain a copy of the License at
|
|
|
*
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
*
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
* See the License for the specific language governing permissions and
|
|
|
* limitations under the License.
|
|
|
*/
|
|
|
|
|
|
// ResourceParser.java - 资源解析工具类
|
|
|
// 主要功能:管理便签应用的颜色主题、背景资源、字体大小等UI相关资源的映射和获取
|
|
|
package net.micode.notes.tool;
|
|
|
|
|
|
// ======================= 导入区域 =======================
|
|
|
// Android相关类
|
|
|
import android.content.Context; // 上下文,用于访问偏好设置
|
|
|
import android.preference.PreferenceManager; // 偏好设置管理器
|
|
|
|
|
|
// 应用内部资源
|
|
|
import net.micode.notes.R; // 资源文件R类
|
|
|
import net.micode.notes.ui.NotesPreferenceActivity; // 设置Activity,包含偏好设置键名
|
|
|
|
|
|
// ======================= 资源解析主类 =======================
|
|
|
/**
|
|
|
* ResourceParser - 资源解析工具类
|
|
|
* 集中管理便签应用的UI资源映射关系
|
|
|
* 包括:背景颜色、字体大小、编辑界面背景、列表项背景、小部件背景等
|
|
|
*/
|
|
|
public class ResourceParser {
|
|
|
|
|
|
// ======================= 便签背景颜色常量 =======================
|
|
|
/**
|
|
|
* 便签背景颜色类型常量
|
|
|
* 对应五种不同的便签背景颜色主题
|
|
|
*/
|
|
|
public static final int YELLOW = 0; // 黄色主题
|
|
|
public static final int BLUE = 1; // 蓝色主题
|
|
|
public static final int WHITE = 2; // 白色主题
|
|
|
public static final int GREEN = 3; // 绿色主题
|
|
|
public static final int RED = 4; // 红色主题
|
|
|
|
|
|
/** 默认背景颜色索引 - 应用启动时的默认颜色 */
|
|
|
public static final int BG_DEFAULT_COLOR = YELLOW; // 默认为黄色
|
|
|
|
|
|
// ======================= 字体大小常量 =======================
|
|
|
/**
|
|
|
* 字体大小类型常量
|
|
|
* 对应四种不同的字体大小级别
|
|
|
*/
|
|
|
public static final int TEXT_SMALL = 0; // 小号字体
|
|
|
public static final int TEXT_MEDIUM = 1; // 中号字体
|
|
|
public static final int TEXT_LARGE = 2; // 大号字体
|
|
|
public static final int TEXT_SUPER = 3; // 超大号字体
|
|
|
|
|
|
/** 默认字体大小索引 - 应用启动时的默认字体大小 */
|
|
|
public static final int BG_DEFAULT_FONT_SIZE = TEXT_MEDIUM; // 默认为中号字体
|
|
|
|
|
|
// ======================= 编辑界面背景资源类 =======================
|
|
|
/**
|
|
|
* NoteBgResources - 便签编辑界面背景资源类
|
|
|
* 管理便签编辑页面的背景图片资源
|
|
|
*/
|
|
|
public static class NoteBgResources {
|
|
|
// 便签编辑区域背景资源数组
|
|
|
// 数组索引对应颜色常量:0=黄, 1=蓝, 2=白, 3=绿, 4=红
|
|
|
private final static int [] BG_EDIT_RESOURCES = new int [] {
|
|
|
R.drawable.edit_yellow, // 黄色编辑背景
|
|
|
R.drawable.edit_blue, // 蓝色编辑背景
|
|
|
R.drawable.edit_white, // 白色编辑背景
|
|
|
R.drawable.edit_green, // 绿色编辑背景
|
|
|
R.drawable.edit_red // 红色编辑背景
|
|
|
};
|
|
|
|
|
|
// 便签标题栏背景资源数组
|
|
|
// 与编辑区域背景对应,但用于标题栏部分
|
|
|
private final static int [] BG_EDIT_TITLE_RESOURCES = new int [] {
|
|
|
R.drawable.edit_title_yellow, // 黄色标题背景
|
|
|
R.drawable.edit_title_blue, // 蓝色标题背景
|
|
|
R.drawable.edit_title_white, // 白色标题背景
|
|
|
R.drawable.edit_title_green, // 绿色标题背景
|
|
|
R.drawable.edit_title_red // 红色标题背景
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 获取便签编辑区域背景资源ID
|
|
|
* @param id 颜色索引(YELLOW/BLUE/WHITE/GREEN/RED)
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteBgResource(int id) {
|
|
|
return BG_EDIT_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取便签标题栏背景资源ID
|
|
|
* @param id 颜色索引(YELLOW/BLUE/WHITE/GREEN/RED)
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteTitleBgResource(int id) {
|
|
|
return BG_EDIT_TITLE_RESOURCES[id];
|
|
|
}
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取默认背景颜色ID
|
|
|
* 根据用户设置决定:随机颜色或默认颜色
|
|
|
* @param context 上下文,用于读取偏好设置
|
|
|
* @return 背景颜色索引
|
|
|
*/
|
|
|
public static int getDefaultBgId(Context context) {
|
|
|
// 从偏好设置读取是否启用随机背景颜色
|
|
|
if (context.getSharedPreferences(NotesPreferenceActivity.PREFERENCE_NAME, Context.MODE_PRIVATE).getBoolean(
|
|
|
NotesPreferenceActivity.PREFERENCE_SET_BG_COLOR_KEY, // 偏好设置键名
|
|
|
false)) { // 默认值为false(不随机)
|
|
|
// 随机选择一种颜色
|
|
|
return (int) (Math.random() * NoteBgResources.BG_EDIT_RESOURCES.length);
|
|
|
} else {
|
|
|
// 使用默认颜色
|
|
|
return BG_DEFAULT_COLOR;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// ======================= 列表项背景资源类 =======================
|
|
|
/**
|
|
|
* NoteItemBgResources - 便签列表项背景资源类
|
|
|
* 管理便签列表界面中各项的背景图片资源
|
|
|
* 支持不同位置的项使用不同背景(首项、中间项、末项、单独项)
|
|
|
*/
|
|
|
public static class NoteItemBgResources {
|
|
|
// 列表首项背景资源数组
|
|
|
// 用于列表中的第一个项(顶部圆角)
|
|
|
private final static int [] BG_FIRST_RESOURCES = new int [] {
|
|
|
R.drawable.list_yellow_up, // 黄色首项背景
|
|
|
R.drawable.list_blue_up, // 蓝色首项背景
|
|
|
R.drawable.list_white_up, // 白色首项背景
|
|
|
R.drawable.list_green_up, // 绿色首项背景
|
|
|
R.drawable.list_red_up // 红色首项背景
|
|
|
};
|
|
|
|
|
|
// 列表中间项背景资源数组
|
|
|
// 用于列表中非首尾的中间项(直角)
|
|
|
private final static int [] BG_NORMAL_RESOURCES = new int [] {
|
|
|
R.drawable.list_yellow_middle, // 黄色中间项背景
|
|
|
R.drawable.list_blue_middle, // 蓝色中间项背景
|
|
|
R.drawable.list_white_middle, // 白色中间项背景
|
|
|
R.drawable.list_green_middle, // 绿色中间项背景
|
|
|
R.drawable.list_red_middle // 红色中间项背景
|
|
|
};
|
|
|
|
|
|
// 列表末项背景资源数组
|
|
|
// 用于列表中的最后一个项(底部圆角)
|
|
|
private final static int [] BG_LAST_RESOURCES = new int [] {
|
|
|
R.drawable.list_yellow_down, // 黄色末项背景
|
|
|
R.drawable.list_blue_down, // 蓝色末项背景
|
|
|
R.drawable.list_white_down, // 白色末项背景
|
|
|
R.drawable.list_green_down, // 绿色末项背景
|
|
|
R.drawable.list_red_down, // 红色末项背景
|
|
|
};
|
|
|
|
|
|
// 列表单独项背景资源数组
|
|
|
// 用于列表中只有一个项的情况(上下都有圆角)
|
|
|
private final static int [] BG_SINGLE_RESOURCES = new int [] {
|
|
|
R.drawable.list_yellow_single, // 黄色单独项背景
|
|
|
R.drawable.list_blue_single, // 蓝色单独项背景
|
|
|
R.drawable.list_white_single, // 白色单独项背景
|
|
|
R.drawable.list_green_single, // 绿色单独项背景
|
|
|
R.drawable.list_red_single // 红色单独项背景
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 获取列表首项背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteBgFirstRes(int id) {
|
|
|
return BG_FIRST_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取列表末项背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteBgLastRes(int id) {
|
|
|
return BG_LAST_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取列表单独项背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteBgSingleRes(int id) {
|
|
|
return BG_SINGLE_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取列表中间项背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getNoteBgNormalRes(int id) {
|
|
|
return BG_NORMAL_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取文件夹项背景资源ID
|
|
|
* 文件夹使用统一的背景,不区分颜色
|
|
|
* @return 文件夹专用背景资源ID
|
|
|
*/
|
|
|
public static int getFolderBgRes() {
|
|
|
return R.drawable.list_folder;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// ======================= 小部件背景资源类 =======================
|
|
|
/**
|
|
|
* WidgetBgResources - 桌面小部件背景资源类
|
|
|
* 管理不同尺寸桌面小部件的背景图片资源
|
|
|
*/
|
|
|
public static class WidgetBgResources {
|
|
|
// 2x尺寸小部件背景资源数组
|
|
|
// 用于2x2尺寸的桌面小部件
|
|
|
private final static int [] BG_2X_RESOURCES = new int [] {
|
|
|
R.drawable.widget_2x_yellow, // 黄色2x小部件背景
|
|
|
R.drawable.widget_2x_blue, // 蓝色2x小部件背景
|
|
|
R.drawable.widget_2x_white, // 白色2x小部件背景
|
|
|
R.drawable.widget_2x_green, // 绿色2x小部件背景
|
|
|
R.drawable.widget_2x_red, // 红色2x小部件背景
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 获取2x尺寸小部件背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getWidget2xBgResource(int id) {
|
|
|
return BG_2X_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
// 4x尺寸小部件背景资源数组
|
|
|
// 用于4x4尺寸的桌面小部件
|
|
|
private final static int [] BG_4X_RESOURCES = new int [] {
|
|
|
R.drawable.widget_4x_yellow, // 黄色4x小部件背景
|
|
|
R.drawable.widget_4x_blue, // 蓝色4x小部件背景
|
|
|
R.drawable.widget_4x_white, // 白色4x小部件背景
|
|
|
R.drawable.widget_4x_green, // 绿色4x小部件背景
|
|
|
R.drawable.widget_4x_red // 红色4x小部件背景
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 获取4x尺寸小部件背景资源ID
|
|
|
* @param id 颜色索引
|
|
|
* @return 对应的drawable资源ID
|
|
|
*/
|
|
|
public static int getWidget4xBgResource(int id) {
|
|
|
return BG_4X_RESOURCES[id];
|
|
|
}
|
|
|
}
|
|
|
|
|
|
// ======================= 文本外观资源类 =======================
|
|
|
/**
|
|
|
* TextAppearanceResources - 文本外观资源类
|
|
|
* 管理便签内容的字体大小样式资源
|
|
|
* 包含对偏好设置中存储异常的处理
|
|
|
*/
|
|
|
public static class TextAppearanceResources {
|
|
|
// 文本外观样式资源数组
|
|
|
// 索引对应字体大小常量:0=小, 1=中, 2=大, 3=超大
|
|
|
private final static int [] TEXTAPPEARANCE_RESOURCES = new int [] {
|
|
|
R.style.TextAppearanceNormal, // 小号字体样式
|
|
|
R.style.TextAppearanceMedium, // 中号字体样式
|
|
|
R.style.TextAppearanceLarge, // 大号字体样式
|
|
|
R.style.TextAppearanceSuper // 超大号字体样式
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
* 获取文本外观样式资源ID
|
|
|
* 包含对偏好设置中存储错误ID的修复处理
|
|
|
* @param id 字体大小索引
|
|
|
* @return 对应的style资源ID
|
|
|
*/
|
|
|
public static int getTexAppearanceResource(int id) {
|
|
|
/**
|
|
|
* HACKME: 修复在偏好设置中存储资源ID的bug
|
|
|
* 问题:从偏好设置读取的id可能超过资源数组长度
|
|
|
* 解决:如果id超出范围,返回默认字体大小
|
|
|
*/
|
|
|
if (id >= TEXTAPPEARANCE_RESOURCES.length) {
|
|
|
return BG_DEFAULT_FONT_SIZE; // 返回默认字体大小索引
|
|
|
}
|
|
|
return TEXTAPPEARANCE_RESOURCES[id];
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
* 获取文本外观资源数组长度
|
|
|
* 用于验证和边界检查
|
|
|
* @return 字体大小样式总数
|
|
|
*/
|
|
|
public static int getResourcesSize() {
|
|
|
return TEXTAPPEARANCE_RESOURCES.length;
|
|
|
}
|
|
|
}
|
|
|
} |