MainPage.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869
  1. /**
  2. * Sample React Native App
  3. * https://github.com/facebook/react-native
  4. *
  5. * @format
  6. * @flow
  7. */
  8. import React, { Component } from "react";
  9. import {
  10. Platform,
  11. StyleSheet,
  12. Text,
  13. View,
  14. Image,
  15. FlatList,
  16. TouchableOpacity,
  17. ImageBackground,
  18. TextInput,
  19. Button,
  20. ViewPagerAndroid,
  21. DeviceEventEmitter
  22. } from "react-native";
  23. import Swiper from "react-native-swiper";
  24. import AndroidUtil from "../../util/AndroidUtil";
  25. import BasePage from "../BasePage";
  26. import Header from "./Header";
  27. import Swipers from "./Swiper";
  28. import Dimensions from '../utils/dimensions'
  29. export default class MainPage extends BasePage {
  30. constructor(props) {
  31. super(props);
  32. this.state = {
  33. grade: '大学',
  34. text: '小伙子'
  35. }
  36. }
  37. render() {
  38. return (
  39. <View style={{ flex: 1 }}>
  40. <FlatList
  41. style={{ flex: 1 }}
  42. ref="_flatlist"
  43. horizontal={false}
  44. removeClippedSubviews={false}
  45. ListHeaderComponent={() => this.headerorfooterComponent()}
  46. // searchSection={() => this.renderSearchSection()}
  47. keyExtractor={(item, index) => item.key.toString()}
  48. renderItem={({ item }) => {
  49. return this.loadFlatItem(item);
  50. }}
  51. data={[
  52. {
  53. //轮播
  54. key: 111,
  55. typea: 1,
  56. text: "第一种类型"
  57. },
  58. {
  59. //标题类型
  60. key: 333,
  61. typea: 0,
  62. title: "全部课程全部课程全部课程全部课程全部课程全部课程"
  63. },
  64. {
  65. //只有一个标题下面两个图片
  66. key: 222,
  67. typea: 2,
  68. item: {
  69. item_type: 1,
  70. title: "课程表:第一周",
  71. icon_item: [
  72. {
  73. icon:
  74. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  75. name: "第一张图片文字"
  76. },
  77. {
  78. icon:
  79. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  80. name: "第二张图片文字"
  81. }
  82. ]
  83. }
  84. },
  85. {
  86. //一个标题,大长图
  87. key: 444,
  88. typea: 3,
  89. title: "五月主题:五一启程,去看看不同世界",
  90. text: "每天30分钟,玩学两不误",
  91. icon_item: [
  92. {
  93. icon:
  94. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  95. name: "第一张图片文字"
  96. },
  97. {
  98. icon:
  99. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  100. name: "第二张图片文字"
  101. },
  102. {
  103. icon:
  104. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  105. name: "第三张图片文字"
  106. },
  107. {
  108. icon:
  109. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  110. name: "第四张图片文字"
  111. },
  112. {
  113. icon:
  114. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  115. name: "第五张图片文字"
  116. }
  117. ]
  118. },
  119. {
  120. key: 555,
  121. typea: 4,
  122. title: "热门课程",
  123. text: "text",
  124. mask: false,
  125. icon_item: [
  126. {
  127. icon:
  128. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  129. name: "第一张图片文字"
  130. },
  131. {
  132. icon:
  133. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  134. name: "第二张图片文字"
  135. },
  136. {
  137. icon:
  138. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  139. name: "第三张图片文字"
  140. },
  141. {
  142. icon:
  143. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  144. name: "第四张图片文字"
  145. },
  146. {
  147. icon:
  148. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  149. name: "第五张图片文字"
  150. }
  151. ]
  152. },
  153. {
  154. //标题类型
  155. key: 0,
  156. typea: 0,
  157. title: "全部课程"
  158. },
  159. {
  160. //一个标题,icon下有文字
  161. key: 666,
  162. typea: 4,
  163. title: "测试text为空的时候",
  164. text: "",
  165. mask: false,
  166. icon_item: [
  167. {
  168. icon:
  169. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  170. name: "第一张图片文字"
  171. },
  172. {
  173. icon:
  174. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  175. name: "第二张图片文字"
  176. },
  177. {
  178. icon:
  179. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  180. name: "第三张图片文字"
  181. },
  182. {
  183. icon:
  184. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  185. name: "第四张图片文字"
  186. },
  187. {
  188. icon:
  189. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  190. name: "第五张图片文字"
  191. }
  192. ]
  193. },
  194. {
  195. key: 777,
  196. typea: 4,
  197. title: "测试观看记录",
  198. text: "",
  199. mask: true,
  200. icon_item: [
  201. {
  202. last_time: "2小时前",
  203. icon:
  204. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  205. name: "第一张图片文字",
  206. curriculum_name: "课件名字"
  207. },
  208. {
  209. last_time: "3小时前",
  210. icon:
  211. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  212. name: "第二张图片文字",
  213. curriculum_name: "课件名字1"
  214. },
  215. {
  216. last_time: "4小时前",
  217. icon:
  218. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  219. name: "第三张图片文字",
  220. curriculum_name: "课件名字2"
  221. },
  222. {
  223. last_time: "1天前",
  224. icon:
  225. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  226. name: "第四张图片文字",
  227. curriculum_name: "课件名字3"
  228. },
  229. {
  230. last_time: "2天前",
  231. icon:
  232. "https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1556277324856&di=dc1548a0c5ba10481af922e174912937&imgtype=0&src=http%3A%2F%2Fwww.51pptmoban.com%2Fd%2Ffile%2F2012%2F05%2F12%2F82c4568a90055adcf8fbb896f0841c69.jpg",
  233. name: "第五张图片文字",
  234. curriculum_name: "课件名字4"
  235. }
  236. ]
  237. }
  238. ]}
  239. />
  240. </View>
  241. );
  242. }
  243. // flat 头部组件
  244. headerorfooterComponent() {
  245. return (
  246. <View>
  247. <Header
  248. uri="https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=1295208965,3056573814&amp;fm=26&amp;gp=0.jpg"
  249. width={400}
  250. height={150}
  251. username="卡通笨笨熊"
  252. flowerNumber="123234"
  253. onPress={() => this.toNextPage("MainActivity")}
  254. />
  255. {/* 搜索区域 */}
  256. <View style={styles.searchSection}>
  257. <TextInput
  258. style={styles.searchBox}
  259. onChangeText={(text) => this.setState({ text })}
  260. value={this.state.text}
  261. />
  262. <View
  263. style={styles.rightBtn}
  264. >
  265. <Image
  266. source={{uri: 'https://facebook.github.io/react-native/docs/assets/favicon.png'}}
  267. style={styles.rightBtnIcon}
  268. />
  269. <Text
  270. style={styles.rightBtnText}
  271. >
  272. {this.state.grade}
  273. </Text>
  274. </View>
  275. </View>
  276. </View>
  277. );
  278. }
  279. loadFlatItem(data) {
  280. switch (data.typea) {
  281. // case 0:
  282. // return (
  283. // <View
  284. // style={{
  285. // height: 50,
  286. // width: "100%",
  287. // justifyContent: "center",
  288. // alignItems: "center",
  289. // backgroundColor: "red"
  290. // }}
  291. // >
  292. // <View
  293. // style={{
  294. // height: "60%",
  295. // justifyContent: "center",
  296. // alignItems: "center",
  297. // width: "90%",
  298. // backgroundColor: "green",
  299. // borderRadius: 20,
  300. // flexDirection: "row"
  301. // }}
  302. // >
  303. // <View style={{ flex: 0.2 }} />
  304. // <Text
  305. // numberOfLines={1}
  306. // style={{
  307. // flex: 12,
  308. // justifyContent: "center",
  309. // alignItems: "center",
  310. // fontSize: 18,
  311. // fontWeight: "bold",
  312. // color: "#3E455B"
  313. // }}
  314. // >
  315. // {data.title}
  316. // </Text>
  317. // <View
  318. // style={{
  319. // flex: 1,
  320. // height: "100%",
  321. // justifyContent: "center",
  322. // alignItems: "center"
  323. // }}
  324. // >
  325. // <Image
  326. // source={{
  327. // uri:
  328. // "https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=1295208965,3056573814&fm=26&gp=0.jpg"
  329. // }}
  330. // style={{
  331. // width: "50%",
  332. // height: "50%",
  333. // justifyContent: "center",
  334. // alignItems: "center",
  335. // borderRadius: 30
  336. // }}
  337. // />
  338. // </View>
  339. // </View>
  340. // </View>
  341. // );
  342. // break;
  343. case 1:
  344. return (
  345. <View
  346. style={{
  347. height:193,
  348. flex: 1,
  349. justifyContent: "center",
  350. alignItems: "center",
  351. flexDirection: "row",
  352. backgroundColor: 'red'
  353. }}
  354. >
  355. <View
  356. style={{
  357. // width: "90%",
  358. width: Dimensions.width,
  359. // overflow: "hidden",
  360. height: 150
  361. }}
  362. >
  363. <Swipers
  364. autoplay={true}
  365. loop={true}
  366. ifShowMiddle={true}
  367. />
  368. </View>
  369. </View>
  370. );
  371. break;
  372. case 2:
  373. let arr = [];
  374. let index = 0;
  375. for (let item of data.item.icon_item) {
  376. arr.push(
  377. <TouchableOpacity
  378. style={{ flex: 2 }}
  379. onPress={() => {
  380. alert(item.name);
  381. }}
  382. key={index}
  383. activeOpacity={1}
  384. >
  385. <Image
  386. source={{
  387. uri: item.icon
  388. }}
  389. key={index}
  390. style={{
  391. width: "100%",
  392. height: "100%",
  393. justifyContent: "center",
  394. alignItems: "center",
  395. borderRadius: 10
  396. }}
  397. />
  398. </TouchableOpacity>
  399. );
  400. if (index < data.item.icon_item.length - 1) {
  401. arr.push(
  402. <View
  403. key={item.name}
  404. style={{
  405. flex: 0.1
  406. }}
  407. />
  408. );
  409. }
  410. index++;
  411. }
  412. return (
  413. <View
  414. style={{
  415. marginTop: 20,
  416. flex: 1,
  417. justifyContent: "center",
  418. alignItems: "center"
  419. }}
  420. >
  421. <View
  422. style={{
  423. flex: 1,
  424. flexDirection: "column",
  425. width: "90%",
  426. height: 150
  427. }}
  428. >
  429. <Text
  430. style={{
  431. flex: 0.5,
  432. fontSize: 18,
  433. fontWeight: "bold",
  434. color: "#3E455B"
  435. }}
  436. >
  437. {data.item.title}
  438. </Text>
  439. <View
  440. style={{
  441. flex: 2,
  442. flexDirection: "row",
  443. justifyContent: "space-between"
  444. }}
  445. >
  446. {arr}
  447. </View>
  448. </View>
  449. </View>
  450. );
  451. break;
  452. case 3:
  453. return (
  454. <View
  455. style={{
  456. marginTop: 20,
  457. flex: 1,
  458. justifyContent: "center",
  459. alignItems: "center"
  460. }}
  461. >
  462. <View
  463. style={{
  464. width: "90%",
  465. height: 200,
  466. flexDirection: "column"
  467. }}
  468. >
  469. <View
  470. style={{
  471. flex: 0.5,
  472. justifyContent: "center",
  473. alignItems: "center",
  474. flexDirection: "row"
  475. }}
  476. >
  477. <View
  478. style={{
  479. flex: 0.1,
  480. height: 14,
  481. justifyContent: "flex-start",
  482. alignItems: "center",
  483. backgroundColor: "#01AFFE",
  484. borderRadius: 20
  485. }}
  486. />
  487. <View
  488. style={{
  489. flex: 0.1
  490. }}
  491. />
  492. <Text
  493. numberOfLines={1}
  494. style={{
  495. flex: 11,
  496. fontSize: 18,
  497. fontWeight: "bold",
  498. color: "#3E455B"
  499. }}
  500. >
  501. {data.title}
  502. </Text>
  503. </View>
  504. {text_z}
  505. <View
  506. style={{
  507. flex: 3
  508. }}
  509. >
  510. <FlatList
  511. style={{
  512. flex: 1
  513. }}
  514. ItemSeparatorComponent={() => (
  515. <View
  516. style={{
  517. width: 10
  518. }}
  519. />
  520. )}
  521. showsHorizontalScrollIndicator={false}
  522. keyExtractor={(item, index) => item.name.toString()}
  523. data={data.icon_item}
  524. horizontal={true}
  525. renderItem={({ item }) => {
  526. return (
  527. <TouchableOpacity
  528. style={{
  529. flex: 1,
  530. height: "100%",
  531. width: this.getWindowWidth() * 0.9
  532. }}
  533. onPress={() => {
  534. alert(item.name);
  535. }}
  536. activeOpacity={1}
  537. >
  538. <Image
  539. source={{
  540. uri: item.icon
  541. }}
  542. style={{
  543. height: "100%",
  544. width: "100%",
  545. justifyContent: "center",
  546. alignItems: "center",
  547. borderRadius: 20
  548. }}
  549. />
  550. </TouchableOpacity>
  551. );
  552. }}
  553. />
  554. </View>
  555. </View>
  556. </View>
  557. );
  558. break;
  559. case 4:
  560. let text_z = [];
  561. let zhezhao = [];
  562. let view_height = 190;
  563. //判断是否需要text
  564. if (data.text != "") {
  565. view_height = 217;
  566. text_z.push(
  567. <View
  568. key={data.text}
  569. style={{
  570. flex: 0.5,
  571. justifyContent: "center",
  572. alignItems: "center",
  573. flexDirection: "row"
  574. }}
  575. >
  576. <View
  577. style={{
  578. flex: 1,
  579. flexDirection: "row"
  580. }}
  581. >
  582. <View
  583. style={{
  584. flex: 0.2
  585. }}
  586. />
  587. <Text
  588. style={{
  589. flex: 11,
  590. color: "#8F94AA"
  591. }}
  592. >
  593. {data.text}
  594. </Text>
  595. </View>
  596. </View>
  597. );
  598. }
  599. return (
  600. <View
  601. style={{
  602. marginTop: 20,
  603. flex: 1,
  604. justifyContent: "center",
  605. alignItems: "center"
  606. }}
  607. >
  608. <View
  609. style={{
  610. width: "90%",
  611. height: view_height,
  612. flexDirection: "column"
  613. }}
  614. >
  615. <View
  616. style={{
  617. flex: 0.5,
  618. justifyContent: "center",
  619. alignItems: "center",
  620. flexDirection: "row"
  621. }}
  622. >
  623. <View
  624. style={{
  625. flex: 0.1,
  626. height: 14,
  627. justifyContent: "flex-start",
  628. alignItems: "center",
  629. backgroundColor: "#01AFFE",
  630. borderRadius: 15
  631. }}
  632. />
  633. <View
  634. style={{
  635. flex: 0.1
  636. }}
  637. />
  638. <Text
  639. style={{
  640. flex: 11,
  641. fontSize: 18,
  642. fontWeight: "bold",
  643. color: "#3E455B"
  644. }}
  645. >
  646. {data.title}
  647. </Text>
  648. </View>
  649. {text_z}
  650. <View
  651. style={{
  652. flex: 3
  653. }}
  654. >
  655. <FlatList
  656. style={{
  657. flex: 1
  658. }}
  659. ItemSeparatorComponent={() => (
  660. <View
  661. style={{
  662. width: 10
  663. }}
  664. />
  665. )}
  666. showsHorizontalScrollIndicator={false}
  667. keyExtractor={(item, index) => item.name.toString()}
  668. data={data.icon_item}
  669. horizontal={true}
  670. renderItem={({ item }) => {
  671. //判断是否需要遮盖层(观看记录)
  672. if (data.mask) {
  673. zhezhao = [];
  674. zhezhao.push(
  675. <View
  676. key={item.name}
  677. style={{
  678. flex: 1,
  679. width: "100%",
  680. flexDirection: "column"
  681. }}
  682. >
  683. <View
  684. style={{
  685. flex: 2
  686. }}
  687. />
  688. <View
  689. style={{
  690. flex: 1,
  691. backgroundColor: "#344563",
  692. width: "100%",
  693. borderBottomLeftRadius: 15,
  694. borderBottomRightRadius: 15,
  695. flexDirection: "row"
  696. }}
  697. >
  698. <View
  699. style={{
  700. flex: 0.1
  701. }}
  702. />
  703. <View
  704. style={{
  705. flex: 1
  706. }}
  707. >
  708. <Text
  709. style={{
  710. flex: 1,
  711. color: "red",
  712. textAlign: "left"
  713. }}
  714. >
  715. {item.last_time + ":"}
  716. </Text>
  717. <Text
  718. style={{
  719. flex: 1,
  720. color: "red",
  721. textAlign: "left"
  722. }}
  723. >
  724. {item.curriculum_name}
  725. </Text>
  726. </View>
  727. </View>
  728. </View>
  729. );
  730. }
  731. return (
  732. <TouchableOpacity
  733. style={{
  734. flex: 1,
  735. height: "100%",
  736. width: this.getWindowWidth() * 0.22
  737. }}
  738. onPress={() => {
  739. alert(item.name);
  740. }}
  741. activeOpacity={1}
  742. >
  743. <View
  744. style={{
  745. flex: 1,
  746. height: "100%",
  747. width: "100%",
  748. justifyContent: "center",
  749. alignItems: "center"
  750. }}
  751. >
  752. <View
  753. style={{
  754. flex: 5,
  755. height: "100%",
  756. width: "100%",
  757. justifyContent: "center",
  758. alignItems: "center"
  759. }}
  760. >
  761. <ImageBackground
  762. source={{
  763. uri: item.icon
  764. }}
  765. style={{
  766. height: "100%",
  767. width: "100%",
  768. justifyContent: "center",
  769. alignItems: "center"
  770. }}
  771. imageStyle={{
  772. borderRadius: 20
  773. }}
  774. >
  775. {zhezhao}
  776. </ImageBackground>
  777. </View>
  778. <Text
  779. style={{
  780. justifyContent: "center",
  781. alignItems: "center",
  782. flex: 1,
  783. fontSize: 12
  784. }}
  785. >
  786. {item.name}
  787. </Text>
  788. </View>
  789. </TouchableOpacity>
  790. );
  791. }}
  792. />
  793. </View>
  794. </View>
  795. </View>
  796. );
  797. break;
  798. case 5:
  799. break;
  800. case 6:
  801. break;
  802. case 7:
  803. break;
  804. case 8:
  805. break;
  806. }
  807. }
  808. }
  809. const styles = StyleSheet.create({
  810. title_text: {
  811. justifyContent: "center",
  812. alignItems: "center",
  813. color: "red",
  814. fontSize: 30,
  815. textAlign: "center",
  816. marginTop: 30,
  817. marginBottom: 50
  818. },
  819. /* 搜索区域 */
  820. searchSection: {
  821. flex: 1,
  822. width: Dimensions.width,
  823. height: 60,
  824. flexDirection: 'row',
  825. alignItems: 'center',
  826. backgroundColor: '#f0f1f5',
  827. justifyContent: 'space-around'
  828. },
  829. searchBox: {
  830. width: 232,
  831. height: 40,
  832. backgroundColor: '#fff',
  833. borderRadius: 20
  834. },
  835. rightBtn: {
  836. width: 113,
  837. height: 40,
  838. backgroundColor: '#fff',
  839. borderRadius: 20,
  840. alignItems: 'center',
  841. justifyContent: 'center',
  842. justifyContent: 'space-around',
  843. flexDirection: 'row',
  844. paddingLeft: 20,
  845. paddingRight: 10,
  846. },
  847. rightBtnIcon:{
  848. width:14,
  849. height:14
  850. },
  851. rightBtnText: {
  852. color: '#151515',
  853. fontSize: 18,
  854. }
  855. /* 轮播图区域 */
  856. });