MainPage.js 27 KB

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