NotePad功能扩展(1)


  • UI美化(设置背景颜色,选中时的笔记背景颜色变换)

  • 更换背景

功能解析


  • UI美化(设置背景颜色,选中时的便签背景颜色变换)

NotePad源码中的应用,只有简单的笔记黑色主题。本功能对此进行扩展,给予notePad一个新的主题

  1. 在AndroidManifest.xml中增加一句代码将NotePad换为白色主题

<activity

android:name=“.NoteSearch”

android:label=“NoteSearch”

android:theme=“@android:style/Theme.Holo.Light”

  1. 让笔记的每条笔记都具有自己的背景颜色,所以选择在数据库中增加一个字段“color”用于存放每条笔记的背景颜色。先在NotePad.java 中设置颜色编号

public static final String COLUMN_NAME_BACK_COLOR = “color”;

public static final int DEFAULT_COLOR = 0;

public static final int YELLOW_COLOR = 1;

public static final int BLUE_COLOR = 2;

public static final int GREEN_COLOR = 3;

public static final int RED_COLOR = 4;

  1. 在NotePadProvider.java中修改创建数据库的语句

(如果数据库已创建需要将数据库删除重新运行一遍程序)

public void onCreate(SQLiteDatabase db) {

db.execSQL(“CREATE TABLE " + NotePad.Notes.TABLE_NAME + " (”

  • NotePad.Notes._ID + " INTEGER PRIMARY KEY,"

  • NotePad.Notes.COLUMN_NAME_TITLE + " TEXT,"

  • NotePad.Notes.COLUMN_NAME_NOTE + " TEXT,"

  • NotePad.Notes.COLUMN_NAME_CREATE_DATE + " INTEGER,"

  • NotePad.Notes.COLUMN_NAME_MODIFICATION_DATE + " INTEGER,"

  • NotePad.Notes.COLUMN_NAME_BACK_COLOR + " INTEGER" //数据库增加color属性

  • “);”);

}

  1. 实例化和设置静态对象的块

static{

·····

// add Maps “color” to “color”

sNotesProjectionMap.put(

NotePad.Notes.COLUMN_NAME_BACK_COLOR,

NotePad.Notes.COLUMN_NAME_BACK_COLOR);

·····

}

  1. 增加创建新笔记时需要执行的语句,给每条笔记设置默认背景颜色

// 笔记背景默认为白色

if (values.containsKey(NotePad.Notes.COLUMN_NAME_BACK_COLOR) == false) {

values.put(NotePad.Notes.COLUMN_NAME_BACK_COLOR, NotePad.Notes.DEFAULT_COLOR);

}

  1. 笔记列表显示时从数据库中读取color的代码,所以在NoteList和NoteSearch中的PROJECTION添加color属性

private static final String[] PROJECTION = new String[] {

NotePad.Notes._ID, // 0

NotePad.Notes.COLUMN_NAME_TITLE, // 1

//扩展 显示时间戳

NotePad.Notes.COLUMN_NAME_MODIFICATION_DATE,

//扩展 显示笔记背景颜色

NotePad.Notes.COLUMN_NAME_BACK_COLOR,

};

  1. 使用bindView将颜色填充到ListView。新建一个MyCursorAdapter继承SimpleCursorAdapter

public class MyCursorAdapter extends SimpleCursorAdapter {

public MyCursorAdapter(Context context, int layout, Cursor c,

String[] from, int[] to) {

super(context, layout, c, from, to);

}

@Override

public void bindView(View view, Context context, Cursor cursor){

super.bindView(view, context, cursor);

//从数据库中读取的先前存入的笔记背景颜色的编码,再设置笔记的背景颜色

int x = cursor.getInt(cursor.getColumnIndex(NotePad.Notes.COLUMN_NAME_BACK_COLOR));

switch (x){

case NotePad.Notes.DEFAULT_COLOR:

view.setBackgroundColor(Color.rgb(255, 255, 255));

break;

case NotePad.Notes.YELLOW_COLOR:

view.setBackgroundColor(Color.rgb(247, 216, 133));

break;

case NotePad.Notes.BLUE_COLOR:

view.setBackgroundColor(Color.rgb(165, 202, 237));

break;

case NotePad.Notes.GREEN_COLOR:

view.setBackgroundColor(Color.rgb(161, 214, 174));

break;

case NotePad.Notes.RED_COLOR:

view.setBackgroundColor(Color.rgb(244, 149, 133));

break;

default:

view.setBackgroundColor(Color.rgb(255, 255, 255));

break;

}

}

}

  1. 将NoteList和NoteSearch里的适配器改为MyCursorAdapter

MyCursorAdapter adapter

= new MyCursorAdapter(

this,

R.layout.noteslist_item,

cursor,

dataColumns,

viewIDs

);

  1. 新建colors.xml和color_select.xml。选中时的笔记时笔记的背景颜色会改变

#be96df

<item android:drawable=“@color/color1”

android:state_pressed=“true”/>

  1. 在notelist_item.xml里为控件添加选择器

android:background=“@drawable/color_select”

  1. 模拟器截图

UI

Ui

ui

select

  • 更换背景颜色
  1. 为了编辑笔记的时候可以显示背景颜色(显示时能查询到color数据),在NoteEditor.java中增加color属性

private static final String[] PROJECTION =

new String[] {

NotePad.Notes._ID,

NotePad.Notes.COLUMN_NAME_TITLE,

NotePad.Notes.COLUMN_NAME_NOTE,

//增加 背景颜色

NotePad.Notes.COLUMN_NAME_BACK_COLOR

};

  1. 在onResume()中增加设置背景颜色的代码

//读取颜色数据

if(mCursor!=null){

mCursor.moveToFirst();

int x = mCursor.getColumnIndex(NotePad.Notes.COLUMN_NAME_BACK_COLOR);

int y = mCursor.getInt(x);

Log.i(“NoteEditor”, “color”+y);

switch (y){

case NotePad.Notes.DEFAULT_COLOR:

mText.setBackgroundColor(Color.rgb(255, 255, 255));

break;

case NotePad.Notes.YELLOW_COLOR:

mText.setBackgroundColor(Color.rgb(247, 216, 133));

break;

case NotePad.Notes.BLUE_COLOR:

mText.setBackgroundColor(Color.rgb(165, 202, 237));

break;

case NotePad.Notes.GREEN_COLOR:

mText.setBackgroundColor(Color.rgb(161, 214, 174));

break;

case NotePad.Notes.RED_COLOR:

mText.setBackgroundColor(Color.rgb(244, 149, 133));

break;

default:

mText.setBackgroundColor(Color.rgb(255, 255, 255));

break;

}

}

  1. 在editor_options_menu.xml中添加一个更改背景的按钮

<item android:id=“@+id/menu_color”

android:title=“color”

android:icon=“@drawable/ic_menu_edit”

android:showAsAction=“always”/>

  1. 往NoteEditor.java中添加增加上一步新增的选项的执行语句,在onOptionsItemSelected()的switch中添加代码

case R.id.menu_color://跳转改变颜色的activity

Intent intent = new Intent(null,mUri);

intent.setClass(NoteEditor.this,NoteColor.class);

NoteEditor.this.startActivity(intent);

break;

  1. 新建选择背景颜色的布局note_color.xml

<ImageButton

android:id=“@+id/color_white”

android:layout_width=“0dp”

android:layout_height=“50dp”

android:layout_weight=“1”

android:background=“#ffffff”

android:onClick=“white”/>

资源分享

一线互联网面试专题

379页的Android进阶知识大全

379页的Android进阶知识大全

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

2020年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
android:layout_weight=“1”

android:background=“#ffffff”

android:onClick=“white”/>

资源分享

[外链图片转存中…(img-N4mXJeIF-1715854362042)]

[外链图片转存中…(img-vgqTj1hD-1715854362045)]

[外链图片转存中…(img-I3wt7WTr-1715854362046)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

2020年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值