Skip to main content
版本:v1.0

CALORIE

创建传感器

const calorie = hmSensor.createSensor(hmSensor.id.CALORIE)

calorie 实例

calorie: object

属性说明类型
current当前消耗卡路里,单位 kcalnumber
target目标消耗卡路里,单位 kcalnumber

注册传感器实例回调事件

calorie.addEventListener(event, callback: Callback)

CHANGE 事件

event 值

hmSensor.event.CHANGE

Callback

() => void

完整示例

class TextByLine {
constructor(params) {
const { text = '', y = undefined, line = 0 } = params

this.text = text
this.y = y
this.line = line
this.y_computed = Number.isInteger(this.y) ? this.y : px(this.line * 60 + 120)
}

render() {
return hmUI.createWidget(hmUI.widget.TEXT, {
x: px(0),
y: this.y_computed,
w: px(480),
h: px(46),
color: 0xffffff,
text_size: px(20),
align_h: hmUI.align.CENTER_H,
align_v: hmUI.align.CENTER_V,
text_style: hmUI.text_style.NONE,
text: this.text
})
}
}

Page({
build() {
const calorie = hmSensor.createSensor(hmSensor.id.CALORIE)

const currentText = new TextByLine({
text: `current:${calorie.current};target:${calorie.target}`,
line: 0
}).render()

const changeEventText = new TextByLine({
text: `EVENT-CHANGE:${calorie.current}`,
line: 1
}).render()

const changeCallback = () => {
const current = calorie.current

changeEventText.setProperty(hmUI.prop.MORE, {
text: `EVENT-CHANGE: ${current}`
})
}

const calorieChangeListener = () => {
calorie.addEventListener(hmSensor.event.CHANGE, changeCallback)
}

hmUI.createWidget(hmUI.widget.BUTTON, {
x: px(80),
y: px(300),
w: px(300),
h: px(60),
radius: px(12),
normal_color: 0xfc6950,
press_color: 0xfeb4a8,
text: 'REGISTER_CHANGE',
click_func: calorieChangeListener
})
}
})