forked from Sky24n/flutter_wanandroid
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcity_select_page.dart
177 lines (156 loc) · 4.72 KB
/
city_select_page.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
import 'dart:convert';
import 'package:azlistview/azlistview.dart';
import 'package:common_utils/common_utils.dart';
import 'package:flutter/material.dart';
import 'package:flutter/rendering.dart';
import 'package:flutter/services.dart';
import 'package:lpinyin/lpinyin.dart';
class CityInfo extends ISuspensionBean {
String name;
String tagIndex;
String namePinyin;
CityInfo({
this.name,
this.tagIndex,
this.namePinyin,
});
CityInfo.fromJson(Map<String, dynamic> json)
: name = json['name'] == null ? "" : json['name'];
Map<String, dynamic> toJson() => {
'name': name,
'tagIndex': tagIndex,
'namePinyin': namePinyin,
'isShowSuspension': isShowSuspension
};
@override
String getSuspensionTag() => tagIndex;
@override
String toString() => "CityBean {" + " \"name\":\"" + name + "\"" + '}';
}
class CitySelectPage extends StatefulWidget {
final String title;
CitySelectPage(this.title);
@override
State<StatefulWidget> createState() {
return new _CitySelectPageState();
}
}
class _CitySelectPageState extends State<CitySelectPage> {
List<CityInfo> _cityList = List();
List<CityInfo> _hotCityList = List();
int _suspensionHeight = 40;
int _itemHeight = 50;
String _suspensionTag = "";
@override
void initState() {
super.initState();
loadData();
}
void loadData() async {
//加载城市列表
rootBundle.loadString('assets/data/china.json').then((value) {
Map countyMap = json.decode(value);
List list = countyMap['china'];
list.forEach((value) {
_cityList.add(CityInfo(name: value['name']));
});
_handleList(_cityList);
_hotCityList.add(CityInfo(name: "北京市", tagIndex: "热门"));
_hotCityList.add(CityInfo(name: "广州市", tagIndex: "热门"));
_hotCityList.add(CityInfo(name: "成都市", tagIndex: "热门"));
_hotCityList.add(CityInfo(name: "深圳市", tagIndex: "热门"));
_hotCityList.add(CityInfo(name: "杭州市", tagIndex: "热门"));
_hotCityList.add(CityInfo(name: "武汉市", tagIndex: "热门"));
setState(() {
_suspensionTag = _hotCityList[0].getSuspensionTag();
});
});
}
void _handleList(List<CityInfo> list) {
if (list == null || list.isEmpty) return;
for (int i = 0, length = list.length; i < length; i++) {
String pinyin = PinyinHelper.getPinyinE(list[i].name);
String tag = pinyin.substring(0, 1).toUpperCase();
list[i].namePinyin = pinyin;
if (RegExp("[A-Z]").hasMatch(tag)) {
list[i].tagIndex = tag;
} else {
list[i].tagIndex = "#";
}
}
SuspensionUtil.sortListBySuspensionTag(list);
}
void _onSusTagChanged(String tag) {
setState(() {
_suspensionTag = tag;
});
}
///构建悬停Widget.
Widget _buildSusWidget(String susTag) {
return Container(
height: _suspensionHeight.toDouble(),
padding: const EdgeInsets.only(left: 15.0),
color: Color(0xfff3f4f5),
alignment: Alignment.centerLeft,
child: Text(
'$susTag',
softWrap: false,
style: TextStyle(
fontSize: 14.0,
color: Color(0xff999999),
),
),
);
}
///构建列表 item Widget.
Widget _buildListItem(CityInfo model) {
return Column(
children: <Widget>[
Offstage(
offstage: !(model.isShowSuspension == true),
child: _buildSusWidget(model.getSuspensionTag()),
),
SizedBox(
height: _itemHeight.toDouble(),
child: ListTile(
title: Text(model.name),
onTap: () {
LogUtil.e("OnItemClick: $model");
Navigator.pop(context, model);
},
),
)
],
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
centerTitle: true,
),
body: new Column(
children: <Widget>[
Container(
alignment: Alignment.centerLeft,
padding: const EdgeInsets.only(left: 15.0),
height: 50.0,
child: Text("当前城市: 成都市"),
),
Expanded(
flex: 1,
child: new AzListView(
data: _cityList,
topData: _hotCityList,
itemBuilder: (context, model) => _buildListItem(model),
suspensionWidget: _buildSusWidget(_suspensionTag),
isUseRealIndex: true,
itemHeight: _itemHeight,
suspensionHeight: _suspensionHeight,
onSusTagChanged: _onSusTagChanged,
))
],
));
}
}