Showing
6 changed files
with
69 additions
and
19 deletions
| @@ -7,7 +7,7 @@ | @@ -7,7 +7,7 @@ | ||
| 7 | "main": "Index.ets", | 7 | "main": "Index.ets", |
| 8 | "version": "1.0.0", | 8 | "version": "1.0.0", |
| 9 | "dependencies": { | 9 | "dependencies": { |
| 10 | - "@ohos/lottie": "2.0.0", | 10 | + "@ohos/lottie": "2.0.10", |
| 11 | "wdConstant": "file:../../commons/wdConstant", | 11 | "wdConstant": "file:../../commons/wdConstant", |
| 12 | "wdPlayer": "file:../../features/wdPlayer", | 12 | "wdPlayer": "file:../../features/wdPlayer", |
| 13 | "wdLogin": "file:../../features/wdLogin", | 13 | "wdLogin": "file:../../features/wdLogin", |
| @@ -7,7 +7,6 @@ import { ErrorComponent } from '../view/ErrorComponent' | @@ -7,7 +7,6 @@ import { ErrorComponent } from '../view/ErrorComponent' | ||
| 7 | import RefreshLayout from './RefreshLayout' | 7 | import RefreshLayout from './RefreshLayout' |
| 8 | import { RefreshLayoutBean } from './RefreshLayoutBean'; | 8 | import { RefreshLayoutBean } from './RefreshLayoutBean'; |
| 9 | import { CompDTO, ContentDTO } from 'wdBean' | 9 | import { CompDTO, ContentDTO } from 'wdBean' |
| 10 | -import LoadMoreLayout from './LoadMoreLayout' | ||
| 11 | import NoMoreLayout from './NoMoreLayout' | 10 | import NoMoreLayout from './NoMoreLayout' |
| 12 | import CustomRefreshLoadLayout from './CustomRefreshLoadLayout'; | 11 | import CustomRefreshLoadLayout from './CustomRefreshLoadLayout'; |
| 13 | import { CustomSelectUI } from '../view/CustomSelectUI'; | 12 | import { CustomSelectUI } from '../view/CustomSelectUI'; |
| 1 | -import CustomRefreshLoadLayout from './CustomRefreshLoadLayout'; | ||
| 2 | -import { RefreshLayoutBean } from './RefreshLayoutBean'; | 1 | +import CustomLoadMoreLayout from '../refresh/CustomLoadMoreLayout'; |
| 3 | 2 | ||
| 4 | /** | 3 | /** |
| 5 | * The load more layout component. | 4 | * The load more layout component. |
| 6 | */ | 5 | */ |
| 7 | @Component | 6 | @Component |
| 8 | export default struct LoadMoreLayout { | 7 | export default struct LoadMoreLayout { |
| 9 | - @ObjectLink refreshBean: RefreshLayoutBean; | 8 | + @Prop isVisible: boolean; |
| 10 | 9 | ||
| 11 | build() { | 10 | build() { |
| 12 | Column() { | 11 | Column() { |
| 13 | - if (this.refreshBean.isVisible) { | ||
| 14 | - CustomRefreshLoadLayout({ | ||
| 15 | - refreshBean: new RefreshLayoutBean(this.refreshBean.isVisible, | ||
| 16 | - this.refreshBean.imageSrc, this.refreshBean.textValue, this.refreshBean.heightValue) | ||
| 17 | - }) | ||
| 18 | - } else { | ||
| 19 | - CustomRefreshLoadLayout({ | ||
| 20 | - refreshBean: new RefreshLayoutBean(this.refreshBean.isVisible, | ||
| 21 | - this.refreshBean.imageSrc, this.refreshBean.textValue, 0) | ||
| 22 | - }) | 12 | + if (this.isVisible) { |
| 13 | + CustomLoadMoreLayout() | ||
| 23 | } | 14 | } |
| 24 | } | 15 | } |
| 25 | } | 16 | } |
| @@ -84,10 +84,7 @@ export struct PageComponent { | @@ -84,10 +84,7 @@ export struct PageComponent { | ||
| 84 | // 加载更多 | 84 | // 加载更多 |
| 85 | ListItem() { | 85 | ListItem() { |
| 86 | if (this.pageModel.hasMore) { | 86 | if (this.pageModel.hasMore) { |
| 87 | - // LoadMoreLayout({ | ||
| 88 | - // refreshBean: new RefreshLayoutBean(this.pageModel.isVisiblePullUpLoad, this.pageModel.pullUpLoadImage, | ||
| 89 | - // this.pageModel.pullUpLoadText, this.pageModel.pullUpLoadHeight) | ||
| 90 | - // }) | 87 | + LoadMoreLayout({ isVisible: this.pageModel.isVisiblePullUpLoad }) |
| 91 | } else if (!this.pageModel.contentNeedScroll) { | 88 | } else if (!this.pageModel.contentNeedScroll) { |
| 92 | PageNoMoreLayout({ noMoreBean: new NoMoreBean(this.pageModel.pageInfo.baselineCopywriting) }) | 89 | PageNoMoreLayout({ noMoreBean: new NoMoreBean(this.pageModel.pageInfo.baselineCopywriting) }) |
| 93 | } | 90 | } |
sight_harmony/features/wdComponent/src/main/ets/components/refresh/CustomLoadMoreLayout.ets
0 → 100644
| 1 | +import lottie, { AnimationItem } from '@ohos/lottie'; | ||
| 2 | +import { Logger } from 'wdKit/Index'; | ||
| 3 | +import { RefreshConstants } from '../../utils/RefreshConstants'; | ||
| 4 | + | ||
| 5 | +/** | ||
| 6 | + * Custom layout to show refresh or load. | ||
| 7 | + * Android 24+12+24(top+image+bottom) 高度db | ||
| 8 | + */ | ||
| 9 | +@Component | ||
| 10 | +export default struct CustomLoadMoreLayout { | ||
| 11 | + private mainRenderingSettings: RenderingContextSettings = new RenderingContextSettings(true) | ||
| 12 | + private mainCanvasRenderingContext: CanvasRenderingContext2D = | ||
| 13 | + new CanvasRenderingContext2D(this.mainRenderingSettings) | ||
| 14 | + private animateName: string = "loadMore"; | ||
| 15 | + private animateItem: AnimationItem | null = null; | ||
| 16 | + | ||
| 17 | + build() { | ||
| 18 | + Row() { | ||
| 19 | + Canvas(this.mainCanvasRenderingContext) | ||
| 20 | + .width(14) | ||
| 21 | + .height(14) | ||
| 22 | + .backgroundColor(Color.Transparent) | ||
| 23 | + .onReady(() => { | ||
| 24 | + // 可在此生命回调周期中加载动画,可以保证动画尺寸正确 | ||
| 25 | + //抗锯齿的设置 | ||
| 26 | + this.mainCanvasRenderingContext.imageSmoothingEnabled = true; | ||
| 27 | + this.mainCanvasRenderingContext.imageSmoothingQuality = 'medium' | ||
| 28 | + this.animate() | ||
| 29 | + }) | ||
| 30 | + .onDisAppear(() => { | ||
| 31 | + Logger.error('zzzz','CustomLoadMoreLayout onDisAppear') | ||
| 32 | + lottie.destroy(this.animateName); | ||
| 33 | + }) | ||
| 34 | + | ||
| 35 | + Text('努力加载中') | ||
| 36 | + .margin({ | ||
| 37 | + left: RefreshConstants.RefreshLayout_TEXT_MARGIN_LEFT, | ||
| 38 | + bottom: RefreshConstants.RefreshLayout_TEXT_MARGIN_BOTTOM | ||
| 39 | + }) | ||
| 40 | + .fontSize(14) | ||
| 41 | + .fontColor('#888888') | ||
| 42 | + .textAlign(TextAlign.Center) | ||
| 43 | + } | ||
| 44 | + .clip(true) | ||
| 45 | + .width(RefreshConstants.FULL_WIDTH) | ||
| 46 | + .justifyContent(FlexAlign.Center) | ||
| 47 | + .height(60) | ||
| 48 | + } | ||
| 49 | + | ||
| 50 | + animate() { | ||
| 51 | + if (this.animateItem == null) { | ||
| 52 | + this.animateItem = lottie.loadAnimation({ | ||
| 53 | + container: this.mainCanvasRenderingContext, | ||
| 54 | + renderer: 'canvas', // canvas 渲染模式 | ||
| 55 | + loop: 50, | ||
| 56 | + autoplay: true, | ||
| 57 | + name: this.animateName, | ||
| 58 | + path: "lottie/loading_more.json", // 路径加载动画只支持entry/src/main/ets 文件夹下的相对路径 | ||
| 59 | + }) | ||
| 60 | + } | ||
| 61 | + } | ||
| 62 | +} |
| 1 | +{"v":"5.6.10","fr":60,"ip":0,"op":60,"w":128,"h":128,"nm":"上拉刷新-灰色","ddd":0,"assets":[{"id":"image_0","w":128,"h":128,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"loding.png","cl":"png","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0]},{"t":60,"s":[360]}],"ix":10},"p":{"a":0,"k":[64,64,0],"ix":2},"a":{"a":0,"k":[64,64,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":60,"st":0,"bm":0}],"markers":[{"tm":1,"cm":"{\n\t\"storePath\":\t\"/Users/changkang/Downloads/中文版动效/动效到处最终版本的/上拉刷新-列表灰色\"\n}","dr":0}]} |
-
Please register or login to post a comment