Merge branch 'feature/listview' into 'master'
Feature/listview See merge request !11
This commit is contained in:
commit
16602716f3
@ -51,14 +51,8 @@ public class StackNode extends GroupNode<FrameLayout> {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void blend(FrameLayout view, String name, JSValue prop) {
|
protected void blend(FrameLayout view, String name, JSValue prop) {
|
||||||
switch (name) {
|
|
||||||
case "gravity":
|
|
||||||
view.setForegroundGravity(prop.asNumber().toInt());
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
super.blend(view, name, prop);
|
super.blend(view, name, prop);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected ViewGroup.LayoutParams generateDefaultLayoutParams() {
|
protected ViewGroup.LayoutParams generateDefaultLayoutParams() {
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
package pub.doric.shader;
|
package pub.doric.shader;
|
||||||
|
|
||||||
import android.util.TypedValue;
|
import android.util.TypedValue;
|
||||||
|
import android.view.Gravity;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
import pub.doric.DoricContext;
|
import pub.doric.DoricContext;
|
||||||
@ -52,7 +53,7 @@ public class TextNode extends ViewNode<TextView> {
|
|||||||
view.setTextColor(prop.asNumber().toInt());
|
view.setTextColor(prop.asNumber().toInt());
|
||||||
break;
|
break;
|
||||||
case "textAlignment":
|
case "textAlignment":
|
||||||
view.setGravity(prop.asNumber().toInt());
|
view.setGravity(prop.asNumber().toInt() | Gravity.CENTER_VERTICAL);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
super.blend(view, name, prop);
|
super.blend(view, name, prop);
|
||||||
|
@ -19,6 +19,7 @@ import android.content.Context;
|
|||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.widget.FrameLayout;
|
import android.widget.FrameLayout;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
|
|
||||||
import pub.doric.DoricContext;
|
import pub.doric.DoricContext;
|
||||||
import pub.doric.DoricRegistry;
|
import pub.doric.DoricRegistry;
|
||||||
@ -66,7 +67,7 @@ public abstract class ViewNode<T extends View> extends DoricContextHolder {
|
|||||||
this.mId = id;
|
this.mId = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getType(){
|
public String getType() {
|
||||||
return mType;
|
return mType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,32 +94,30 @@ public abstract class ViewNode<T extends View> extends DoricContextHolder {
|
|||||||
} else {
|
} else {
|
||||||
params = mLayoutParams;
|
params = mLayoutParams;
|
||||||
}
|
}
|
||||||
|
if (mLayoutParams instanceof LinearLayout.LayoutParams && ((LinearLayout.LayoutParams) mLayoutParams).weight > 0) {
|
||||||
|
if (mSuperNode instanceof VLayoutNode) {
|
||||||
|
params.height = ViewGroup.LayoutParams.MATCH_PARENT;
|
||||||
|
} else if (mSuperNode instanceof HLayoutNode) {
|
||||||
|
params.width = ViewGroup.LayoutParams.MATCH_PARENT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
mView.setLayoutParams(params);
|
mView.setLayoutParams(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void blend(T view, String name, JSValue prop) {
|
protected void blend(T view, String name, JSValue prop) {
|
||||||
switch (name) {
|
switch (name) {
|
||||||
case "width":
|
case "width":
|
||||||
if (mLayoutParams.width >= 0) {
|
setWidth(prop.asNumber().toFloat());
|
||||||
mLayoutParams.width = DoricUtils.dp2px(prop.asNumber().toFloat());
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "height":
|
case "height":
|
||||||
if (mLayoutParams.height >= 0) {
|
setHeight(prop.asNumber().toFloat());
|
||||||
mLayoutParams.height = DoricUtils.dp2px(prop.asNumber().toFloat());
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "x":
|
case "x":
|
||||||
if (mLayoutParams instanceof ViewGroup.MarginLayoutParams) {
|
setX(prop.asNumber().toFloat());
|
||||||
float x = prop.asNumber().toFloat();
|
|
||||||
((ViewGroup.MarginLayoutParams) mLayoutParams).leftMargin = DoricUtils.dp2px(x);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "y":
|
case "y":
|
||||||
if (mLayoutParams instanceof ViewGroup.MarginLayoutParams) {
|
setY(prop.asNumber().toFloat());
|
||||||
float y = prop.asNumber().toFloat();
|
|
||||||
((ViewGroup.MarginLayoutParams) mLayoutParams).topMargin = DoricUtils.dp2px(y);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "bgColor":
|
case "bgColor":
|
||||||
view.setBackgroundColor(prop.asNumber().toInt());
|
view.setBackgroundColor(prop.asNumber().toInt());
|
||||||
@ -133,9 +132,7 @@ public abstract class ViewNode<T extends View> extends DoricContextHolder {
|
|||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case "layoutConfig":
|
case "layoutConfig":
|
||||||
if (prop.isObject() && mSuperNode != null) {
|
setLayoutConfig(prop.asObject());
|
||||||
mSuperNode.blendSubLayoutConfig(this, prop.asObject());
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case "border":
|
case "border":
|
||||||
if (prop.isObject() && doricLayer != null) {
|
if (prop.isObject() && doricLayer != null) {
|
||||||
@ -216,4 +213,34 @@ public abstract class ViewNode<T extends View> extends DoricContextHolder {
|
|||||||
public String getId() {
|
public String getId() {
|
||||||
return mId;
|
return mId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void setWidth(float width) {
|
||||||
|
if (mLayoutParams.width >= 0) {
|
||||||
|
mLayoutParams.width = DoricUtils.dp2px(width);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setHeight(float height) {
|
||||||
|
if (mLayoutParams.height >= 0) {
|
||||||
|
mLayoutParams.height = DoricUtils.dp2px(height);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setX(float x) {
|
||||||
|
if (mLayoutParams instanceof ViewGroup.MarginLayoutParams) {
|
||||||
|
((ViewGroup.MarginLayoutParams) mLayoutParams).leftMargin = DoricUtils.dp2px(x);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setY(float y) {
|
||||||
|
if (mLayoutParams instanceof ViewGroup.MarginLayoutParams) {
|
||||||
|
((ViewGroup.MarginLayoutParams) mLayoutParams).topMargin = DoricUtils.dp2px(y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setLayoutConfig(JSObject layoutConfig) {
|
||||||
|
if (mSuperNode != null) {
|
||||||
|
mSuperNode.blendSubLayoutConfig(this, layoutConfig);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@ package pub.doric.shader.list;
|
|||||||
|
|
||||||
import android.widget.FrameLayout;
|
import android.widget.FrameLayout;
|
||||||
|
|
||||||
|
import com.github.pengfeizhou.jscore.JSObject;
|
||||||
import com.github.pengfeizhou.jscore.JSValue;
|
import com.github.pengfeizhou.jscore.JSValue;
|
||||||
|
|
||||||
import pub.doric.DoricContext;
|
import pub.doric.DoricContext;
|
||||||
@ -45,4 +46,11 @@ public class ListItemNode extends StackNode {
|
|||||||
super.blend(view, name, prop);
|
super.blend(view, name, prop);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void blend(JSObject jsObject) {
|
||||||
|
super.blend(jsObject);
|
||||||
|
getDoricLayer().getLayoutParams().width = getLayoutParams().width;
|
||||||
|
getDoricLayer().getLayoutParams().height = getLayoutParams().height;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout } from "doric";
|
import { Group, Panel, List, text, gravity, Color, Stack, LayoutSpec, list, NativeCall, listItem, log, vlayout, Gravity, hlayout } from "doric";
|
||||||
const colors = [
|
const colors = [
|
||||||
"#f0932b",
|
"#f0932b",
|
||||||
"#eb4d4b",
|
"#eb4d4b",
|
||||||
@ -26,23 +26,44 @@ class ListPanel extends Panel {
|
|||||||
list({
|
list({
|
||||||
itemCount: 1000,
|
itemCount: 1000,
|
||||||
renderItem: (idx: number) => {
|
renderItem: (idx: number) => {
|
||||||
return listItem(text({
|
return listItem(
|
||||||
|
hlayout([
|
||||||
|
text({
|
||||||
layoutConfig: {
|
layoutConfig: {
|
||||||
widthSpec: LayoutSpec.AT_MOST,
|
widthSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
heightSpec: LayoutSpec.WRAP_CONTENT,
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
margin: {
|
alignment: gravity().center(),
|
||||||
left: 10,
|
|
||||||
right: 50,
|
|
||||||
top: 50,
|
|
||||||
bottom: 10,
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
text: `Cell At Line ${idx}`,
|
text: `Cell At Line ${idx}`,
|
||||||
textAlignment: gravity().center(),
|
textAlignment: gravity().center(),
|
||||||
textColor: Color.parse("#ffffff"),
|
textColor: Color.parse("#ffffff"),
|
||||||
textSize: 20,
|
textSize: 20,
|
||||||
})).also(it => {
|
height: 50,
|
||||||
it.gravity = gravity().center()
|
bgColor: Color.parse('#00ff00'),
|
||||||
|
}),
|
||||||
|
text({
|
||||||
|
layoutConfig: {
|
||||||
|
widthSpec: LayoutSpec.EXACTLY,
|
||||||
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
|
alignment: gravity().center(),
|
||||||
|
weight: 1,
|
||||||
|
},
|
||||||
|
text: `Right`,
|
||||||
|
textAlignment: gravity().right(),
|
||||||
|
textColor: Color.parse("#ffffff"),
|
||||||
|
textSize: 20,
|
||||||
|
height: 50,
|
||||||
|
bgColor: Color.parse('#00ffff'),
|
||||||
|
}),
|
||||||
|
]).also(it => {
|
||||||
|
it.layoutConfig = {
|
||||||
|
widthSpec: LayoutSpec.AT_MOST,
|
||||||
|
heightSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
|
alignment: gravity().center(),
|
||||||
|
}
|
||||||
|
it.bgColor = Color.parse('#ffffff')
|
||||||
|
})
|
||||||
|
).also(it => {
|
||||||
it.bgColor = Color.parse(colors[idx % colors.length])
|
it.bgColor = Color.parse(colors[idx % colors.length])
|
||||||
it.layoutConfig = {
|
it.layoutConfig = {
|
||||||
widthSpec: LayoutSpec.AT_MOST,
|
widthSpec: LayoutSpec.AT_MOST,
|
||||||
@ -51,8 +72,7 @@ class ListPanel extends Panel {
|
|||||||
it.height = 100
|
it.height = 100
|
||||||
it.onClick = () => {
|
it.onClick = () => {
|
||||||
log(`Click item at ${idx}`)
|
log(`Click item at ${idx}`)
|
||||||
it.bgColor = Color.parse('#000000')
|
it.height += 10
|
||||||
log(`bgcolor is ${Color.parse('#000000').toModel()}`)
|
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
@ -189,6 +189,10 @@ class SnakeView extends ViewHolder<SnakeModel> {
|
|||||||
textSize: 30,
|
textSize: 30,
|
||||||
textAlignment: new Gravity().center(),
|
textAlignment: new Gravity().center(),
|
||||||
bgColor: Color.parse('#ffff00'),
|
bgColor: Color.parse('#ffff00'),
|
||||||
|
layoutConfig: {
|
||||||
|
widthSpec: LayoutSpec.EXACTLY,
|
||||||
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
|
},
|
||||||
}).also(it => this.up = it)
|
}).also(it => this.up = it)
|
||||||
]).also(it => {
|
]).also(it => {
|
||||||
it.layoutConfig = {
|
it.layoutConfig = {
|
||||||
@ -204,6 +208,10 @@ class SnakeView extends ViewHolder<SnakeModel> {
|
|||||||
textSize: 30,
|
textSize: 30,
|
||||||
textAlignment: new Gravity().center(),
|
textAlignment: new Gravity().center(),
|
||||||
bgColor: Color.parse('#ffff00'),
|
bgColor: Color.parse('#ffff00'),
|
||||||
|
layoutConfig: {
|
||||||
|
widthSpec: LayoutSpec.EXACTLY,
|
||||||
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
|
},
|
||||||
}).also(it => this.left = it),
|
}).also(it => this.left = it),
|
||||||
text({
|
text({
|
||||||
width: 50,
|
width: 50,
|
||||||
@ -212,6 +220,10 @@ class SnakeView extends ViewHolder<SnakeModel> {
|
|||||||
textSize: 30,
|
textSize: 30,
|
||||||
textAlignment: new Gravity().center(),
|
textAlignment: new Gravity().center(),
|
||||||
bgColor: Color.parse('#ffff00'),
|
bgColor: Color.parse('#ffff00'),
|
||||||
|
layoutConfig: {
|
||||||
|
widthSpec: LayoutSpec.EXACTLY,
|
||||||
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
|
},
|
||||||
}).also(it => this.down = it),
|
}).also(it => this.down = it),
|
||||||
text({
|
text({
|
||||||
width: 50,
|
width: 50,
|
||||||
@ -220,6 +232,10 @@ class SnakeView extends ViewHolder<SnakeModel> {
|
|||||||
textSize: 30,
|
textSize: 30,
|
||||||
textAlignment: new Gravity().center(),
|
textAlignment: new Gravity().center(),
|
||||||
bgColor: Color.parse('#ffff00'),
|
bgColor: Color.parse('#ffff00'),
|
||||||
|
layoutConfig: {
|
||||||
|
widthSpec: LayoutSpec.EXACTLY,
|
||||||
|
heightSpec: LayoutSpec.EXACTLY,
|
||||||
|
},
|
||||||
}).also(it => this.right = it),
|
}).also(it => this.right = it),
|
||||||
]).also(it => {
|
]).also(it => {
|
||||||
it.layoutConfig = {
|
it.layoutConfig = {
|
||||||
@ -248,16 +264,6 @@ class SnakeView extends ViewHolder<SnakeModel> {
|
|||||||
}).in(root)
|
}).in(root)
|
||||||
}
|
}
|
||||||
|
|
||||||
buildController(text: string) {
|
|
||||||
const ret = new Text
|
|
||||||
ret.width = ret.height = 50
|
|
||||||
ret.bgColor = Color.parse('#ffff00')
|
|
||||||
ret.text = text
|
|
||||||
ret.textSize = 30
|
|
||||||
ret.textAlignment = new Gravity().center()
|
|
||||||
return ret
|
|
||||||
}
|
|
||||||
|
|
||||||
bind(state: SnakeModel): void {
|
bind(state: SnakeModel): void {
|
||||||
log('build', state)
|
log('build', state)
|
||||||
this.panel.width = state.width * 10
|
this.panel.width = state.width * 10
|
||||||
|
@ -530,23 +530,3 @@ - (UIView *)viewWithTagString:(NSString *)tagString {
|
|||||||
layout.layoutConfig = [[DoricLayoutConfig alloc] initWithWidth:DoricLayoutWrapContent height:DoricLayoutWrapContent];
|
layout.layoutConfig = [[DoricLayoutConfig alloc] initWithWidth:DoricLayoutWrapContent height:DoricLayoutWrapContent];
|
||||||
return layout;
|
return layout;
|
||||||
}
|
}
|
||||||
|
|
||||||
DoricVLayoutView *vLayoutWithBlock(NSArray <UIView *(^)()> *blocks) {
|
|
||||||
DoricVLayoutView *layout = [[DoricVLayoutView alloc] initWithFrame:CGRectZero];
|
|
||||||
UIView *(^block)();
|
|
||||||
for (block in blocks) {
|
|
||||||
[layout addSubview:block()];
|
|
||||||
}
|
|
||||||
layout.layoutConfig = [[DoricLayoutConfig alloc] initWithWidth:DoricLayoutWrapContent height:DoricLayoutWrapContent];
|
|
||||||
return layout;
|
|
||||||
}
|
|
||||||
|
|
||||||
DoricHLayoutView *hLayoutWithBlock(NSArray <UIView *(^)()> *blocks) {
|
|
||||||
DoricHLayoutView *layout = [[DoricHLayoutView alloc] initWithFrame:CGRectZero];
|
|
||||||
UIView *(^block)();
|
|
||||||
for (block in blocks) {
|
|
||||||
[layout addSubview:block()];
|
|
||||||
}
|
|
||||||
layout.layoutConfig = [[DoricLayoutConfig alloc] initWithWidth:DoricLayoutWrapContent height:DoricLayoutWrapContent];
|
|
||||||
return layout;
|
|
||||||
}
|
|
||||||
|
@ -29,10 +29,6 @@ - (DoricStackView *)build {
|
|||||||
}
|
}
|
||||||
|
|
||||||
- (void)blendView:(DoricStackView *)view forPropName:(NSString *)name propValue:(id)prop {
|
- (void)blendView:(DoricStackView *)view forPropName:(NSString *)name propValue:(id)prop {
|
||||||
if ([name isEqualToString:@"gravity"]) {
|
|
||||||
view.gravity = (DoricGravity) [(NSNumber *) prop integerValue];
|
|
||||||
} else {
|
|
||||||
[super blendView:view forPropName:name propValue:prop];
|
[super blendView:view forPropName:name propValue:prop];
|
||||||
}
|
|
||||||
}
|
}
|
||||||
@end
|
@end
|
||||||
|
@ -93,7 +93,10 @@ - (void)blendSubNode:(DoricViewNode *)subNode layoutConfig:(NSDictionary *)layou
|
|||||||
if (alignment) {
|
if (alignment) {
|
||||||
params.alignment = (DoricGravity) [alignment integerValue];
|
params.alignment = (DoricGravity) [alignment integerValue];
|
||||||
}
|
}
|
||||||
|
NSNumber *weight = layoutConfig[@"weight"];
|
||||||
|
if (weight) {
|
||||||
|
params.weight = (DoricGravity) [weight integerValue];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)blendSubNode:(NSDictionary *)subModel {
|
- (void)blendSubNode:(NSDictionary *)subModel {
|
||||||
|
@ -39,15 +39,10 @@ - (void)blendView:(UILabel *)view forPropName:(NSString *)name propValue:(id)pro
|
|||||||
} else if ([name isEqualToString:@"textAlignment"]) {
|
} else if ([name isEqualToString:@"textAlignment"]) {
|
||||||
DoricGravity gravity = (DoricGravity) [(NSNumber *) prop integerValue];
|
DoricGravity gravity = (DoricGravity) [(NSNumber *) prop integerValue];
|
||||||
NSTextAlignment alignment = NSTextAlignmentCenter;
|
NSTextAlignment alignment = NSTextAlignmentCenter;
|
||||||
switch (gravity) {
|
if ((gravity & LEFT) == LEFT) {
|
||||||
case LEFT:
|
|
||||||
alignment = NSTextAlignmentLeft;
|
alignment = NSTextAlignmentLeft;
|
||||||
break;
|
} else if ((gravity & RIGHT) == RIGHT) {
|
||||||
case RIGHT:
|
|
||||||
alignment = NSTextAlignmentRight;
|
alignment = NSTextAlignmentRight;
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
view.textAlignment = alignment;
|
view.textAlignment = alignment;
|
||||||
} else {
|
} else {
|
||||||
|
@ -20,6 +20,10 @@ import { IList, List } from './listview'
|
|||||||
|
|
||||||
export function text(config: IText) {
|
export function text(config: IText) {
|
||||||
const ret = new Text
|
const ret = new Text
|
||||||
|
ret.layoutConfig = {
|
||||||
|
widthSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
|
heightSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
|
}
|
||||||
for (let key in config) {
|
for (let key in config) {
|
||||||
Reflect.set(ret, key, Reflect.get(config, key, config), ret)
|
Reflect.set(ret, key, Reflect.get(config, key, config), ret)
|
||||||
}
|
}
|
||||||
@ -28,6 +32,10 @@ export function text(config: IText) {
|
|||||||
|
|
||||||
export function image(config: IImage) {
|
export function image(config: IImage) {
|
||||||
const ret = new Image
|
const ret = new Image
|
||||||
|
ret.layoutConfig = {
|
||||||
|
widthSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
|
heightSpec: LayoutSpec.WRAP_CONTENT,
|
||||||
|
}
|
||||||
for (let key in config) {
|
for (let key in config) {
|
||||||
Reflect.set(ret, key, Reflect.get(config, key, config), ret)
|
Reflect.set(ret, key, Reflect.get(config, key, config), ret)
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,9 @@ import { LayoutConfig, Group, Property, IView } from "./view";
|
|||||||
import { Gravity } from "../util/gravity";
|
import { Gravity } from "../util/gravity";
|
||||||
|
|
||||||
export interface IStack extends IView {
|
export interface IStack extends IView {
|
||||||
gravity?: Gravity
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Stack extends Group implements IStack {
|
export class Stack extends Group implements IStack {
|
||||||
@Property
|
|
||||||
gravity?: Gravity
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user