Listtile Multi-select - Flutter Firestore Streambuilder - PullRequest
0 голосов
/ 23 февраля 2020

Мне нужна помощь в создании приложения для викторины с флаттером, я использую Firestore для своих данных и хочу добавить вопрос с несколькими вариантами ответов, поэтому, когда пользователь нажимает на один из вариантов, он выделяется, как в этом примере

(я использую этот GIF из другого вопроса, потому что я не знал, как объяснить)

это то, что у меня есть для сейчас

это мой код:

Widget _buildListItem(BuildContext context, DocumentSnapshot document) {

return ListTile(
  title: Container(
    margin: EdgeInsets.all(8.0),
    padding: EdgeInsets.fromLTRB(210, 0.0, 0.0, 0.0),
    decoration: BoxDecoration(
        color: Colors.white,
        border: Border.all(
            color: Colors.pink[800], // set border color
            width: 3.0), // set border width
        borderRadius: BorderRadius.all(
            Radius.circular(10.0)), // set rounded corner radius
        boxShadow: [
          BoxShadow(
              blurRadius: 5,
              color: Colors.black,
              offset: Offset(0.5, 1))
        ] // make rounded corner of border
        ),
      child: Row(
          children: <Widget>[
        Container(
            child: Text(
              document['rep'],
              style: TextStyle(
                fontSize: 50.0,
                color: Colors.black,
              ),
            ),
        )

          ]
      ),
  ),

  onTap: () {
    Firestore.instance.runTransaction(
            (transaction) async {
      DocumentSnapshot freshSnap =
      await transaction.get(document.reference);
      await transaction.update(freshSnap.reference, {
        'votes': freshSnap['votes'] + 1,
      });
    });


  },

);

}

@ переопределить сборку виджета (контекст BuildContext) ) {возврат Эшафот (тело: Контейнер (

    child: StreamBuilder(
        stream: Firestore.instance.collection('questions').snapshots(),
        builder: (context, snapshot) {
          if (!snapshot.hasData) return const Text('Loading ...');
          return ListView.builder(
              padding: EdgeInsets.fromLTRB(50.0, 300.0, 50.0, 0.0),
              itemExtent: 100.0,
              itemCount: snapshot.data.documents.length,
              itemBuilder: (context, index) =>
                  _buildListItem(context, snapshot.data.documents[index]),
            );

        }),

  ),

  floatingActionButton: FloatingActionButton(
    onPressed: () {
      Navigator.push(
          context, MaterialPageRoute(builder: (context) => new Home()));
    },
    child: Text("Home"),
  ),

);

}

большое спасибо!

1 Ответ

0 голосов
/ 23 февраля 2020

Фрагмент списка с цветным контейнером:

itemBuilder: (context, index){
 return Container(
     color: isSelected[index] ? Colors.blue : null,
     child: ListTile(title:'test'),
 );
}                  

Изменение статуса выбора при прикосновении к элементу.

ListTile(
    title: Text('test'),
    selected: isSelected[index],
    onTap: () {
      setState(() {
        isSelected[index] = !isSelected[index];
      });
    },
),
final List<bool> isSelected;

Попробуйте DartPad

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...