您最多选择25个主题
主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
653 行
28 KiB
653 行
28 KiB
using System.Collections.Generic;
|
|
using Unity.UIWidgets.engine;
|
|
using Unity.UIWidgets.foundation;
|
|
using Unity.UIWidgets.painting;
|
|
using Unity.UIWidgets.rendering;
|
|
using Unity.UIWidgets.ui;
|
|
using Unity.UIWidgets.widgets;
|
|
using Image = Unity.UIWidgets.widgets.Image;
|
|
using TextStyle = Unity.UIWidgets.painting.TextStyle;
|
|
|
|
namespace UIWidgetsSample
|
|
{
|
|
public class AsScreenCanvas : WidgetCanvas
|
|
{
|
|
protected override Widget getWidget()
|
|
{
|
|
return new AsScreen();
|
|
}
|
|
|
|
public class AsScreen : StatefulWidget
|
|
{
|
|
public AsScreen(Key key = null) : base(key)
|
|
{
|
|
}
|
|
|
|
public override State createState()
|
|
{
|
|
return new _AsScreenState();
|
|
}
|
|
}
|
|
|
|
class _AsScreenState : State<AsScreen>
|
|
{
|
|
const double headerHeight = 50.0;
|
|
|
|
Widget _buildHeader(BuildContext context)
|
|
{
|
|
return new Container(
|
|
padding: EdgeInsets.only(left: 16.0, right: 8.0),
|
|
height: headerHeight,
|
|
color: CLColors.header,
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
child: new Text(
|
|
"All Assets",
|
|
style: new TextStyle(
|
|
fontSize: 16,
|
|
color: Color.fromARGB(100, 255, 255, 0)
|
|
)
|
|
)
|
|
),
|
|
new CustomButton(
|
|
padding: EdgeInsets.only(0.0, 0.0, 16.0, 0.0),
|
|
child: new Icon(
|
|
Icons.keyboard_arrow_down,
|
|
size: 18.0,
|
|
color: CLColors.icon2
|
|
)
|
|
),
|
|
new Container(
|
|
decoration: new BoxDecoration(
|
|
color: CLColors.white,
|
|
borderRadius: BorderRadius.all(3)
|
|
),
|
|
width: 320,
|
|
height: 36,
|
|
padding: EdgeInsets.all(10.0),
|
|
margin: EdgeInsets.only(right: 4),
|
|
child: new EditableText(
|
|
maxLines: 1,
|
|
controller: new TextEditingController("Type here to search assets"),
|
|
focusNode: new FocusNode(),
|
|
style: new TextStyle(
|
|
fontSize: 16
|
|
),
|
|
selectionColor: Color.fromARGB(255, 255, 0, 0),
|
|
cursorColor: Color.fromARGB(255, 0, 0, 0)
|
|
)
|
|
),
|
|
new Container(
|
|
decoration: new BoxDecoration(
|
|
color: CLColors.background4,
|
|
borderRadius: BorderRadius.all(2)
|
|
),
|
|
width: 36,
|
|
height: 36,
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
children: new List<Widget>
|
|
{
|
|
new CustomButton(
|
|
padding: EdgeInsets.only(8.0, 0.0, 8.0, 0.0),
|
|
child: new Icon(
|
|
Icons.search,
|
|
size: 18.0,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
}
|
|
)
|
|
),
|
|
new Container(
|
|
margin: EdgeInsets.only(left: 16, right: 16),
|
|
child: new Text(
|
|
"Learn Game Development",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
decoration: new BoxDecoration(
|
|
border: Border.all(
|
|
color: CLColors.white
|
|
)
|
|
),
|
|
margin: EdgeInsets.only(right: 16),
|
|
padding: EdgeInsets.all(4),
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
children: new List<Widget>
|
|
{
|
|
new Text(
|
|
"Plus/Pro",
|
|
style: new TextStyle(
|
|
fontSize: 11,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
}
|
|
)
|
|
),
|
|
new Container(
|
|
margin: EdgeInsets.only(right: 16),
|
|
child: new Text(
|
|
"Impressive New Assets",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
child: new Text(
|
|
"Shop On Old Store",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
),
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
Widget _buildFooter(BuildContext context)
|
|
{
|
|
return new Container(
|
|
color: CLColors.header,
|
|
margin: EdgeInsets.only(top: 50),
|
|
height: 90,
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
margin: EdgeInsets.only(right: 10),
|
|
child: new Text(
|
|
"Copyright © 2018 Unity Technologies",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.text9
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
margin: EdgeInsets.only(right: 10),
|
|
child: new Text(
|
|
"All prices are exclusive of tax",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.text9
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
margin: EdgeInsets.only(right: 10),
|
|
child: new Text(
|
|
"Terms of Service and EULA",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.text10
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
child: new Text(
|
|
"Cookies",
|
|
style: new TextStyle(
|
|
fontSize: 12,
|
|
color: CLColors.text10
|
|
)
|
|
)
|
|
),
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
Widget _buildBanner(BuildContext context)
|
|
{
|
|
return new Container(
|
|
height: 450,
|
|
color: CLColors.white,
|
|
child: Image.network(
|
|
"https://d2ujflorbtfzji.cloudfront.net/banner/5c57178c-4be6-4903-953b-85125bfb7154.jpg",
|
|
fit: BoxFit.cover
|
|
)
|
|
);
|
|
}
|
|
|
|
Widget _buildTopAssetsRow(BuildContext context, string title)
|
|
{
|
|
var testCard = new AssetCard(
|
|
"AI Template",
|
|
"INVECTOR",
|
|
45.0,
|
|
36.0,
|
|
true,
|
|
"https://d2ujflorbtfzji.cloudfront.net/key-image/46dc65c1-f605-4ccb-97e0-3d60b28cfdfe.jpg"
|
|
);
|
|
return new Container(
|
|
margin: EdgeInsets.only(left: 98),
|
|
child: new Column(
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
child: new Container(
|
|
margin: EdgeInsets.only(top: 50, bottom: 20),
|
|
child: new Row(
|
|
crossAxisAlignment: CrossAxisAlignment.baseline,
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
child: new Text(
|
|
title,
|
|
style: new TextStyle(
|
|
fontSize: 24,
|
|
color: CLColors.black
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
margin: EdgeInsets.only(left: 15),
|
|
child:
|
|
new Text(
|
|
"See More",
|
|
style: new TextStyle(
|
|
fontSize: 16,
|
|
color: CLColors.text4
|
|
)
|
|
)
|
|
)
|
|
})
|
|
)
|
|
),
|
|
new Row(
|
|
children: new List<Widget>
|
|
{
|
|
testCard,
|
|
testCard,
|
|
testCard,
|
|
testCard,
|
|
testCard,
|
|
testCard
|
|
}
|
|
)
|
|
}
|
|
));
|
|
}
|
|
|
|
bool _onNotification(ScrollNotification notification, BuildContext context)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
Widget _buildContentList(BuildContext context)
|
|
{
|
|
return new NotificationListener<ScrollNotification>(
|
|
onNotification: (ScrollNotification notification) =>
|
|
{
|
|
_onNotification(notification, context);
|
|
return true;
|
|
},
|
|
child: new Flexible(
|
|
child: new ListView(
|
|
physics: new AlwaysScrollableScrollPhysics(),
|
|
children: new List<Widget>
|
|
{
|
|
_buildBanner(context),
|
|
_buildTopAssetsRow(context, "Recommanded For You"),
|
|
_buildTopAssetsRow(context, "Beach Day"),
|
|
_buildTopAssetsRow(context, "Top Free Packages"),
|
|
_buildTopAssetsRow(context, "Top Paid Packages"),
|
|
_buildFooter(context)
|
|
}
|
|
)
|
|
)
|
|
);
|
|
}
|
|
|
|
public override Widget build(BuildContext context)
|
|
{
|
|
var container = new Container(
|
|
color: CLColors.background3,
|
|
child: new Container(
|
|
color: CLColors.background3,
|
|
child: new Column(
|
|
children: new List<Widget>
|
|
{
|
|
this._buildHeader(context),
|
|
this._buildContentList(context),
|
|
}
|
|
)
|
|
)
|
|
);
|
|
return container;
|
|
}
|
|
}
|
|
|
|
public class AssetCard : StatelessWidget
|
|
{
|
|
public AssetCard(
|
|
string name,
|
|
string category,
|
|
double price,
|
|
double priceDiscount,
|
|
bool showBadge,
|
|
string imageSrc
|
|
)
|
|
{
|
|
this.name = name;
|
|
this.category = category;
|
|
this.price = price;
|
|
this.priceDiscount = priceDiscount;
|
|
this.showBadge = showBadge;
|
|
this.imageSrc = imageSrc;
|
|
}
|
|
|
|
public string name;
|
|
public string category;
|
|
public double price;
|
|
public double priceDiscount;
|
|
public bool showBadge;
|
|
public string imageSrc;
|
|
|
|
public override Widget build(BuildContext context)
|
|
{
|
|
var card = new Container(
|
|
margin: EdgeInsets.only(right: 45),
|
|
child: new Container(
|
|
child: new Column(
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
decoration: new BoxDecoration(
|
|
color: CLColors.white,
|
|
borderRadius: BorderRadius.only(topLeft: 3, topRight: 3)
|
|
),
|
|
width: 200,
|
|
height: 124,
|
|
child: Image.network(
|
|
this.imageSrc,
|
|
fit: BoxFit.fill
|
|
)
|
|
),
|
|
new Container(
|
|
color: CLColors.white,
|
|
width: 200,
|
|
height: 86,
|
|
padding: EdgeInsets.fromLTRB(14, 12, 14, 8),
|
|
child: new Column(
|
|
crossAxisAlignment: CrossAxisAlignment.baseline,
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
height: 18,
|
|
padding: EdgeInsets.only(top: 3),
|
|
child:
|
|
new Text(
|
|
category,
|
|
style: new TextStyle(
|
|
fontSize: 11,
|
|
color: CLColors.text5
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
height: 20,
|
|
padding: EdgeInsets.only(top: 2),
|
|
child:
|
|
new Text(
|
|
name,
|
|
style: new TextStyle(
|
|
fontSize: 14,
|
|
color: CLColors.text6
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
height: 22,
|
|
padding: EdgeInsets.only(top: 4),
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
child: new Row(
|
|
children: new List<Widget>
|
|
{
|
|
new Container(
|
|
margin: EdgeInsets.only(right: 10),
|
|
child: new Text(
|
|
"$" + this.price,
|
|
style: new TextStyle(
|
|
fontSize: 14,
|
|
color: CLColors.text7,
|
|
decoration: TextDecoration.lineThrough
|
|
)
|
|
)
|
|
),
|
|
new Container(
|
|
child: new Text(
|
|
"$" + this.priceDiscount,
|
|
style: new TextStyle(
|
|
fontSize: 14,
|
|
color: CLColors.text8
|
|
)
|
|
)
|
|
)
|
|
})
|
|
),
|
|
showBadge
|
|
? new Container(
|
|
width: 80,
|
|
height: 18,
|
|
color: CLColors.black,
|
|
child: new Row(
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
children: new List<Widget>
|
|
{
|
|
new Text(
|
|
"Plus/Pro",
|
|
style: new TextStyle(
|
|
fontSize: 11,
|
|
color: CLColors.white
|
|
)
|
|
)
|
|
}
|
|
)
|
|
)
|
|
: new Container()
|
|
}
|
|
)
|
|
)
|
|
}
|
|
)
|
|
)
|
|
}
|
|
)
|
|
)
|
|
);
|
|
return card;
|
|
}
|
|
}
|
|
|
|
public class EventsWaterfallScreen : StatefulWidget
|
|
{
|
|
public EventsWaterfallScreen(Key key = null) : base(key: key)
|
|
{
|
|
}
|
|
|
|
public override State createState()
|
|
{
|
|
return new _EventsWaterfallScreenState();
|
|
}
|
|
}
|
|
|
|
class _EventsWaterfallScreenState : State<EventsWaterfallScreen>
|
|
{
|
|
const double headerHeight = 80.0;
|
|
|
|
double _offsetY = 0.0;
|
|
|
|
Widget _buildHeader(BuildContext context)
|
|
{
|
|
return new Container(
|
|
padding: EdgeInsets.only(left: 16.0, right: 8.0),
|
|
// color: CLColors.blue,
|
|
height: headerHeight - _offsetY,
|
|
child: new Row(
|
|
children: new List<Widget>
|
|
{
|
|
new Flexible(
|
|
flex: 1,
|
|
fit: FlexFit.tight,
|
|
child: new Text(
|
|
"Today",
|
|
style: new TextStyle(
|
|
fontSize: (34.0 / headerHeight) * (headerHeight - _offsetY),
|
|
color: CLColors.white
|
|
)
|
|
)),
|
|
new CustomButton(
|
|
padding: EdgeInsets.only(8.0, 0.0, 8.0, 0.0),
|
|
child: new Icon(
|
|
Icons.notifications,
|
|
size: 18.0,
|
|
color: CLColors.icon2
|
|
)
|
|
),
|
|
new CustomButton(
|
|
padding: EdgeInsets.only(8.0, 0.0, 16.0, 0.0),
|
|
child: new Icon(
|
|
Icons.account_circle,
|
|
size: 18.0,
|
|
color: CLColors.icon2
|
|
)
|
|
)
|
|
}
|
|
)
|
|
);
|
|
}
|
|
|
|
bool _onNotification(ScrollNotification notification, BuildContext context)
|
|
{
|
|
double pixels = notification.metrics.pixels;
|
|
if (pixels >= 0.0)
|
|
{
|
|
if (pixels <= headerHeight)
|
|
{
|
|
setState(() => { _offsetY = pixels / 2.0; });
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (_offsetY != 0.0)
|
|
{
|
|
setState(() => { _offsetY = 0.0; });
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
Widget _buildContentList(BuildContext context)
|
|
{
|
|
return new NotificationListener<ScrollNotification>(
|
|
onNotification: (ScrollNotification notification) =>
|
|
{
|
|
_onNotification(notification, context);
|
|
return true;
|
|
},
|
|
child: new Flexible(
|
|
child: new Container(
|
|
// color: CLColors.green,
|
|
child: ListView.builder(
|
|
itemCount: 20,
|
|
itemExtent: 100,
|
|
physics: new AlwaysScrollableScrollPhysics(),
|
|
itemBuilder: (BuildContext context1, int index) =>
|
|
{
|
|
return new Container(
|
|
color: Color.fromARGB(255, (index * 10) % 256, (index * 20) % 256,
|
|
(index * 30) % 256)
|
|
);
|
|
}
|
|
)
|
|
)
|
|
)
|
|
);
|
|
}
|
|
|
|
public override Widget build(BuildContext context)
|
|
{
|
|
var container = new Container(
|
|
// color: CLColors.background1,
|
|
child: new Container(
|
|
// color: CLColors.background1,
|
|
child: new Column(
|
|
children: new List<Widget>
|
|
{
|
|
this._buildHeader(context),
|
|
this._buildContentList(context)
|
|
}
|
|
)
|
|
)
|
|
);
|
|
return container;
|
|
}
|
|
}
|
|
|
|
public static class Icons
|
|
{
|
|
public static readonly IconData notifications = new IconData(0xe7f4, fontFamily: "Material Icons");
|
|
public static readonly IconData account_circle = new IconData(0xe853, fontFamily: "Material Icons");
|
|
public static readonly IconData search = new IconData(0xe8b6, fontFamily: "Material Icons");
|
|
public static readonly IconData keyboard_arrow_down = new IconData(0xe313, fontFamily: "Material Icons");
|
|
}
|
|
|
|
public static class CLColors
|
|
{
|
|
public static readonly Color primary = new Color(0xFFE91E63);
|
|
public static readonly Color secondary1 = new Color(0xFF00BCD4);
|
|
public static readonly Color secondary2 = new Color(0xFFF0513C);
|
|
public static readonly Color background1 = new Color(0xFF292929);
|
|
public static readonly Color background2 = new Color(0xFF383838);
|
|
public static readonly Color background3 = new Color(0xFFF5F5F5);
|
|
public static readonly Color background4 = new Color(0xFF00BCD4);
|
|
public static readonly Color icon1 = new Color(0xFFFFFFFF);
|
|
public static readonly Color icon2 = new Color(0xFFA4A4A4);
|
|
public static readonly Color text1 = new Color(0xFFFFFFFF);
|
|
public static readonly Color text2 = new Color(0xFFD8D8D8);
|
|
public static readonly Color text3 = new Color(0xFF959595);
|
|
public static readonly Color text4 = new Color(0xFF002835);
|
|
public static readonly Color text5 = new Color(0xFF9E9E9E);
|
|
public static readonly Color text6 = new Color(0xFF002835);
|
|
public static readonly Color text7 = new Color(0xFF5A5A5B);
|
|
public static readonly Color text8 = new Color(0xFF239988);
|
|
public static readonly Color text9 = new Color(0xFFB3B5B6);
|
|
public static readonly Color text10 = new Color(0xFF00BCD4);
|
|
public static readonly Color dividingLine1 = new Color(0xFF666666);
|
|
public static readonly Color dividingLine2 = new Color(0xFF404040);
|
|
|
|
public static readonly Color transparent = new Color(0x00000000);
|
|
public static readonly Color white = new Color(0xFFFFFFFF);
|
|
public static readonly Color black = new Color(0xFF000000);
|
|
public static readonly Color red = new Color(0xFFFF0000);
|
|
public static readonly Color green = new Color(0xFF00FF00);
|
|
public static readonly Color blue = new Color(0xFF0000FF);
|
|
|
|
public static readonly Color header = new Color(0xFF060B0C);
|
|
}
|
|
}
|
|
}
|