import { text, vlayout, Image, ViewHolder, VMPanel, ViewModel, Gravity, NativeCall, Text, Color, log, logw, loge, Group, LayoutSpec, } from "doric" interface CountModel { count: number } class CounterView extends ViewHolder { number!: Text counter!: Text build(root: Group) { root.addChild(vlayout([ text({ textSize: 40, layoutConfig: { alignment: Gravity.Center, widthSpec: LayoutSpec.WRAP_CONTENT, heightSpec: LayoutSpec.WRAP_CONTENT, }, }).also(it => { this.number = it }), text({ text: "点击计数", textSize: 20, border: { width: 1, color: Color.parse('#000000'), }, corners: 5, layoutConfig: { alignment: Gravity.Center, widthSpec: LayoutSpec.WRAP_CONTENT, heightSpec: LayoutSpec.WRAP_CONTENT, }, padding: { left: 10, right: 10, top: 10, bottom: 10, }, shadow: { color: Color.parse("#00ff00"), opacity: 0.5, radius: 20, offsetX: 10, offsetY: 10, } }).also(it => { this.counter = it }), ]).also(it => { it.width = 200 it.height = 200 it.space = 20 it.gravity = Gravity.Center it.layoutConfig = { alignment: Gravity.Center } it.border = { width: 1, color: Color.parse("#000000"), } it.shadow = { color: Color.parse("#ffff00"), opacity: 0.5, radius: 20, offsetX: 10, offsetY: 10, } it.corners = 20 it.backgroundColor = Color.parse('#ff00ff') })) root.addChild((new Image).also(iv => { iv.imageUrl = "https://misc.aotu.io/ONE-SUNDAY/SteamEngine.png" iv.layoutConfig = { widthSpec: LayoutSpec.WRAP_CONTENT, heightSpec: LayoutSpec.WRAP_CONTENT, } })) } bind(state: CountModel) { this.number.text = `${state.count}` } setCounter(v: Function) { this.counter.onClick = v } } class CounterVM extends ViewModel { onAttached(s: CountModel, vh: CounterView): void { vh.counter.onClick = () => { this.updateState(state => { state.count++ }) } } } @Entry class MyPage extends VMPanel{ getViewHolderClass() { return CounterView } getViewModelClass() { return CounterVM } getState(): CountModel { return { count: 0 } } @NativeCall log() { log("Hello.HEGO") logw("Hello.HEGO") loge("Hello.HEGO") context.modal.toast('This is a toast.').then((r) => { loge(r) }) } }