You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
note/FoldersListAdapter.java

164 lines
7.7 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

/*
* 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.
*/
package net.micode.notes.ui;
import android.content.Context;
import android.database.Cursor;
import android.view.View;
import android.view.ViewGroup;
import android.widget.CursorAdapter;
import android.widget.LinearLayout;
import android.widget.TextView;
import net.micode.notes.R;
import net.micode.notes.data.Notes;
import net.micode.notes.data.Notes.NoteColumns;
public class FoldersListAdapter extends CursorAdapter {
public static final String [] PROJECTION = {
NoteColumns.ID,
NoteColumns.SNIPPET
};
public static final int ID_COLUMN = 0;
public static final int NAME_COLUMN = 1;
public FoldersListAdapter(Context context, Cursor c) {
super(context, c);
// TODO Auto-generated constructor stub
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return new FolderListItem(context);
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
if (view instanceof FolderListItem) {
String folderName = (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
.getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
((FolderListItem) view).bind(folderName);
}
}
public String getFolderName(Context context, int position) {
Cursor cursor = (Cursor) getItem(position);
return (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER) ? context
.getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
}
private class FolderListItem extends LinearLayout {
private TextView mName;
public FolderListItem(Context context) {
super(context);
inflate(context, R.layout.folder_list_item, this);
mName = (TextView) findViewById(R.id.tv_folder_name);
}
public void bind(String name) {
mName.setText(name);
}
}
}
package net.micode.notes.ui;
import android.content.Context;
import android.database.Cursor;
import android.view.View;
import android.view.ViewGroup;
import android.widget.CursorAdapter;
import android.widget.LinearLayout;
import android.widget.TextView;
import net.micode.notes.R;
import net.micode.notes.data.Notes;
import net.micode.notes.data.Notes.NoteColumns;
// FoldersListAdapter类继承自CursorAdapter它是一个用于将数据库游标Cursor中的数据适配到ListView等列表视图组件的适配器类
// 主要用于展示文件夹相关信息的列表,每个列表项对应一个文件夹的名称或特定标识,同时提供了获取文件夹名称等相关功能。
public class FoldersListAdapter extends CursorAdapter {
// 定义一个字符串数组,用于指定从数据库查询时需要获取的列名。
// 这里获取的是便签的唯一标识符ID和文件夹名称片段SNIPPET可能用于表示文件夹名称等相关信息两列。
public static final String [] PROJECTION = {
NoteColumns.ID,
NoteColumns.SNIPPET
};
// 定义常量表示查询结果中ID列对应的索引位置方便后续从Cursor中获取数据这里索引为0。
public static final int ID_COLUMN = 0;
// 定义常量表示查询结果中用于表示文件夹名称或名称片段列对应的索引位置方便后续从Cursor中获取数据这里索引为1。
public static final int NAME_COLUMN = 1;
// 构造函数用于初始化FoldersListAdapter实例接收上下文和数据库游标Cursor作为参数调用父类的构造函数完成基础的初始化工作。
public FoldersListAdapter(Context context, Cursor c) {
super(context, c);
// TODO Auto-generated constructor stub此处可能是预留的代码编写位置目前为空可根据后续需求添加额外的初始化逻辑。
}
// 重写CursorAdapter的newView方法该方法用于创建一个新的视图View对象作为列表中的一个新的列表项视图。
// 在这里创建并返回一个自定义的FolderListItem视图对象用于展示文件夹相关信息。
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return new FolderListItem(context);
}
// 重写CursorAdapter的bindView方法该方法用于将游标Cursor中当前位置的数据绑定到指定的视图View进行数据展示等操作。
@Override
public void bindView(View view, Context context, Cursor cursor) {
// 判断传入的视图是否是FolderListItem类型的实例确保进行正确的绑定操作。
if (view instanceof FolderListItem) {
// 获取文件夹名称相关信息根据游标中获取的ID列的值进行判断如果ID等于Notes.ID_ROOT_FOLDER可能是代表根文件夹的特定标识
// 则从资源文件中获取对应的特定字符串可能是表示“上级文件夹”之类的提示文本作为文件夹名称否则从游标中获取对应的名称列NAME_COLUMN的值作为文件夹名称。
String folderName = (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER)? context
.getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
// 调用FolderListItem的bind方法将获取到的文件夹名称设置到对应的视图中的TextView组件上进行显示。
((FolderListItem) view).bind(folderName);
}
}
// 定义一个方法,用于获取指定位置的文件夹名称,接收上下文和位置索引作为参数。
// 通过调用getItem方法获取对应位置的游标Cursor对象然后按照前面同样的逻辑判断并返回文件夹名称。
public String getFolderName(Context context, int position) {
Cursor cursor = (Cursor) getItem(position);
return (cursor.getLong(ID_COLUMN) == Notes.ID_ROOT_FOLDER)? context
.getString(R.string.menu_move_parent_folder) : cursor.getString(NAME_COLUMN);
}
// 定义一个内部类FolderListItem继承自LinearLayout它代表了列表中的一个文件夹列表项的自定义视图结构用于展示文件夹名称等信息。
private class FolderListItem extends LinearLayout {
// 定义一个TextView组件用于显示文件夹的名称信息。
private TextView mName;
// 构造函数用于初始化FolderListItem实例传入上下文对象调用父类的构造函数完成基础初始化
// 并加载对应的布局文件folder_list_item.xml到该视图中然后获取布局中的TextView组件。
public FolderListItem(Context context) {
super(context);
inflate(context, R.layout.folder_list_item, this);
mName = (TextView) findViewById(R.id.tv_folder_name);
}
// 定义一个方法用于将传入的文件夹名称设置到内部的TextView组件上进行显示实现数据与视图的绑定展示。
public void bind(String name) {
mName.setText(name);
}
}
}