如何根据数据库中的数据修改Android SimpleCursorAdapter以使用不同的布局?

时间:2016-05-10 20:29:23

标签: android listview simplecursoradapter

我的Android应用程序有一个简单的聊天功能。聊天记录存储在板载SQLite数据库中。我正在使用带有SimpleCursorAdapter的ListView来显示聊天。这就是我所拥有的:

public class Chat extends Fragment {
    private View rootView;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState){
        rootView = inflater.inflate(R.layout.chat, container, false);
        return rootView;
    }

    @Override
    public void onViewCreated(View rootView, Bundle savedInstanceState){
        super.onViewCreated(rootView, savedInstanceState);
        displayChats();
    }

    public void displayChats(){
        DatabaseHelper databaseHelper = new DatabaseHelper(getActivity());
        Cursor chatCursor = databaseHelper.getChatsCursor();
        String[] fromColumns = {"messageInfo","messageText"};
        int toViews{R.id.message_info, R.id.message_text};
        SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(getContext(), R.layout.line_of_chat, chatCursor, fromColumns, toViews, 0);
        ListView listView = (ListView) rootView.findViewById(R.id.chat_text_display);
        listView.setAdapter(simpleCursorAdapter);
        databaseHelper.close();
    }
}

我有一个聊天模型,它有一个名为localFlag的布尔值作为其字段之一。如果从设备发送聊天,则localFlag设置为true(或1),如果从设备外部收到聊天,则localFlag设置为false(或0)。

我的SQL电话:

public static final String GET_ALL_CHATS = "select _id, localFlag, messageText, messageInfo from ChatTable";

public Cursor getChatsCursor(){
    SQLiteDatabase sqliteDB = this.getReadableDatabase();
    return sqliteDB.rawQuery(GET_ALL_CHATS, null);
}

我想要做的是如果设置了本地标志,我想使用它:

SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(getContext(), R.layout.outgoing_line_of_chat, chatCursor, fromColumns, toViews, 0);

如果没有设置本地标志,我想用这个:

SimpleCursorAdapter simpleCursorAdapter = new SimpleCursorAdapter(getContext(), R.layout.incoming_line_of_chat, chatCursor, fromColumns, toViews, 0);

注意我想使用R.layout.outgoing_line_of_chat vs R.layout.incoming_line_of_chat

我怎样才能完成这项工作?

2 个答案:

答案 0 :(得分:0)

如果我理解你的问题,我真的不会,但我会尽力帮助你。

您可以在Chat类中执行此操作:

if (localFlag) {
   ChatSimpleCursorAdapter simpleCursorAdapter = new ChatSimpleCursorAdapter(getContext(), R.layout.outgoing_line_of_chat, chatCursor, fromColumns, toViews, 0);
} else {
    ChatSimpleCursorAdapter simpleCursorAdapter = new ChatSimpleCursorAdapter(getContext(), R.layout.incoming_line_of_chat, chatCursor, fromColumns, toViews, 0);
}

或者来自ChatSimpleCursorAdapter的构造函数方法

if (localFlag) {
   layout = R.layout.outgoing_line_of_chat;
} else {
   layout = R.layout.incoming_line_of_chat;
}

super(getContext(), layout, chatCursor, fromColumns, toViews, 0);

答案 1 :(得分:0)

我在google搜索时发现了this帖子。它符合我的需要并且运作良好。希望这对未来的某些人来说会派上用场。这是一个自定义的SimpleCursorAdapter类,我必须创建它才能在Chat.java类中使用它:

public class ChatSimpleCursorAdapter extends SimpleCursorAdapter {
    private Context context;

    private ChatSimpleCursorAdapter(Context context, int layout, Cursor cursor, String[] from, int[] to, int flags){
        this.context = context;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent){
        if(convertView == null){
            LayoutInflater layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            switch(getItemViewType(position)){
                case 0:
                    convertView = layoutInflater.inflate(R.layout.incoming_line_of_chat, null);
                    break;
                case 1:
                    convertView = layoutInflater.inflate(R.layout.outgoing_line_of_chat, null);
                    break;
            }
        }

        return super.getView(position, convertView, parent);
    }

    @Override
    public int getItemViewType(int position){
        Cursor cursor = getCursor();
        cursor.moveToPosition(position);
        int localFlag = cursor.getInt(1);
        if(localFlag == 1){
            return 1;
        }
        return 0;
    }

    @Override
    public int getViewTypeCount(){
        return 2;
    }
}