Simple Contact List with ListTile

Osarugue Enehizena
2 min readApr 24, 2019

--

According to the Flutter API reference documentation a ListTile is a single fixed-height row that typically contains some text as well as a leading or trailing icon.

Today, we are going to see how to build a simple Flutter app to enable us practice with the ListTile Class. We’ll call it SimpleContactList. This app will have just one screen which contains Names, Phone numbers, pictures and a right arrow icon as its trailing for each individual arranged as a list.

Add Images to Your Project

Open Android Studio and create a new flutter project. Delete all the code from lib/main.dart. Create a directory called images to store the images. To use these images we must add a few lines of code in our pubspec.yaml. In pubspec add a section named assets directly under uses-material-design. Make sure that these sections line up to avoid running into errors. Once you’re finished hit packages get in the top right corner of the window.

Create app in Stateless Widget

In the main.dat file create the main method which is an entry point to the app. We call runApp here. The main() method uses arrow (=>) notation. The app extends a StatelessWidget.

The Scaffold widget, from the Material library, provides a default app bar, title, and a body property that holds the widget tree for the screen. The body consists of a ListView Widget containing children Widget.

import 'package:flutter/material.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
final title = 'SimpleContactList';
return MaterialApp(
debugShowCheckedModeBanner: false,
title: title,
home: Scaffold(
appBar: AppBar(
title: Text(title),
),
body: ListView(
children: <Widget>[],
),
),
);
}
}

Add ListTile Widget

ListTile(
leading: CircleAvatar(
backgroundColor: Colors.white,
backgroundImage: AssetImage('images/avatar.png'),
),
title: Text(
'John Judah',
),
subtitle: Text('2348031980943'),
trailing: Icon(Icons.keyboard_arrow_right),
onTap: () {
Text('Another data');
},
),

Leading is the widget to display before the title, usually an Icon or a CircleAvatar widget. We used properties like background color and background Image to set color and images that display at the background.

Title is the primary content of the list tile typically a Text widget.

Subtitle is an additional content displayed below the title.

Trailing is widget to display after the title, typically an Icon widget. We used and keyboard_arrow_right icon.

onTap is called when the user taps this list tile.

Including Divider

new Divider(
height: 1.0,
indent: 1.0,
),

The Divider is a one device pixel thick horizontal line, with padding on either side.

Complete Code

--

--

Osarugue Enehizena
Osarugue Enehizena

Written by Osarugue Enehizena

Software Engineering & Project Leading | Building Bridges Between Faith & Tech🌍🙏💻

No responses yet