feat:blendProps for Cooridinate changes

This commit is contained in:
pengfei.zhou 2020-03-11 11:30:49 +08:00 committed by osborn
parent 1f5fd7de30
commit 348a6f3e56
7 changed files with 29 additions and 37 deletions

View File

@ -18,6 +18,7 @@ package pub.doric.plugin;
import android.graphics.Color; import android.graphics.Color;
import android.view.View; import android.view.View;
import com.github.pengfeizhou.jscore.JSNumber;
import com.github.pengfeizhou.jscore.JSObject; import com.github.pengfeizhou.jscore.JSObject;
import com.github.pengfeizhou.jscore.JSValue; import com.github.pengfeizhou.jscore.JSValue;
@ -163,21 +164,13 @@ public class CoordinatorPlugin extends DoricJavaPlugin {
} }
private void setValue(ViewNode viewNode, boolean isNavBar, String name, float value) { private void setValue(ViewNode viewNode, boolean isNavBar, String name, float value) {
if ("backgroundColor".equals(name)) { if ("backgroundColor".equals(name) && isNavBar) {
if (isNavBar) {
getDoricContext().getDoricNavBar().setBackgroundColor((int) value); getDoricContext().getDoricNavBar().setBackgroundColor((int) value);
} else { } else {
viewNode.setBackgroundColor((int) value); JSNumber jsNumber = new JSNumber(value);
JSObject jsObject = new JSObject();
jsObject.setProperty(name, jsNumber);
viewNode.blend(jsObject);
} }
} else if ("width".equals(name)) {
viewNode.setWidth(value);
} else if ("height".equals(name)) {
viewNode.setHeight(value);
} else if ("x".equals(name)) {
viewNode.setX(value);
} else if ("y".equals(name)) {
viewNode.setY(value);
}
} }
} }

View File

@ -92,6 +92,7 @@ - (void)verticalScrolling:(NSDictionary *)params withPromise:(DoricPromise *)pro
green:startG + (endG - startG) * rate green:startG + (endG - startG) * rate
blue:startB + (endB - startB) * rate blue:startB + (endB - startB) * rate
alpha:startA + (endA - startA) * rate]; alpha:startA + (endA - startA) * rate];
value = DoricColorToNumber(value);
} else { } else {
value = @([changingStart floatValue] + ([changingEnd floatValue] - [changingStart floatValue]) * rate); value = @([changingStart floatValue] + ([changingEnd floatValue] - [changingStart floatValue]) * rate);
} }
@ -105,23 +106,10 @@ - (void)verticalScrolling:(NSDictionary *)params withPromise:(DoricPromise *)pro
} }
- (void)setValue:(DoricViewNode *)viewNode isNavBar:(BOOL)isNavBar name:(NSString *)name value:(id)value { - (void)setValue:(DoricViewNode *)viewNode isNavBar:(BOOL)isNavBar name:(NSString *)name value:(id)value {
if ([@"backgroundColor" isEqualToString:name]) { if ([@"backgroundColor" isEqualToString:name] && isNavBar) {
if ([value isKindOfClass:[NSNumber class]]) { [self.doricContext.navBar doric_navBar_setBackgroundColor:DoricColor(value)];
value = DoricColor(value);
}
if (isNavBar) {
[self.doricContext.navBar doric_navBar_setBackgroundColor:value];
} else { } else {
viewNode.view.backgroundColor = value; [viewNode blend:@{name: value}];
}
} else if ([@"width" isEqualToString:name]) {
viewNode.view.width = [value floatValue];
} else if ([@"height" isEqualToString:name]) {
viewNode.view.height = [value floatValue];
} else if ([@"x" isEqualToString:name]) {
viewNode.view.left = [value floatValue];
} else if ([@"y" isEqualToString:name]) {
viewNode.view.top = [value floatValue];
} }
} }

View File

@ -27,6 +27,8 @@ void DoricLog(NSString *_Nonnull format, ...);
UIColor *_Nonnull DoricColor(NSNumber *_Nonnull number); UIColor *_Nonnull DoricColor(NSNumber *_Nonnull number);
NSNumber *_Nonnull DoricColorToNumber(UIColor *_Nonnull color);
NSBundle *_Nonnull DoricBundle(void); NSBundle *_Nonnull DoricBundle(void);
#ifndef DC_LOCK #ifndef DC_LOCK
@ -39,4 +41,4 @@ NSBundle *_Nonnull DoricBundle(void);
void ShowToast(NSString *_Nonnull text, DoricGravity gravity); void ShowToast(NSString *_Nonnull text, DoricGravity gravity);
UIImage *_Nonnull UIImageWithColor(UIColor * _Nonnull color); UIImage *_Nonnull UIImageWithColor(UIColor *_Nonnull color);

View File

@ -41,6 +41,15 @@ void DoricLog(NSString *_Nonnull format, ...) {
return [UIColor colorWithRed:r green:g blue:b alpha:a]; return [UIColor colorWithRed:r green:g blue:b alpha:a];
} }
NSNumber *DoricColorToNumber(UIColor *color) {
CGFloat r, g, b, a;
[color getRed:&r green:&g blue:&b alpha:&a];
return @((((long) (a * 225) & 0xff) << 24)
| (((long) (r * 225) & 0xff) << 16)
| (((long) (g * 225) & 0xff) << 8)
| (((long) (b * 225) & 0xff) << 0));
}
NSBundle *DoricBundle() { NSBundle *DoricBundle() {
NSBundle *bundle = [NSBundle bundleForClass:[DoricContext class]]; NSBundle *bundle = [NSBundle bundleForClass:[DoricContext class]];
NSURL *url = [bundle URLForResource:@"Doric" withExtension:@"bundle"]; NSURL *url = [bundle URLForResource:@"Doric" withExtension:@"bundle"];

2
doric-js/index.d.ts vendored
View File

@ -929,7 +929,7 @@ declare module 'doric/lib/src/native/coordinator' {
}; };
target: View | "NavBar"; target: View | "NavBar";
changing: { changing: {
name: "width" | "height" | "x" | "y" | "backgroundColor"; name: "width" | "height" | "x" | "y" | "backgroundColor" | "alpha";
start: number | Color; start: number | Color;
end: number | Color; end: number | Color;
}; };

View File

@ -13,7 +13,7 @@ export declare function coordinator(context: BridgeContext): {
}; };
target: View | "NavBar"; target: View | "NavBar";
changing: { changing: {
name: "width" | "height" | "x" | "y" | "backgroundColor"; name: "width" | "height" | "x" | "y" | "backgroundColor" | "alpha";
start: number | Color; start: number | Color;
end: number | Color; end: number | Color;
}; };

View File

@ -42,7 +42,7 @@ export function coordinator(context: BridgeContext) {
}, },
target: View | "NavBar", target: View | "NavBar",
changing: { changing: {
name: "backgroundColor" | "width" | "height" | "x" | "y", name: "backgroundColor" | "width" | "height" | "x" | "y" | "alpha",
start: number | Color start: number | Color
end: number | Color end: number | Color
}, },