totalOutputFluxDesc.vue 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470
  1. <template>
  2. <div class="output-flux-intro">
  3. <!-- 第一部分:输出总通量概念介绍 -->
  4. <div class="content-section">
  5. <div class="section-header">
  6. <div class="section-number">1</div>
  7. <h2>重金属输出总通量概念</h2>
  8. </div>
  9. <div class="concept-card">
  10. <div class="concept-icon">📉</div>
  11. <div class="concept-content">
  12. <p>
  13. <span class="highlight">重金属输出总通量</span>是指通过籽粒移除、秸秆移除、地下渗漏和地表径流四种主要途径从农田生态系统输出的重金属总量,通常以克/公顷/年(g/ha/a)为单位表示。该指标综合反映了农田系统向外部环境输出的重金属污染负荷,是评估农田重金属平衡和生态风险的重要依据。
  14. </p>
  15. </div>
  16. </div>
  17. <div class="formula-container">
  18. <div class="formula-card">
  19. <h3>输出总通量计算公式</h3>
  20. <div class="formula-content">
  21. <p class="formula">F<sub>输出</sub> = F<sub>籽粒</sub> + F<sub>秸秆</sub> + F<sub>渗漏</sub> + F<sub>径流</sub></p>
  22. <div class="formula-explain">
  23. <p>式中:</p>
  24. <p>F<sub>输出</sub> —— 重金属输出总通量 (g/ha/a)</p>
  25. <p>F<sub>籽粒</sub> —— 籽粒移除途径输出通量 (g/ha/a)</p>
  26. <p>F<sub>秸秆</sub> —— 秸秆移除途径输出通量 (g/ha/a)</p>
  27. <p>F<sub>渗漏</sub> —— 地下渗漏途径输出通量 (g/ha/a)</p>
  28. <p>F<sub>径流</sub> —— 地表径流途径输出通量 (g/ha/a)</p>
  29. </div>
  30. </div>
  31. </div>
  32. </div>
  33. </div>
  34. <div class="content-section">
  35. <div class="section-header">
  36. <div class="section-number">2</div>
  37. <h2>总通量输出过程视频演示</h2>
  38. </div>
  39. <div class="video-section">
  40. <div class="video-container">
  41. <video controls class="sampling-video">
  42. <source src='@/assets/videos/输出总通量.mp4' type="video/mp4">
  43. 您的浏览器不支持HTML5视频播放。
  44. </video>
  45. </div>
  46. </div>
  47. </div>
  48. </div>
  49. </template>
  50. <script>
  51. export default {
  52. data() {
  53. return {
  54. contributionImage: '/输出途径贡献比例.png'
  55. };
  56. }
  57. };
  58. </script>
  59. <style scoped>
  60. .output-flux-intro {
  61. padding: 30px;
  62. background: linear-gradient(135deg, rgba(245, 252, 240, 0.9) 0%, rgba(235, 248, 255, 0.9) 100%);
  63. font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  64. }
  65. .content-section {
  66. margin-bottom: 50px;
  67. padding: 30px;
  68. border-radius: 15px;
  69. background: rgba(255, 255, 255, 0.92);
  70. box-shadow: 0 8px 25px rgba(0, 60, 120, 0.08);
  71. transition: all 0.4s ease;
  72. }
  73. .content-section:hover {
  74. transform: translateY(-5px);
  75. box-shadow: 0 12px 35px rgba(0, 60, 120, 0.15);
  76. }
  77. .section-header {
  78. display: flex;
  79. align-items: center;
  80. margin-bottom: 25px;
  81. padding-bottom: 15px;
  82. border-bottom: 2px solid rgba(58, 160, 207, 0.25);
  83. }
  84. .section-number {
  85. width: 50px;
  86. height: 50px;
  87. background: linear-gradient(135deg, #4a9ef7, #3a9fd3);
  88. color: white;
  89. border-radius: 50%;
  90. display: flex;
  91. align-items: center;
  92. justify-content: center;
  93. font-size: 1.8rem;
  94. font-weight: bold;
  95. margin-right: 20px;
  96. box-shadow: 0 5px 12px rgba(74, 158, 247, 0.25);
  97. }
  98. h2 {
  99. color: #1a365d;
  100. font-size: 1.9rem;
  101. margin: 0;
  102. font-weight: 650;
  103. }
  104. .concept-card {
  105. display: flex;
  106. align-items: center;
  107. padding: 25px;
  108. background: rgba(235, 245, 255, 0.6);
  109. border-radius: 15px;
  110. margin-bottom: 30px;
  111. border-left: 4px solid #3a9fd3;
  112. }
  113. .concept-icon {
  114. font-size: 2.5rem;
  115. margin-right: 25px;
  116. color: #3a9fd3;
  117. }
  118. .concept-content p {
  119. font-size: 1.15rem;
  120. line-height: 1.8;
  121. color: #2d3748;
  122. margin: 0 0 15px 0;
  123. }
  124. .highlight {
  125. font-weight: 600;
  126. color: #1a6fb3;
  127. }
  128. .formula-container {
  129. display: flex;
  130. justify-content: center;
  131. }
  132. .formula-card {
  133. width: 100%;
  134. max-width: 700px;
  135. padding: 25px;
  136. background: rgba(245, 252, 255, 0.8);
  137. border-radius: 15px;
  138. box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  139. border-top: 3px solid #3a9fd3;
  140. }
  141. .formula-card h3 {
  142. color: #1a365d;
  143. font-size: 1.5rem;
  144. margin-top: 0;
  145. margin-bottom: 20px;
  146. text-align: center;
  147. }
  148. .formula-content {
  149. display: flex;
  150. flex-direction: column;
  151. align-items: center;
  152. }
  153. .formula {
  154. font-size: 1.8rem;
  155. font-weight: bold;
  156. color: #2c3e50;
  157. margin-bottom: 20px;
  158. text-align: center;
  159. padding: 15px;
  160. background: white;
  161. border-radius: 10px;
  162. width: 100%;
  163. box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  164. }
  165. .formula-explain {
  166. width: 100%;
  167. }
  168. .formula-explain p {
  169. font-size: 1.1rem;
  170. line-height: 1.8;
  171. color: #2d3748;
  172. margin: 5px 0;
  173. }
  174. .formula-explain p:first-child {
  175. font-weight: 600;
  176. margin-bottom: 10px;
  177. }
  178. .contribution-container {
  179. display: grid;
  180. grid-template-columns: repeat(2, 1fr);
  181. gap: 25px;
  182. margin-bottom: 30px;
  183. }
  184. .contribution-card {
  185. display: flex;
  186. padding: 20px;
  187. background: rgba(245, 252, 255, 0.7);
  188. border-radius: 15px;
  189. box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  190. transition: all 0.3s ease;
  191. }
  192. .contribution-card:hover {
  193. transform: translateY(-5px);
  194. box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
  195. }
  196. .contribution-icon {
  197. font-size: 2rem;
  198. margin-right: 20px;
  199. color: #3a9fd3;
  200. }
  201. .contribution-content h3 {
  202. color: #1a365d;
  203. font-size: 1.3rem;
  204. margin-top: 0;
  205. margin-bottom: 12px;
  206. }
  207. .contribution-content p {
  208. font-size: 1.05rem;
  209. line-height: 1.6;
  210. color: #2d3748;
  211. margin: 0 0 10px 0;
  212. }
  213. .image-container {
  214. max-width: 700px;
  215. margin: 0 auto;
  216. border-radius: 15px;
  217. overflow: hidden;
  218. box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
  219. }
  220. .flux-image {
  221. width: 100%;
  222. display: block;
  223. }
  224. .image-caption {
  225. text-align: center;
  226. font-size: 16px;
  227. color: #2d3748;
  228. padding: 15px;
  229. background: rgba(248, 250, 252, 0.8);
  230. margin: 0;
  231. border-top: 1px dashed #cbd5e0;
  232. }
  233. .application-container {
  234. display: grid;
  235. grid-template-columns: repeat(2, 1fr);
  236. gap: 25px;
  237. }
  238. .application-card {
  239. display: flex;
  240. padding: 20px;
  241. background: rgba(245, 252, 255, 0.7);
  242. border-radius: 15px;
  243. box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  244. transition: all 0.3s ease;
  245. border-left: 4px solid #5cb85c;
  246. }
  247. .application-card:hover {
  248. transform: translateY(-5px);
  249. box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
  250. }
  251. .application-icon {
  252. font-size: 2rem;
  253. margin-right: 20px;
  254. color: #5cb85c;
  255. }
  256. .application-content h3 {
  257. color: #1a365d;
  258. font-size: 1.3rem;
  259. margin-top: 0;
  260. margin-bottom: 12px;
  261. }
  262. .application-content p {
  263. font-size: 1.05rem;
  264. line-height: 1.6;
  265. color: #2d3748;
  266. margin: 0;
  267. }
  268. /* 响应式设计 */
  269. @media (max-width: 1200px) {
  270. .contribution-container {
  271. grid-template-columns: 1fr;
  272. }
  273. }
  274. @media (max-width: 900px) {
  275. .content-section {
  276. padding: 25px;
  277. }
  278. .section-number {
  279. width: 45px;
  280. height: 45px;
  281. font-size: 1.6rem;
  282. }
  283. h2 {
  284. font-size: 1.7rem;
  285. }
  286. .application-container {
  287. grid-template-columns: 1fr;
  288. }
  289. }
  290. @media (max-width: 768px) {
  291. .output-flux-intro {
  292. padding: 20px;
  293. }
  294. .concept-card {
  295. flex-direction: column;
  296. text-align: center;
  297. }
  298. .concept-icon {
  299. margin-right: 0;
  300. margin-bottom: 15px;
  301. }
  302. .contribution-card {
  303. flex-direction: column;
  304. text-align: center;
  305. }
  306. .contribution-icon {
  307. margin-right: 0;
  308. margin-bottom: 15px;
  309. }
  310. }
  311. @media (max-width: 480px) {
  312. .output-flux-intro {
  313. padding: 15px;
  314. }
  315. .content-section {
  316. padding: 20px;
  317. }
  318. .section-header {
  319. flex-direction: column;
  320. align-items: flex-start;
  321. }
  322. .section-number {
  323. margin-right: 0;
  324. margin-bottom: 15px;
  325. }
  326. h2 {
  327. font-size: 1.6rem;
  328. }
  329. .formula {
  330. font-size: 1.5rem;
  331. }
  332. }
  333. /* 新增视频模块样式 */
  334. .video-section {
  335. display: flex;
  336. flex-direction: column;
  337. gap: 30px;
  338. margin-top: 20px;
  339. }
  340. .video-container {
  341. border-radius: 12px;
  342. overflow: hidden;
  343. position: relative;
  344. box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
  345. max-width: 800px;
  346. margin: 0 auto;
  347. transition: all 0.4s ease;
  348. }
  349. .video-container:hover {
  350. transform: translateY(-5px);
  351. box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2);
  352. }
  353. .sampling-video {
  354. width: 100%;
  355. height: auto;
  356. display: block;
  357. background: #f8fafc;
  358. min-height: 400px;
  359. }
  360. .video-caption {
  361. text-align: center;
  362. font-size: 1.1rem;
  363. color: #1a365d;
  364. padding: 15px;
  365. font-weight: 600;
  366. background: linear-gradient(to right, rgba(248, 250, 252, 0.9), rgba(240, 248, 255, 0.9));
  367. margin: 0;
  368. border-top: 1px dashed #cbd5e0;
  369. position: relative;
  370. }
  371. .video-caption::before {
  372. content: "📹";
  373. position: absolute;
  374. left: 20px;
  375. top: 50%;
  376. transform: translateY(-50%);
  377. }
  378. .video-description {
  379. background: rgba(245, 249, 255, 0.6);
  380. border-radius: 12px;
  381. padding: 20px;
  382. border-left: 4px solid #3acfd5;
  383. }
  384. .video-description h3 {
  385. color: #1a365d;
  386. margin-top: 0;
  387. margin-bottom: 15px;
  388. font-size: 1.4rem;
  389. }
  390. .video-description ul {
  391. padding-left: 25px;
  392. margin: 15px 0;
  393. }
  394. .video-description li {
  395. margin-bottom: 10px;
  396. line-height: 1.7;
  397. position: relative;
  398. }
  399. .video-description li::before {
  400. content: "•";
  401. color: #3acfd5;
  402. font-size: 1.2rem;
  403. position: absolute;
  404. left: -20px;
  405. top: 0;
  406. }
  407. </style>