mirror of
https://github.com/supleed2/ELEC60013-ES-CW1.git
synced 2024-11-10 01:35:50 +00:00
Added functionality for switching between pages
This commit is contained in:
parent
fd156f31e8
commit
3363d514a0
10
lib/data.dart
Normal file
10
lib/data.dart
Normal file
|
@ -0,0 +1,10 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class DataPage extends StatelessWidget {
|
||||
const DataPage({ Key? key }) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Text("Data Page");
|
||||
}
|
||||
}
|
|
@ -1,4 +1,8 @@
|
|||
import 'package:flutter/material.dart';
|
||||
import 'package:leg_barkr_app/data.dart';
|
||||
import 'package:leg_barkr_app/steps.dart';
|
||||
import 'package:leg_barkr_app/map.dart';
|
||||
import 'package:leg_barkr_app/settings.dart';
|
||||
|
||||
class HomeScreen extends StatefulWidget {
|
||||
const HomeScreen({Key? key}) : super(key: key);
|
||||
|
@ -8,21 +12,27 @@ class HomeScreen extends StatefulWidget {
|
|||
}
|
||||
|
||||
class _HomeScreenState extends State<HomeScreen> {
|
||||
int page = 0;
|
||||
PageController pageController = PageController();
|
||||
int _page = 0;
|
||||
PageController _pageController = PageController();
|
||||
|
||||
void onBottomBarPressed(int newPage) {
|
||||
void onBottomBarPressed(int page) {
|
||||
setState(() {
|
||||
page = newPage;
|
||||
_page = page;
|
||||
});
|
||||
pageController.jumpToPage(newPage);
|
||||
_pageController.jumpToPage(page);
|
||||
}
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Scaffold(
|
||||
body: PageView(
|
||||
controller: pageController,
|
||||
controller: _pageController,
|
||||
children: const <Widget>[
|
||||
DataPage(),
|
||||
StepsPage(),
|
||||
MapPage(),
|
||||
SettingsPage()
|
||||
],
|
||||
),
|
||||
bottomNavigationBar: BottomNavigationBar(
|
||||
items: const <BottomNavigationBarItem>[
|
||||
|
@ -31,9 +41,11 @@ class _HomeScreenState extends State<HomeScreen> {
|
|||
BottomNavigationBarItem(icon: Icon(Icons.location_on_outlined), label: 'Location'),
|
||||
BottomNavigationBarItem(icon: Icon(Icons.settings), label: 'Settings'),
|
||||
],
|
||||
currentIndex: page,
|
||||
currentIndex: _page,
|
||||
selectedItemColor: Colors.green,
|
||||
unselectedItemColor: Colors.black,
|
||||
showSelectedLabels: true,
|
||||
showUnselectedLabels: false,
|
||||
backgroundColor: Colors.white,
|
||||
onTap: onBottomBarPressed,
|
||||
type: BottomNavigationBarType.fixed,
|
||||
|
|
10
lib/map.dart
Normal file
10
lib/map.dart
Normal file
|
@ -0,0 +1,10 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class MapPage extends StatelessWidget {
|
||||
const MapPage({ Key? key }) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Text("Map Page");
|
||||
}
|
||||
}
|
10
lib/settings.dart
Normal file
10
lib/settings.dart
Normal file
|
@ -0,0 +1,10 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class SettingsPage extends StatelessWidget {
|
||||
const SettingsPage({ Key? key }) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Text("Settings Page");
|
||||
}
|
||||
}
|
10
lib/steps.dart
Normal file
10
lib/steps.dart
Normal file
|
@ -0,0 +1,10 @@
|
|||
import 'package:flutter/material.dart';
|
||||
|
||||
class StepsPage extends StatelessWidget {
|
||||
const StepsPage({ Key? key }) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Text("Data Page");
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue