From 10187dc068e85865118410f7f26482c61c006cee Mon Sep 17 00:00:00 2001 From: Felipe Erias Date: Wed, 1 Dec 2021 14:38:10 +0900 Subject: Images and behaviour in HVAC --- lib/page_hvac.dart | 81 ++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 63 insertions(+), 18 deletions(-) (limited to 'lib/page_hvac.dart') diff --git a/lib/page_hvac.dart b/lib/page_hvac.dart index 07cc772..47aea03 100644 --- a/lib/page_hvac.dart +++ b/lib/page_hvac.dart @@ -92,9 +92,19 @@ class HVACPage extends StatefulWidget { State createState() => _HVACPageState(); } -String chairOn = 'images/HMI_HVAC_Left_Chair_ON.png'; -String chairOff = 'images/HMI_HVAC_Right_Chair_ON.png'; -bool selected = true; // Get from API +String leftChairOn = 'images/HMI_HVAC_Left_Chair_ON.png'; +String leftChairOff = 'images/HMI_HVAC_Left_Chair_OFF.png'; +String rightChairOn = 'images/HMI_HVAC_Right_Chair_ON.png'; +String rightChairOff = 'images/HMI_HVAC_Right_Chair_OFF.png'; +String circulationActive = 'images/HMI_HVAC_Circulation_Active.png'; +String circulationInactive = 'images/HMI_HVAC_Circulation_Inactive.png'; + +// Get from API +bool leftChairSelected = true; +bool rightChairSelected = true; +bool ACSelected = true; +bool autoSelected = true; +bool circulationSelected = true; class _HVACPageState extends State { final double fanSpeed = 20; @@ -105,6 +115,9 @@ class _HVACPageState extends State { TextStyle buttonTextStyle = DefaultTextStyle.of(context).style.copyWith( fontSize: sizeHelper.baseFontSize, ); + TextStyle unselectedButtonTextStyle = buttonTextStyle.copyWith( + color: Colors.grey, + ); Widget fanSpeedControl = Container( padding: EdgeInsets.symmetric( @@ -131,12 +144,14 @@ class _HVACPageState extends State { children: [ IconButton( iconSize: sizeHelper.largeIconSize, - icon: Image.asset(selected ? chairOn : chairOff, + icon: Image.asset(leftChairSelected ? leftChairOn : leftChairOff, width: sizeHelper.largeIconSize, height: sizeHelper.largeIconSize, fit: BoxFit.contain), onPressed: () { - selected = !selected; + setState(() { + leftChairSelected = !leftChairSelected; + }); }, ), SizedBox(height: sizeHelper.defaultPadding), @@ -149,10 +164,18 @@ class _HVACPageState extends State { padding: EdgeInsets.all(sizeHelper.defaultPadding), child: Column( children: [ - Image.asset('images/HMI_HVAC_Right_Chair_ON.png', - width: sizeHelper.largeIconSize, - height: sizeHelper.largeIconSize, - fit: BoxFit.contain), + IconButton( + iconSize: sizeHelper.largeIconSize, + icon: Image.asset(rightChairSelected ? rightChairOn : rightChairOff, + width: sizeHelper.largeIconSize, + height: sizeHelper.largeIconSize, + fit: BoxFit.contain), + onPressed: () { + setState(() { + rightChairSelected = !rightChairSelected; + }); + }, + ), SizedBox(height: sizeHelper.defaultPadding), _TemperatureSelector(), ], @@ -168,13 +191,20 @@ class _HVACPageState extends State { height: sizeHelper.defaultButtonHeight, margin: EdgeInsets.all(sizeHelper.defaultPadding), decoration: BoxDecoration( - border: Border.all(color: Colors.green), + border: Border.all( + color: ACSelected ? Colors.green : Colors.grey, + ), borderRadius: BorderRadius.circular(20)), child: OutlinedButton( onPressed: () { - // Respond to button press + setState(() { + ACSelected = !ACSelected; + }); }, - child: Text("A / C", style: buttonTextStyle), + child: Text( + "A / C", + style: ACSelected ? buttonTextStyle : unselectedButtonTextStyle, + ), ), ), Container( @@ -182,13 +212,21 @@ class _HVACPageState extends State { height: sizeHelper.defaultButtonHeight, margin: EdgeInsets.all(sizeHelper.defaultPadding), decoration: BoxDecoration( - border: Border.all(color: Colors.green), + border: Border.all( + color: autoSelected ? Colors.green : Colors.grey, + ), borderRadius: BorderRadius.circular(20)), child: OutlinedButton( onPressed: () { - // Respond to button press + setState(() { + autoSelected = !autoSelected; + }); }, - child: Text("Auto", style: buttonTextStyle), + child: Text( + "Auto", + style: + autoSelected ? buttonTextStyle : unselectedButtonTextStyle, + ), ), ), Container( @@ -196,13 +234,20 @@ class _HVACPageState extends State { height: sizeHelper.defaultButtonHeight, margin: EdgeInsets.all(sizeHelper.defaultPadding), decoration: BoxDecoration( - border: Border.all(color: Colors.green), + border: Border.all( + color: circulationSelected ? Colors.green : Colors.grey, + ), borderRadius: BorderRadius.circular(20)), child: OutlinedButton( onPressed: () { - // Respond to button press + setState(() { + circulationSelected = !circulationSelected; + }); }, - child: Image.asset('images/HMI_HVAC_Circulation_Inactive.png', + child: Image.asset( + circulationSelected + ? circulationActive + : circulationInactive, width: sizeHelper.defaultIconSize, height: sizeHelper.defaultIconSize, fit: BoxFit.contain)), -- cgit 1.2.3-korg