yifang.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811
  1. <template>
  2. <view class="rizhao">
  3. <!-- #ifdef MP-WEIXIN -->
  4. <web-view :src="`${url}/dist/index.html#/pages/h5/yifang?id=${id}&token=${token}`"></web-view>
  5. <!-- <web-view :src="`http://192.168.2.12:8080/?id=${id}&token=${token}`"></web-view> -->
  6. <!-- #endif -->
  7. <!-- #ifdef H5 -->
  8. <view class="objContaier" id="objContaier" :style="{width:conWidth + 'px',height:conHeight + 'px'}"></view>
  9. <view class="rizhao-louhao u-flex u-flex-wrap">
  10. <view class="u-flex u-col-center u-row-center louhao-active" :style="{borderColor:louhao == index ? '#1F7EFF' : '#999999'}" v-for="(item,index) in louhaoList" :key="index" @click="changelou(index)">
  11. <text class="text1" :style="{color:louhao == index ? '#1F7EFF' : '#999999'}">{{item.build_num}}#</text>
  12. <text class="text2" v-if="louhao == index">✓</text>
  13. </view>
  14. <!-- <view class="u-flex u-col-center u-row-center louhao-active" @click="zhankai()">
  15. <text class="text1">展开</text>
  16. </view> -->
  17. </view>
  18. <!-- <view class="louceng-fangxiang u-flex u-row-between">
  19. <text class="text">南面</text>
  20. <text>东西面</text>
  21. </view>
  22. <view class="louceng-jieqi">
  23. <view class="jieqi-box u-flex u-row-between u-flex-wrap">
  24. <text v-for="(a,b) in 6" :class="b == 0 ? 'text' : ''" :key="b">大寒</text>
  25. </view>
  26. </view>
  27. <view class="time-box u-flex u-flex-wrap">
  28. <view class="u-flex time-item" v-for="(a,b) in 5" :key="b">
  29. <text></text>
  30. <text>8h=日照</text>
  31. </view>
  32. </view> -->
  33. <scroll-view class="louceng-time-table" scroll-x="true" v-if="list.length > 0">
  34. <view class="u-flex-col" :style="{width:getwidth() + 'rpx'}">
  35. <view class="table-header">
  36. {{louhaoList[louhao].build_num}}#
  37. </view>
  38. <view class="body-header u-flex">
  39. <view class="header-title u-flex-col u-row-between">
  40. <text class="text1">单元</text>
  41. <text class="text2">楼层</text>
  42. <image src="../../static/images/xiegang.png" mode=""></image>
  43. </view>
  44. <view class="danyuan-header" v-for="(a,b) in list[0].unit_info" :key="b">
  45. <view class="danyuan-title">
  46. 第{{a.unit}}单元
  47. </view>
  48. <view class="u-flex">
  49. <view class="house-title" v-for="(c,d) in a.house_info" :key="d">
  50. {{d + 1}}室
  51. </view>
  52. </view>
  53. </view>
  54. </view>
  55. <view class="body-item" v-for="(item,index) in list" :key="index">
  56. <view class="item-title">{{item.floor}}F</view>
  57. <view class="danyuan-item" v-for="(a,b) in item.unit_info" :key="b">
  58. <view class="house-item" style="background-color: #dafddc;" v-for="(c,d) in a.house_info" :key="d">
  59. <view class="house-room u-flex">
  60. <text>{{c.room_num}}</text>
  61. <text>室</text>
  62. </view>
  63. <view class="house-allprice">
  64. <text>{{(c.record_total_price/10000).toFixed(2)}}</text>
  65. <text>万元</text>
  66. </view>
  67. <view class="house-price">
  68. <text>{{c.record_unit_price}}</text>
  69. <text>元/㎡</text>
  70. </view>
  71. <view class="house-mianji">
  72. <text>{{c.covered_area}}</text>
  73. <text>㎡</text>
  74. </view>
  75. </view>
  76. </view>
  77. </view>
  78. </view>
  79. </scroll-view>
  80. <!-- <view class="" v-html="disclaimer"></view> -->
  81. <view class="" style="height: 170rpx;"></view>
  82. <view class="rizhao-btn u-flex u-row-between">
  83. <text @click="showtocall = true">隐私电话</text>
  84. <text @click="tochat">在线咨询</text>
  85. </view>
  86. <u-popup v-model="showtocall" mode="center" background="rgba(0,0,0,0)">
  87. <view class="tocall-box u-flex-col u-col-center">
  88. <image class="tocall-img" src="../../static/images/popup1-1.png" mode=""></image>
  89. <view class="u-flex-col u-col-center tocall-text">您是否进行呼叫?</view>
  90. <view class="u-flex u-row-between tocall-btn">
  91. <text @click="showtocall = false">取消</text>
  92. <text @click="tocell">确定</text>
  93. </view>
  94. </view>
  95. </u-popup>
  96. <u-popup v-model="showlogin" mode="center" background="rgba(0,0,0,0)">
  97. <view class="tocall-box u-flex-col u-col-center">
  98. <image class="tocall-img" src="../../static/images/popup1-1.png" mode=""></image>
  99. <view class="u-flex-col u-col-center tocall-text">你目前处于未登录状态请前往登录</view>
  100. <view class="u-flex u-row-between tocall-btn">
  101. <text @click="showlogin = false">取消</text>
  102. <text @click="tologin">确定</text>
  103. </view>
  104. </view>
  105. </u-popup>
  106. <!-- #endif -->
  107. </view>
  108. </template>
  109. <script>
  110. // #ifdef H5
  111. var modelUrl = '' //'https://fangcan.hdlkeji.com/dist/fixedly/兔女郎.obj'
  112. var modelUrl1 = '' //'https://fangcan.hdlkeji.com/dist/fixedly/兔女郎.mtl'
  113. var container
  114. var rotating = true;
  115. import {
  116. OBJLoader
  117. } from '../../platforms/h5/common/obj/OBJLoader.js'
  118. import {
  119. MTLLoader
  120. } from '../../platforms/h5/common/obj/MTLLoader.js'
  121. import {
  122. OrbitControls
  123. } from '../../platforms/h5/common/OrbitControls.js';
  124. import * as THREE from '../../platforms/h5/common/three.js';
  125. // 材质模型加载器,模型在服务器上
  126. const mtlLoader = new MTLLoader()
  127. const objLoader = new OBJLoader();
  128. export default {
  129. data() {
  130. return {
  131. scene: undefined,
  132. light: undefined,
  133. camera: undefined,
  134. controls: undefined,
  135. renderer: undefined,
  136. conWidth: uni.getSystemInfoSync().windowWidth,
  137. conHeight: uni.getSystemInfoSync().windowWidth - 50,
  138. showtocall: false,
  139. id: '',
  140. louhaoList: [],
  141. louhao: 0,
  142. list: [],
  143. detail: {},
  144. showlogin: false,
  145. disclaimer: ''
  146. }
  147. },
  148. onLoad(option) {
  149. this.id = option.id
  150. uni.setStorageSync("token", option.token || '')
  151. this.getdata()
  152. this.getconfig()
  153. },
  154. onShow() {
  155. },
  156. mounted() {
  157. },
  158. methods: {
  159. getconfig() {
  160. this.$u.post('/api/Index/platform_config').then(res => {
  161. const regex = new RegExp('<img', 'gi')
  162. this.disclaimer = res.data.disclaimer.replace(regex, `<img style="max-width: 100%; height: auto"`)
  163. })
  164. },
  165. getwidth() {
  166. var width = 0
  167. this.list.forEach((item, index) => {
  168. if (index == 0) {
  169. width = width + 104
  170. item.unit_info.forEach(val => {
  171. width = width + val.house_info.length * 160
  172. })
  173. }
  174. })
  175. return width
  176. },
  177. getlist() {
  178. this.$u.post('/api/Property/house_detail', {
  179. id: this.id,
  180. build_num: this.louhaoList[this.louhao].build_num
  181. }).then(res => {
  182. this.list = res.data
  183. })
  184. },
  185. getdata() {
  186. this.$u.post('/api/Property/property_detail', {
  187. id: this.id
  188. }).then(res => {
  189. this.detail = res.data
  190. if (res.data.abbr_url)
  191. modelUrl = res.data.abbr_url
  192. uni.setNavigationBarTitle({
  193. title: res.data.name
  194. })
  195. if (modelUrl) {
  196. this.$nextTick(() => {
  197. this.setglb()
  198. this.animate();
  199. })
  200. }
  201. })
  202. this.$u.post('/api/Property/build_info', {
  203. id: this.id
  204. }).then(res => {
  205. this.louhaoList = res.data
  206. if (this.louhaoList.length > 0) {
  207. this.getlist()
  208. }
  209. })
  210. },
  211. tologin() {
  212. wx1.miniProgram.switchTab({
  213. url: "/pages/mine/mine"
  214. })
  215. },
  216. tochat() {
  217. if (uni.getStorageSync("token")) {
  218. this.$u.post('/api/Member/consult_record', {
  219. type: 2
  220. })
  221. wx1.miniProgram.navigateTo({
  222. url: "/pages/index/chat?hx_username=" + this.detail.hx_username + "&worker_id=" + this.detail.worker_id
  223. })
  224. } else {
  225. this.showlogin = true
  226. }
  227. },
  228. tocell() {
  229. if (uni.getStorageSync("token")) {
  230. this.$u.post('/api/Member/consult_record', {
  231. type: 1
  232. })
  233. window.location.href = `tel:${this.detail.privacy_phone}`
  234. } else {
  235. this.showlogin = true
  236. }
  237. },
  238. zhankai() {
  239. },
  240. changelou(index) {
  241. this.louhao = index
  242. this.getlist()
  243. },
  244. animate() {
  245. requestAnimationFrame(this.animate);
  246. if (rotating) {
  247. this.scene.rotation.y += -0.0008;
  248. } else {
  249. this.scene.rotation.y = this.scene.rotation.y;
  250. }
  251. this.renderer.render(this.scene, this.camera);
  252. },
  253. init() {
  254. // 创建场景
  255. this.scene = new THREE.Scene()
  256. this.scene.background = new THREE.Color('#B9D3FF')
  257. // 渲染
  258. container = document.getElementById('objContaier')
  259. this.renderer = new THREE.WebGLRenderer({
  260. antialias: false,
  261. alpha: true
  262. })
  263. this.renderer.outputEncoding = THREE.sRGBEncoding;
  264. this.renderer.setPixelRatio(window.devicePixelRatio);
  265. this.renderer.setSize(this.conWidth, this.conHeight);
  266. container.appendChild(this.renderer.domElement)
  267. // 相机
  268. this.camera = new THREE.PerspectiveCamera(45, this.conWidth / this.conHeight, 1, 1000000000)
  269. //设置视角离原点的位置(眼睛距离模型的距离)
  270. if (modelUrl1) {
  271. mtlLoader.load(modelUrl1, (mtl) => {
  272. // console.log(JSON.parse(JSON.stringify(mtl)));
  273. mtl.preload()
  274. for (const material of Object.values(mtl.materials)) {
  275. material.side = THREE.DoubleSide;
  276. }
  277. objLoader.setMaterials(mtl)
  278. this.setobj()
  279. })
  280. } else {
  281. this.setobj()
  282. }
  283. },
  284. setobj() {
  285. objLoader.load(modelUrl, (root) => {
  286. // console.log(JSON.parse(JSON.stringify(root.children)));
  287. // 设置旋转中心点
  288. const box = new THREE.Box3().setFromObject(root);
  289. const boxSize = box.getSize(new THREE.Vector3()).length();
  290. const boxCenter = box.getCenter(new THREE.Vector3());
  291. root.position.x = root.position.x - boxCenter.x
  292. root.position.y = root.position.y - boxCenter.y
  293. root.position.z = root.position.z - boxCenter.z
  294. var num = boxSize * 0.6
  295. this.root = root
  296. this.camera.position.set(num, num, num)
  297. this.camera.lookAt(new THREE.Vector3(0, 0, 0))
  298. // 轨道控制
  299. this.controls = new OrbitControls(this.camera, this.renderer.domElement)
  300. this.controls.target.set(0, 0, 0);
  301. this.controls.update();
  302. // 光源
  303. const skyColor = 0xB09595;
  304. const groundColor = 0x594C4B;
  305. const intensity = 0.5;
  306. const light = new THREE.HemisphereLight(skyColor, groundColor, intensity);
  307. this.scene.add(light);
  308. // 直射光
  309. const pivotPoint = window.pivotPoint = new THREE.Object3D();
  310. const dcolor = 0xffffff;
  311. const dlight = new THREE.DirectionalLight(dcolor);
  312. // 设置平行光源的产生阴影的范围参数
  313. dlight.shadow.camera.near = 0;
  314. dlight.shadow.camera.far = 50000;
  315. dlight.shadow.camera.left = -20000;
  316. dlight.shadow.camera.right = 20000;
  317. dlight.shadow.camera.top = 20000;
  318. dlight.shadow.camera.bottom = -20000;
  319. dlight.distance = 1110;
  320. dlight.intensity = 0.1;
  321. dlight.shadow.mapSize.height = 2560;
  322. dlight.shadow.mapSize.width = 2560;
  323. dlight.castShadow = true;
  324. let sphereLight = new THREE.SphereGeometry(5, 32, 32); // 创建一个球形mesh,用来存放点光源
  325. let sphereLightMaterial = new THREE.MeshBasicMaterial({
  326. color: 0xac6c25
  327. });
  328. let sphereLightMesh = window.sphereLightMesh = new THREE.Mesh(sphereLight, sphereLightMaterial);
  329. sphereLightMesh.castShadow = false; //将这个球形mesh的产生阴影和接收阴影参数打开
  330. sphereLightMesh.receiveShadow = false; //将这个球形mesh的产生阴影和接收阴影参数打开
  331. sphereLightMesh.position.set(-25000, 0, 0); // 设置此球形mesh的位置
  332. pivotPoint.add(sphereLightMesh); // 将球形mesh添加到点光源里
  333. pivotPoint.add(dlight); // 将平行光源添加到点光源里
  334. dlight.position.copy(sphereLightMesh.position);
  335. // dlight.position.set(num, num, num);
  336. this.scene.add(dlight);
  337. // 环境光
  338. // const ambient = new THREE.AmbientLight(0x333333, 1)
  339. // this.scene.add(ambient)
  340. // 点光源
  341. // const dian = new THREE.PointLight(0x333333, 1, 100);
  342. // dian.position.set(num, num, num);
  343. // this.scene.add(dian);
  344. // 辅助坐标线
  345. // var axesHelper = new THREE.AxesHelper(150);
  346. // this.scene.add(axesHelper);
  347. this.scene.add(this.root);
  348. // console.log(boxSize, boxCenter);
  349. }, (xhr) => {
  350. // console.log(xhr.loaded, xhr.total, 'objLoader');
  351. // console.log(xhr);
  352. // console.log((xhr.loaded / xhr.total * 100) + '% loaded');
  353. });
  354. },
  355. setglb() {
  356. this.init();
  357. var modelBorder = document.getElementById("objContaier");
  358. modelBorder.addEventListener("mouseenter", function(event) {
  359. rotating = false;
  360. });
  361. modelBorder.addEventListener("mouseleave", function(event) {
  362. rotating = true;
  363. });
  364. modelBorder.addEventListener('touchmove', function(e) {
  365. rotating = false;
  366. }, false);
  367. modelBorder.addEventListener('touchstart', function(e) {
  368. rotating = false;
  369. }, false);
  370. modelBorder.addEventListener('touchend', function(e) {
  371. rotating = true;
  372. }, false);
  373. }
  374. }
  375. }
  376. // #endif
  377. // #ifdef MP-WEIXIN
  378. export default {
  379. data() {
  380. return {
  381. id: '',
  382. token: uni.getStorageSync("token") || '',
  383. url: this.$url
  384. }
  385. },
  386. onLoad(option) {
  387. this.id = option.id
  388. },
  389. methods: {
  390. }
  391. }
  392. // #endif
  393. </script>
  394. <style lang="scss">
  395. page {
  396. background-color: #F5F5F5;
  397. }
  398. .rizhao {
  399. .tocall-box {
  400. position: relative;
  401. .tocall-img {
  402. width: 650rpx;
  403. height: 476rpx;
  404. }
  405. .tocall-btn {
  406. position: absolute;
  407. bottom: 70rpx;
  408. left: 0;
  409. width: 100%;
  410. padding: 0 48rpx;
  411. text:first-child {
  412. width: 254rpx;
  413. line-height: 80rpx;
  414. background: #FFA120;
  415. border-radius: 20rpx;
  416. text-align: center;
  417. font-size: 34rpx;
  418. font-family: PingFangSC-Medium, PingFang SC;
  419. font-weight: 500;
  420. color: #FFFFFF;
  421. }
  422. text:last-child {
  423. width: 254rpx;
  424. line-height: 80rpx;
  425. background: #1F7EFF;
  426. border-radius: 20rpx;
  427. text-align: center;
  428. font-size: 34rpx;
  429. font-family: PingFangSC-Medium, PingFang SC;
  430. font-weight: 500;
  431. color: #FFFFFF;
  432. text-decoration: none;
  433. }
  434. }
  435. .tocall-text {
  436. text-align: center;
  437. font-size: 24rpx;
  438. font-family: PingFangSC-Regular, PingFang SC;
  439. font-weight: 400;
  440. color: #999999;
  441. position: absolute;
  442. top: 244rpx;
  443. left: 0;
  444. z-index: 10;
  445. width: 100%;
  446. }
  447. }
  448. .rizhao-btn {
  449. position: fixed;
  450. bottom: 0;
  451. left: 0;
  452. z-index: 10;
  453. width: 750rpx;
  454. height: 166rpx;
  455. background: #FFFFFF;
  456. padding: 0 24rpx 54rpx 24rpx;
  457. text:first-child {
  458. width: 338rpx;
  459. line-height: 84rpx;
  460. background: #FFA120;
  461. border-radius: 20rpx;
  462. text-align: center;
  463. font-size: 28rpx;
  464. font-family: PingFangSC-Regular, PingFang SC;
  465. font-weight: 400;
  466. color: #FFFFFF;
  467. text-decoration: none;
  468. }
  469. text:last-child {
  470. width: 338rpx;
  471. line-height: 84rpx;
  472. background: #1F7EFF;
  473. border-radius: 20rpx;
  474. text-align: center;
  475. font-size: 28rpx;
  476. font-family: PingFangSC-Regular, PingFang SC;
  477. font-weight: 400;
  478. color: #FFFFFF;
  479. }
  480. }
  481. .louceng-time-table {
  482. width: 702rpx;
  483. margin: 20rpx auto;
  484. background-color: #fff;
  485. .body-header {
  486. height: 124rpx;
  487. white-space: nowrap;
  488. border-bottom: 1rpx solid #CCCCCC;
  489. .danyuan-header {
  490. .danyuan-title {
  491. height: 58rpx;
  492. line-height: 58rpx;
  493. text-align: center;
  494. border-bottom: 1rpx solid #CCCCCC;
  495. border-right: 1rpx solid #CCCCCC;
  496. }
  497. .house-title {
  498. width: 160rpx;
  499. height: 64rpx;
  500. line-height: 64rpx;
  501. font-size: 24rpx;
  502. font-family: PingFangSC-Regular, PingFang SC;
  503. font-weight: 400;
  504. color: #333333;
  505. text-align: center;
  506. border-right: 1rpx solid #CCCCCC;
  507. }
  508. }
  509. .header-title {
  510. width: 104rpx;
  511. height: 124rpx;
  512. border-right: 1rpx solid #CCCCCC;
  513. padding: 8rpx 12rpx;
  514. position: relative;
  515. image {
  516. position: absolute;
  517. top: 0;
  518. left: 0;
  519. width: 100%;
  520. height: 100%;
  521. }
  522. text {
  523. font-size: 24rpx;
  524. font-family: PingFangSC-Regular, PingFang SC;
  525. font-weight: 400;
  526. color: #333333;
  527. }
  528. .text1 {
  529. width: 100%;
  530. text-align: right;
  531. }
  532. .text2 {
  533. width: 100%;
  534. }
  535. }
  536. }
  537. .body-item {
  538. height: 160rpx;
  539. white-space: nowrap;
  540. border-bottom: 1rpx solid #CCCCCC;
  541. .danyuan-item {
  542. display: inline-block;
  543. white-space: nowrap;
  544. vertical-align: top;
  545. .house-item {
  546. display: inline-flex;
  547. flex-direction: column;
  548. justify-content: center;
  549. width: 160rpx;
  550. padding-left: 16rpx;
  551. border-right: 1rpx solid #CCCCCC;
  552. border-bottom: 1rpx solid #CCCCCC;
  553. height: 160rpx;
  554. .house-mianji {
  555. text:first-child {
  556. font-size: 24rpx;
  557. color: #333333;
  558. }
  559. text:last-child {
  560. font-size: 18rpx;
  561. color: #999999;
  562. }
  563. }
  564. .house-price {
  565. text:first-child {
  566. font-size: 24rpx;
  567. color: #1F7EFF;
  568. }
  569. text:last-child {
  570. font-size: 18rpx;
  571. color: #999999;
  572. }
  573. }
  574. .house-allprice {
  575. text:first-child {
  576. font-size: 28rpx;
  577. color: #FFA120;
  578. }
  579. text:last-child {
  580. font-size: 18rpx;
  581. color: #999999;
  582. }
  583. }
  584. .house-room {
  585. text:first-child {
  586. font-size: 24rpx;
  587. color: #333333;
  588. }
  589. text:last-child {
  590. font-size: 18rpx;
  591. color: #999999;
  592. }
  593. }
  594. }
  595. }
  596. .item-title {
  597. vertical-align: top;
  598. width: 104rpx;
  599. text-align: center;
  600. line-height: 160rpx;
  601. font-size: 24rpx;
  602. font-family: PingFangSC-Regular, PingFang SC;
  603. font-weight: 400;
  604. color: #333333;
  605. border-right: 1rpx solid #CCCCCC;
  606. display: inline-block;
  607. min-width: 1rpx;
  608. }
  609. }
  610. .table-header {
  611. width: 100%;
  612. text-align: center;
  613. font-size: 24rpx;
  614. font-family: PingFangSC-Regular, PingFang SC;
  615. font-weight: 400;
  616. color: #333333;
  617. line-height: 110rpx;
  618. border-bottom: 1rpx solid #CCCCCC;
  619. }
  620. }
  621. .time-box {
  622. width: 702rpx;
  623. height: 138rpx;
  624. background: #FFFFFF;
  625. border-radius: 20rpx;
  626. margin: 20rpx auto;
  627. padding: 24rpx 20rpx 4rpx 20rpx;
  628. .time-item {
  629. margin-bottom: 20rpx;
  630. text:first-child {
  631. width: 32rpx;
  632. height: 32rpx;
  633. background: #61C86A;
  634. border-radius: 8rpx;
  635. margin-right: 20rpx;
  636. }
  637. text:last-child {
  638. font-size: 24rpx;
  639. font-family: PingFangSC-Regular, PingFang SC;
  640. font-weight: 400;
  641. color: #999999;
  642. margin-right: 40rpx;
  643. }
  644. }
  645. }
  646. .louceng-jieqi {
  647. background-color: #fff;
  648. padding-bottom: 24rpx;
  649. .jieqi-box {
  650. width: 662rpx;
  651. height: 164rpx;
  652. background: #F5F5F5;
  653. border-radius: 20rpx;
  654. margin: 0 auto;
  655. padding: 24rpx 20rpx 4rpx 20rpx;
  656. text {
  657. margin-bottom: 20rpx;
  658. width: 194rpx;
  659. line-height: 48rpx;
  660. background: #FFFFFF;
  661. border-radius: 8rpx;
  662. border: 2rpx solid #999999;
  663. text-align: center;
  664. font-size: 24rpx;
  665. font-family: PingFangSC-Regular, PingFang SC;
  666. font-weight: 400;
  667. color: #999999;
  668. }
  669. .text {
  670. color: #1F7EFF;
  671. border-color: #1F7EFF;
  672. }
  673. }
  674. }
  675. .louceng-fangxiang {
  676. padding: 24rpx 44rpx;
  677. background-color: #FFFFFF;
  678. text {
  679. width: 318rpx;
  680. line-height: 84rpx;
  681. background: #FFFFFF;
  682. border-radius: 20rpx;
  683. border: 2rpx solid #999999;
  684. text-align: center;
  685. font-size: 28rpx;
  686. font-family: PingFangSC-Regular, PingFang SC;
  687. font-weight: 400;
  688. color: #999999;
  689. }
  690. .text {
  691. color: #1F7EFF;
  692. border-color: #1F7EFF;
  693. }
  694. }
  695. .rizhao-louhao {
  696. position: sticky;
  697. top: 0;
  698. left: 0;
  699. z-index: 10;
  700. width: 750rpx;
  701. background: #FFFFFF;
  702. border-radius: 20rpx;
  703. padding: 0 18rpx 24rpx 18rpx;
  704. border-bottom: 2rpx solid #F5F5F5;
  705. .louhao-active {
  706. margin: 0 25rpx;
  707. width: 92rpx;
  708. height: 40rpx;
  709. background: #FFFFFF;
  710. border-radius: 8rpx;
  711. border: 1rpx solid #999999;
  712. position: relative;
  713. margin-top: 24rpx;
  714. .text1 {
  715. font-size: 24rpx;
  716. font-family: PingFangSC-Regular, PingFang SC;
  717. font-weight: 400;
  718. color: #999999;
  719. }
  720. .text2 {
  721. width: 20rpx;
  722. line-height: 20rpx;
  723. background: #1F7EFF;
  724. border-radius: 8rpx 0px 8rpx 0px;
  725. text-align: center;
  726. position: absolute;
  727. bottom: 0;
  728. right: 0;
  729. z-index: 1;
  730. color: #fff;
  731. font-size: 18rpx;
  732. }
  733. }
  734. }
  735. }
  736. </style>