700개 이상의 실습 및 과정 이용하기

Working with Onscreen Data in a Flutter Application

실습 1시간 30분 universal_currency_alt 크레딧 1개 show_chart 입문
info 이 실습에는 학습을 지원하는 AI 도구가 통합되어 있을 수 있습니다.
700개 이상의 실습 및 과정 이용하기

GSP1011

Google Cloud self-paced labs logo

Overview

Flutter is Google's UI toolkit for building beautiful, natively compiled applications for mobile, web, and desktop from a single codebase. Flutter works with existing code, is used by developers and organizations around the world, and is free and open source.

In this lab, you will create a Flutter app using generated template code. The basic Flutter interface provides a simple example to get started programming in Flutter.

The Flutter UI displaying the Google Products title and a list of subtitles on a mobile phone screen

What you'll learn

  • How to write a Flutter app that looks natural on iOS, Android, and the web
  • Basic structure of a Flutter app
  • Using multiple pages
  • Using hot reload for a quicker development cycle

Prerequisites

Based on the content, it is recommended to have some familiarity with:

  • Flutter
  • Dart

Task 1. Open the Code Server Editor

In this lab, you will use a custom editor that includes the Flutter and Dart extensions. From the initial lab panel:

The Lab Details panel displaying the IDE and Live Server links

  1. Copy the Flutter IDE address displayed.
  2. Paste the Editor address into a Browser tab.

Task 2. Creating a Flutter Template

In this section create a Flutter Web application called first_app.

  1. Click the hamburger button (i.e. Left hand side, three horizontal lines Navigation menu icon).
  2. Open a Terminal within the browser by selecting New Terminal.

The navigation path to the New Terminal is displayed

  1. In the terminal enter the following command:
flutter create first_app
  1. Move to the first_app directory:
cd first_app
  1. Close the terminal window:
exit

The first_app directory and template code have now been created.

Task 3. Opening the new app

In this section explore the Flutter Web application called first_app.

  1. Open the folder first_app.
  2. Acknowledge the on-screen notifications.

At this point you will have the Flutter application open in the current workspace.

Task 4. Running the Flutter Web application

In this section run the Flutter Web application from the command line.

  1. In the editor, open a Terminal.
  2. Ensure the terminal directory is set to first_app.
  3. Run the Flutter web server:
fwr
  1. The running web server should look similar to below:

The running web server messages

  1. Copy the Flutter Live Server address from the lab Panel.
  2. Paste the address into a new browser tab.

The browser will render the web application e.g.

The Flutter Demo Home Page with the message 'You have pushed the button this many times: 0" displayed on a mobile phone screen

Note: Rendering of the web application can take upto ten seconds. The view will show the application based on the code in the editor.

Feel free to interact with the running application

Task 5. Adding Boilerplate code

In this section, replace the Flutter starter code with the example for this lab.

  1. Replace the contents of lib\main.dart with the code below:
import 'package:flutter/material.dart'; // TODO: Embedded List class GoogleProducts { final List<String> items = [ 'Cloud Functions', 'App Engine', 'Kubernetes Engine', 'Compute Engine', 'Bare Metal', 'Preemptible VMs', 'Shielded VMs', 'Sole-tenet Nodes', 'VMWare Engine', 'Cloud Firestore', 'Cloud Storage', 'Persistent Disk', 'Local SSD', 'Cloud Bigtable', 'Cloud Firestore', 'Cloud Memorystore', 'Cloud Spanner', ]; } void main() { runApp(const MyApp()); } class MyApp extends StatelessWidget { const MyApp({Key? key}) : super(key: key); @override Widget build(BuildContext context) { const title = 'Google Products'; return const MaterialApp( title: title, debugShowCheckedModeBanner: false, home: ProductHomeWidget(title), ); } } // TODO: ProductHomeWidget class ProductHomeWidget extends StatelessWidget { final String title; const ProductHomeWidget(this.title, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( // backgroundColor: Colors.white, appBar: AppBar( // backgroundColor: Colors.transparent, // elevation: 0, // TODO: Enable AppBarLeading // leading: const AppBarLeading(), // TODO: Enable AppBarLeading // actions: const [ // AppBarActionsShare(), // ], title: Text(title, style: const TextStyle(color: Colors.black)), ), // body: ProductListView(), ); } } // TODO: AppBarLeading class AppBarLeading extends StatelessWidget { const AppBarLeading({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return const IconButton( icon: Icon( Icons.menu, ), onPressed: null, ); } } // TODO: AppBarActionsShare class AppBarActionsShare extends StatelessWidget { const AppBarActionsShare({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return IconButton( icon: const Icon( Icons.share, ), onPressed: () { const snackBar = SnackBar(content: Text('You selected the Share Action')); ScaffoldMessenger.of(context).showSnackBar(snackBar); }); } } // TODO: ProductListView class ProductListView extends StatelessWidget { final googleProducts = GoogleProducts(); ProductListView({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return ListView.builder( itemCount: googleProducts.items.length, itemBuilder: (context, index) { return ProductListTile(googleProducts.items[index]); }, ); } } // TODO: ProductListTile class ProductListTile extends StatelessWidget { final String? productLabel; const ProductListTile(this.productLabel, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return ListTile( title: Text('$productLabel', style: const TextStyle(color: Colors.black)), subtitle: const Text('SubTitle', style: TextStyle(color: Colors.black)), leading: const Icon(Icons.help_center_outlined, color: Colors.black), // When the child is tapped, show a snackbar. onTap: () { // TODO: Enable onTap // final snackBar = SnackBar(content: Text('You selected $productLabel')); // ScaffoldMessenger.of(context).showSnackBar(snackBar); // TODO: Navigation to the Details Page // Navigator.push( // context, // MaterialPageRoute(builder: (context) => const MyDetails()), // ); }, ); } } // TODO: Add a details page // class MyDetails extends StatelessWidget { // const MyDetails({Key? key}) : super(key: key); // @override // Widget build(BuildContext context) { // const title = 'Details Page'; // return Scaffold( // // backgroundColor: Colors.white, // appBar: AppBar( // iconTheme: const IconThemeData( // color: Colors.grey, //change your color here // ), // backgroundColor: Colors.transparent, // elevation: 0, // // leading: const AppBarLeading(), // actions: const [ // AppBarActionsShare(), // ], // title: const Text(title, style: TextStyle(color: Colors.black)), // ), // // appBar: AppBar( // // title: const Text(title), // // ), // body: const Center( // child: Text('Hello Details Page')), // ); // } // }
  1. After updating lib\main.dart with the boilerplate code, refresh the application.

The Flutter app should now look similar to the image below:

The Google Products title displayed on a mobile phone screen

In the next section, we outline the application we will build in this lab.

Task 6. Designing our application

In this section we use widgets to build a basic two screen application.

A two screen application sketch

From the above sketch we note that our application uses the following types of widgets.

Widget Description
AppBar Header bar
Scaffold Screen layout
Text Text entry fields
ListView Item list

In the next section, we discuss the AppBar and its key properties.

Task 7. Working with AppBar

In this section you will build a basic AppBar configuration. The Flutter page will look similar to the image below:

One frame has a Google Cloud title bar and a share icon. Another frame has 'ProductHome Widget' as the title, as well as a leading, a title, and an actions bar

The AppBar is used to show details about the application functionality. In our application we populate the AppBar with three items:

Property Description
leading An icon placed at the left side of the AppBar
title A title placed on the App Bar
actions An icon placed on the right side of the AppBar

In the next section, learn how to enhance an AppBar.

Adding AppBar icons

Update the AppBar leading setting to reference the function AppBarLeading.

  1. Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Enable AppBarLeading // leading: const AppBarLeading(),

Your code should now look like this:

Widget build(BuildContext context) { return Scaffold( // backgroundColor: Colors.white, appBar: AppBar( // backgroundColor: Colors.transparent, // elevation: 0, // TODO: Enable AppBarLeading leading: const AppBarLeading(), // actions: const [ // AppBarActionsShare(), // ], title: Text(title, style: const TextStyle(color: Colors.black)), ), // body: ProductListView(), ); }
  1. Perform a hot restart to review the changes to the Flutter user interface.
Note: The example uses the Icon.menu option, but you can also customize the icon used.

Adding AppBar actions

Update the AppBar actions setting to reference the function AppBarActionsShare.

  1. Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Enable AppBarActionsShare // actions: const [ // AppBarActionsShare(), // ],

Your code should now look like this:

Widget build(BuildContext context) { return Scaffold( // backgroundColor: Colors.white, appBar: AppBar( // backgroundColor: Colors.transparent, // elevation: 0, leading: const AppBarLeading(), // TODO: Enable AppBarActionsShare actions: const [ AppBarActionsShare(), ], title: Text(title, style: const TextStyle(color: Colors.black)), ), // body: ProductListView(), ); }
  1. Perform a hot restart to review the changes to the Flutter user interface.
Note: Actions are a great way to enhance your application. In the above code we add a share icon. To make this functional, we would need to add some supporting code.

Styling the AppBar

Update the AppBar setting to make it more appealing.

  1. Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Style the AppBar // backgroundColor: Colors.white, appBar: AppBar( // backgroundColor: Colors.transparent, // elevation: 0,

Your code should now look like this:

Widget build(BuildContext context) { return Scaffold( // TODO: Style the AppBar backgroundColor: Colors.white, appBar: AppBar( backgroundColor: Colors.transparent, elevation: 0, leading: const AppBarLeading(), actions: const [ AppBarActionsShare(), ], title: Text(title, style: const TextStyle(color: Colors.black)), ), // body: ProductListView(), ); }
  1. Perform a hot restart to review the changes to the Flutter user interface.

The AppBar provides a lot of options and you should continue to explore its features. With the changes made, your application will look similar to the image below:

The Google Products title alongside a Share icon and navigation menu

At this point our application does not show any product data. In the next section, learn how to use a ListView to display data.

Task 8. Working with ListView

In this section use a ListView builder to show a list of items. Data for the list is defined in a class named GoogleProducts. Use the ListView to display the data as part of the application. The Flutter page will look similar to the image below:

A ListView vertical scroll sketch

In the image a ListView is used to display Google Cloud products.

Note: Using a ListView builder requires a data source. In this example we are using an embedded list of items. However you could also use data from an Asset folder or download the data from the internet.

Read more about working with Lists in the Flutter documentation.

In this exercise below, create a long list using a ListView.builder.

  1. Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Enable the ListView // body: ProductListView(),

Your code should now look like this:

Widget build(BuildContext context) { return Scaffold( backgroundColor: Colors.white, appBar: AppBar( backgroundColor: Colors.transparent, elevation: 0, leading: const AppBarLeading(), actions: const [ AppBarActionsShare(), ], title: Text(title, style: const TextStyle(color: Colors.black)), ), // TODO: Enable the ListView body: ProductListView(), ); }
  1. Perform a hot restart to review the changes to the Flutter user interface.

The application will show information relating to Google Cloud products in the list. In the next section, add some interactivity to the list items.

Task 9. Adding interactivity

In this section learn how to respond when a list item is selected. Add interactivity in Flutter typically requires a Gesture Detector. The type of gesture used in this section is associated with the onTap method. We want to see an on screen notification when the user registers a click on a ListView item.

A SnackBar provides a visual notification and can be used in conjunction with the onTap functionality.

  1. Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Enable onTap // onTap: () { // final snackBar = SnackBar(content: Text('You selected $productLabel')); // ScaffoldMessenger.of(context).showSnackBar(snackBar); // },

Your code should now look like this:

class ProductListTile extends StatelessWidget { final String? productLabel; const ProductListTile(this.productLabel, {Key? key}) : super(key: key); @override Widget build(BuildContext context) { return ListTile( title: Text('$productLabel', style: const TextStyle(color: Colors.black)), subtitle: const Text('SubTitle', style: TextStyle(color: Colors.black)), leading: const Icon(Icons.help_center_outlined, color: Colors.black), // TODO: Enable onTap onTap: () { final snackBar = SnackBar(content: Text('You selected $productLabel')); ScaffoldMessenger.of(context).showSnackBar(snackBar); }, ); } }
  1. Perform a hot restart to review the changes to the Flutter user interface.

The ListView is now present and will be populated with Google Products. It will also respond with a brief notification when an item is clicked.

The Google Products title alongside a navigation menu icon and Share icon, as well as a list of subtitles displayed on a mobile phone screen

In the next section, create a details page to show information about the product selected.

Task 10. Creating a Details page

In this section you will create a second Flutter page that will be used to display additional information.

The Google Products title alongside a navigation menu icon and Share icon, as well as the text 'Hello Details Page'

  • Find the following line(s) and uncomment the code (i.e. remove the // characters):
// TODO: Add a details page // class MyDetails extends StatelessWidget { // const MyDetails({Key? key}) : super(key: key); // // @override // Widget build(BuildContext context) { // const title = 'Details Page'; // // return Scaffold( // appBar: AppBar( // iconTheme: const IconThemeData( // color: Colors.grey, //change your color here // ), // backgroundColor: Colors.transparent, // elevation: 0, // // leading: const AppBarLeading(), // actions: const [ // AppBarActionsShare(), // ], // title: const Text(title, style: TextStyle(color: Colors.black)), // ), // body: const Center( // child: Text('Hello Details Page')), // ); // } // }

Your code should now look like this:

// TODO: Add a details page class MyDetails extends StatelessWidget { const MyDetails({Key? key}) : super(key: key); @override Widget build(BuildContext context) { const title = 'Details Page'; return Scaffold( appBar: AppBar( iconTheme: const IconThemeData( color: Colors.grey, //change your color here ), backgroundColor: Colors.transparent, elevation: 0, // leading: const AppBarLeading(), actions: const [ AppBarActionsShare(), ], title: const Text(title, style: TextStyle(color: Colors.black)), ), body: const Center( child: Text('Hello Details Page')), ); } } Note: Working with the AppBar

Flutter will automatically manage the leading icon. Therefore we do not need to include this option in the Details page AppBar.

If you want an Action to be present, then include the relevant action to be displayed.

Making the above changes ensures the Details AppBar has a similar look and feel to the parent page.

At this point the Details Page is not connected to the first page. Let's correct that in the next section.

Task 11. Navigating between pages

In this section enable navigation v1 between the first and second pages. Previously we enabled a SnackBar to indicate that an onTap event had occurred. We will disable the SnackBar functionality and replace it with Navigation. To achieve navigation will require the following activities:

  • Comment out the SnackBar code

  • Add a navigation between the pages

  • Point the navigation to the MyDetails class

  • Find the following line(s) and uncomment the code (i.e. remove the // characters):

@override Widget build(BuildContext context) { return ListTile( title: Text('$productLabel', style: const TextStyle(color: Colors.black)), subtitle: const Text('SubTitle', style: TextStyle(color: Colors.black)), leading: const Icon(Icons.help_center_outlined, color: Colors.black), // When the child is tapped, show a snackbar. onTap: () { // TODO: SnackBar onscreen notification final snackBar = SnackBar(content: Text('You selected $productLabel')); ScaffoldMessenger.of(context).showSnackBar(snackBar); // TODO: Navigation to the Details Page // Navigator.push( // context, // MaterialPageRoute(builder: (context) => const MyDetails()), // ); }, ); }

Your code should now look like this:

@override Widget build(BuildContext context) { return ListTile( title: Text('$productLabel', style: const TextStyle(color: Colors.black)), subtitle: const Text('SubTitle', style: TextStyle(color: Colors.black)), leading: const Icon(Icons.help_center_outlined, color: Colors.black), // When the child is tapped, show a snackbar. onTap: () { // TODO: SnackBar onscreen notification // final snackBar = SnackBar(content: Text('You selected $productLabel')); // ScaffoldMessenger.of(context).showSnackBar(snackBar); // TODO: Navigation to the Details Page Navigator.push( context, MaterialPageRoute(builder: (context) => const MyDetails()), ); }, ); } Note: The onTap method is updated to add comment lines on the previously enabled snackBar.

The page navigation (i.e. the Route) now takes precedence and maps between the first and second pages when an item is pressed.

The Details Page is now connected to the first page.

The Details Page title alongside a Back arrow and a Share icon with the text 'Hello Details Page' displayed on mobile phone screen

At this point you will be able to move between the pages using the onscreen navigation.

Click Check my progress to verify the objective. Assess my progress

Congratulations!

You have successfully completed the lab and demonstrated your knowledge of Flutter. Over the course of this lab, you have performed the following tasks:

  • Used a ListView widget
  • Refactored code to use ListView.builder
  • Added notifications to Flutter using a SnackBar widget
  • Declared a new Flutter page
  • Passed data between Flutter pages

Next steps / Learn more

Google Cloud training and certification

...helps you make the most of Google Cloud technologies. Our classes include technical skills and best practices to help you get up to speed quickly and continue your learning journey. We offer fundamental to advanced level training, with on-demand, live, and virtual options to suit your busy schedule. Certifications help you validate and prove your skill and expertise in Google Cloud technologies.

Manual Last Updated October 30, 2024

Lab Last Tested October 30, 2024

Copyright 2025 Google LLC. All rights reserved. Google and the Google logo are trademarks of Google LLC. All other company and product names may be trademarks of the respective companies with which they are associated.

시작하기 전에

  1. 실습에서는 정해진 기간 동안 Google Cloud 프로젝트와 리소스를 만듭니다.
  2. 실습에는 시간 제한이 있으며 일시중지 기능이 없습니다. 실습을 종료하면 처음부터 다시 시작해야 합니다.
  3. 화면 왼쪽 상단에서 실습 시작을 클릭하여 시작합니다.

시크릿 브라우징 사용

  1. 실습에 입력한 사용자 이름비밀번호를 복사합니다.
  2. 비공개 모드에서 콘솔 열기를 클릭합니다.

콘솔에 로그인

    실습 사용자 인증 정보를 사용하여
  1. 로그인합니다. 다른 사용자 인증 정보를 사용하면 오류가 발생하거나 요금이 부과될 수 있습니다.
  2. 약관에 동의하고 리소스 복구 페이지를 건너뜁니다.
  3. 실습을 완료했거나 다시 시작하려고 하는 경우가 아니면 실습 종료를 클릭하지 마세요. 이 버튼을 클릭하면 작업 내용이 지워지고 프로젝트가 삭제됩니다.

현재 이 콘텐츠를 이용할 수 없습니다

이용할 수 있게 되면 이메일로 알려드리겠습니다.

감사합니다

이용할 수 있게 되면 이메일로 알려드리겠습니다.

한 번에 실습 1개만 가능

모든 기존 실습을 종료하고 이 실습을 시작할지 확인하세요.

시크릿 브라우징을 사용하여 실습 실행하기

이 실습을 실행하려면 시크릿 모드 또는 시크릿 브라우저 창을 사용하세요. 개인 계정과 학생 계정 간의 충돌로 개인 계정에 추가 요금이 발생하는 일을 방지해 줍니다.