From a41036c91dd69b02c131497558356dfa3f7c53bc Mon Sep 17 00:00:00 2001 From: "pengfei.zhou" Date: Wed, 27 Nov 2019 11:55:49 +0800 Subject: [PATCH] feat:fix transform and layoutcontainer conflict --- demo/src/ListDemo.ts | 1 - demo/src/RefreshableDemo.ts | 27 ++-- demo/src/utils.ts | 4 +- .../Classes/Refresh/DoricRefreshableNode.m | 20 ++- iOS/Pod/Classes/Shader/DoricLayouts.m | 125 +++++++++++------- iOS/Pod/Classes/Shader/DoricViewNode.m | 6 +- js-framework/src/ui/refreshable.ts | 1 - 7 files changed, 113 insertions(+), 71 deletions(-) diff --git a/demo/src/ListDemo.ts b/demo/src/ListDemo.ts index b3de5c46..9c037881 100644 --- a/demo/src/ListDemo.ts +++ b/demo/src/ListDemo.ts @@ -1,6 +1,5 @@ import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout, Text, refreshable, Refreshable, ListItem } from "doric"; import { rotatedArrow, colors } from "./utils"; -import { isObject } from "util"; @Entry class ListPanel extends Panel { build(rootView: Group): void { diff --git a/demo/src/RefreshableDemo.ts b/demo/src/RefreshableDemo.ts index 743da1e6..211108be 100644 --- a/demo/src/RefreshableDemo.ts +++ b/demo/src/RefreshableDemo.ts @@ -20,18 +20,21 @@ class RefreshableDemo extends Panel { width: 30, height: 30, imageBase64: icon_refresh, - }).also(v => refreshImage = v), - ]), { - startAnimation: () => { - log('startAnimation') - }, - stopAnimation: () => { - log('stopAnimation') - }, - setProgressRotation: (rotation: number) => { - refreshImage.setRotation(context, rotation) - }, - }), + }).also(v => { + refreshImage = v + }), + ]), + { + startAnimation: () => { + log('startAnimation') + }, + stopAnimation: () => { + log('stopAnimation') + }, + setProgressRotation: (rotation: number) => { + refreshImage.setRotation(context, rotation) + }, + }), content: scroller(vlayout([ title("Refreshable Demo"), label('start Refresh').apply({ diff --git a/demo/src/utils.ts b/demo/src/utils.ts index 8bb513b6..385cef4c 100644 --- a/demo/src/utils.ts +++ b/demo/src/utils.ts @@ -1,6 +1,4 @@ -import { Color, text, Stack, Text, layoutConfig, LayoutSpec, gravity, pullable, stack, image, Image, BridgeContext } from "doric"; -import { log } from "util"; - +import { Color, text, Stack, Text, layoutConfig, LayoutSpec, gravity, pullable, stack, image, Image, BridgeContext, log } from "doric"; export const icon_refresh = '' export const colors = [ diff --git a/iOS/Pod/Classes/Refresh/DoricRefreshableNode.m b/iOS/Pod/Classes/Refresh/DoricRefreshableNode.m index 1b9c3c90..37f999d6 100644 --- a/iOS/Pod/Classes/Refresh/DoricRefreshableNode.m +++ b/iOS/Pod/Classes/Refresh/DoricRefreshableNode.m @@ -5,7 +5,7 @@ #import "DoricRefreshableNode.h" #import "Doric.h" -@interface DoricRefreshableNode () +@interface DoricRefreshableNode () @property(nonatomic, strong) DoricViewNode *contentNode; @property(nonatomic, copy) NSString *contentViewId; @property(nonatomic, strong) DoricViewNode *headerNode; @@ -14,7 +14,10 @@ @interface DoricRefreshableNode () @implementation DoricRefreshableNode - (DoricSwipeRefreshLayout *)build { - return [DoricSwipeRefreshLayout new]; + return [[DoricSwipeRefreshLayout new] also:^(DoricSwipeRefreshLayout *it) { + it.swipePullingDelegate = self; + + }]; } - (void)blendView:(DoricSwipeRefreshLayout *)view forPropName:(NSString *)name propValue:(id)prop { @@ -138,4 +141,17 @@ - (void)blendHeader { - (void)blendSubNode:(NSDictionary *)subModel { [[self subNodeWithViewId:subModel[@"id"]] blend:subModel[@"props"]]; } + +- (void)startAnimation { + [self.headerNode callJSResponse:@"startAnimation", nil]; +} + +- (void)stopAnimation { + [self.headerNode callJSResponse:@"stopAnimation", nil]; +} + +- (void)setProgressRotation:(CGFloat)rotation { + [self.headerNode callJSResponse:@"setProgressRotation", @(rotation), nil]; +} + @end diff --git a/iOS/Pod/Classes/Shader/DoricLayouts.m b/iOS/Pod/Classes/Shader/DoricLayouts.m index 53bf0d7b..7c9f4229 100644 --- a/iOS/Pod/Classes/Shader/DoricLayouts.m +++ b/iOS/Pod/Classes/Shader/DoricLayouts.m @@ -129,28 +129,33 @@ - (CGSize)sizeContent:(CGSize)size { if (child.isHidden) { continue; } + DoricLayoutConfig *childConfig = child.layoutConfig; if (!childConfig) { childConfig = [DoricLayoutConfig new]; } CGSize childSize = CGSizeMake(child.width, child.height); - if ([child isKindOfClass:[DoricLayoutContainer class]] - || childConfig.widthSpec == DoricLayoutWrapContent - || childConfig.heightSpec == DoricLayoutWrapContent) { - childSize = [child sizeThatFits:CGSizeMake(size.width, size.height - contentHeight)]; - } - if (childConfig.widthSpec == DoricLayoutExact) { - childSize.width = child.width; - } else if (childConfig.widthSpec == DoricLayoutAtMost) { - childSize.width = size.width; - } - if (childConfig.heightSpec == DoricLayoutExact) { - childSize.height = child.height; - } else if (childConfig.heightSpec == DoricLayoutAtMost) { - childSize.height = size.height - contentHeight; - } - if (childConfig.weight) { - childSize.height = child.height; + if (CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + if ([child isKindOfClass:[DoricLayoutContainer class]] + || childConfig.widthSpec == DoricLayoutWrapContent + || childConfig.heightSpec == DoricLayoutWrapContent) { + childSize = [child sizeThatFits:CGSizeMake(size.width, size.height - contentHeight)]; + } + if (childConfig.widthSpec == DoricLayoutExact) { + childSize.width = child.width; + } else if (childConfig.widthSpec == DoricLayoutAtMost) { + childSize.width = size.width; + } + if (childConfig.heightSpec == DoricLayoutExact) { + childSize.height = child.height; + } else if (childConfig.heightSpec == DoricLayoutAtMost) { + childSize.height = size.height - contentHeight; + } + if (childConfig.weight) { + childSize.height = child.height; + } + } else { + childSize = child.bounds.size; } contentWidth = MAX(contentWidth, childSize.width + childConfig.margin.left + childConfig.margin.right); contentHeight = MAX(contentHeight, childSize.height + childConfig.margin.top + childConfig.margin.bottom); @@ -167,6 +172,9 @@ - (void)layout:(CGSize)targetSize { if (child.isHidden) { continue; } + if (!CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + continue; + } DoricLayoutConfig *childConfig = child.layoutConfig; if (!childConfig) { childConfig = [DoricLayoutConfig new]; @@ -246,23 +254,27 @@ - (CGSize)sizeContent:(CGSize)size { childConfig = [DoricLayoutConfig new]; } CGSize childSize = CGSizeMake(child.width, child.height); - if ([child isKindOfClass:[DoricLayoutContainer class]] - || childConfig.widthSpec == DoricLayoutWrapContent - || childConfig.heightSpec == DoricLayoutWrapContent) { - childSize = [child sizeThatFits:CGSizeMake(size.width, size.height - contentHeight)]; - } - if (childConfig.widthSpec == DoricLayoutExact) { - childSize.width = child.width; - } else if (childConfig.widthSpec == DoricLayoutAtMost) { - childSize.width = size.width; - } - if (childConfig.heightSpec == DoricLayoutExact) { - childSize.height = child.height; - } else if (childConfig.heightSpec == DoricLayoutAtMost) { - childSize.height = size.height - contentHeight; - } - if (childConfig.weight) { - childSize.height = child.height; + if (CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + if ([child isKindOfClass:[DoricLayoutContainer class]] + || childConfig.widthSpec == DoricLayoutWrapContent + || childConfig.heightSpec == DoricLayoutWrapContent) { + childSize = [child sizeThatFits:CGSizeMake(size.width, size.height - contentHeight)]; + } + if (childConfig.widthSpec == DoricLayoutExact) { + childSize.width = child.width; + } else if (childConfig.widthSpec == DoricLayoutAtMost) { + childSize.width = size.width; + } + if (childConfig.heightSpec == DoricLayoutExact) { + childSize.height = child.height; + } else if (childConfig.heightSpec == DoricLayoutAtMost) { + childSize.height = size.height - contentHeight; + } + if (childConfig.weight) { + childSize.height = child.height; + } + } else { + childSize = child.bounds.size; } contentWidth = MAX(contentWidth, childSize.width + childConfig.margin.left + childConfig.margin.right); contentHeight += childSize.height + self.space + childConfig.margin.top + childConfig.margin.bottom; @@ -294,6 +306,9 @@ - (void)layout:(CGSize)targetSize { if (child.isHidden) { continue; } + if (!CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + continue; + } DoricLayoutConfig *childConfig = child.layoutConfig; if (!childConfig) { childConfig = [DoricLayoutConfig new]; @@ -371,24 +386,29 @@ - (CGSize)sizeContent:(CGSize)size { childConfig = [DoricLayoutConfig new]; } CGSize childSize = CGSizeMake(child.width, child.height); - if ([child isKindOfClass:[DoricLayoutContainer class]] - || childConfig.widthSpec == DoricLayoutWrapContent - || childConfig.heightSpec == DoricLayoutWrapContent) { - childSize = [child sizeThatFits:CGSizeMake(size.width - contentWidth, size.height)]; - } - if (childConfig.widthSpec == DoricLayoutExact) { - childSize.width = child.width; - } else if (childConfig.widthSpec == DoricLayoutAtMost) { - childSize.width = size.width - contentWidth; - } - if (childConfig.heightSpec == DoricLayoutExact) { - childSize.height = child.height; - } else if (childConfig.heightSpec == DoricLayoutAtMost) { - childSize.height = size.height; - } - if (childConfig.weight) { - childSize.width = child.width; + if (CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + if ([child isKindOfClass:[DoricLayoutContainer class]] + || childConfig.widthSpec == DoricLayoutWrapContent + || childConfig.heightSpec == DoricLayoutWrapContent) { + childSize = [child sizeThatFits:CGSizeMake(size.width - contentWidth, size.height)]; + } + if (childConfig.widthSpec == DoricLayoutExact) { + childSize.width = child.width; + } else if (childConfig.widthSpec == DoricLayoutAtMost) { + childSize.width = size.width - contentWidth; + } + if (childConfig.heightSpec == DoricLayoutExact) { + childSize.height = child.height; + } else if (childConfig.heightSpec == DoricLayoutAtMost) { + childSize.height = size.height; + } + if (childConfig.weight) { + childSize.width = child.width; + } + } else { + childSize = child.bounds.size; } + contentWidth += childSize.width + self.space + childConfig.margin.left + childConfig.margin.right; contentHeight = MAX(contentHeight, childSize.height + childConfig.margin.top + childConfig.margin.bottom); contentWeight += childConfig.weight; @@ -421,6 +441,9 @@ - (void)layout:(CGSize)targetSize { if (child.isHidden) { continue; } + if (!CGAffineTransformEqualToTransform(child.transform, CGAffineTransformIdentity)) { + continue; + } DoricLayoutConfig *childConfig = child.layoutConfig; if (!childConfig) { childConfig = [DoricLayoutConfig new]; diff --git a/iOS/Pod/Classes/Shader/DoricViewNode.m b/iOS/Pod/Classes/Shader/DoricViewNode.m index ce773dbe..3a432cbb 100644 --- a/iOS/Pod/Classes/Shader/DoricViewNode.m +++ b/iOS/Pod/Classes/Shader/DoricViewNode.m @@ -233,7 +233,11 @@ - (NSNumber *)getHeight { } - (void)setRotation:(NSNumber *)rotation { - self.view.transform = CGAffineTransformRotate(self.view.transform, M_PI * rotation.floatValue * 2); + if (rotation.floatValue == 0) { + self.view.transform = CGAffineTransformIdentity; + } else { + self.view.transform = CGAffineTransformMakeRotation(M_PI * rotation.floatValue * 2); + } } - (NSNumber *)getRotation { diff --git a/js-framework/src/ui/refreshable.ts b/js-framework/src/ui/refreshable.ts index 35de57d7..556196e3 100644 --- a/js-framework/src/ui/refreshable.ts +++ b/js-framework/src/ui/refreshable.ts @@ -3,7 +3,6 @@ import { List } from "./list"; import { Scroller } from "./scroller"; import { BridgeContext } from "../runtime/global"; import { layoutConfig } from "./declarative"; -import { Image } from "./widgets"; export interface IRefreshable extends IView { content: List | Scroller