MainPage.js 29 KB

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