Use the _query() infrastructure for polling
This commit is contained in:
parent
1a5992408b
commit
2c72173bfe
@ -31,11 +31,8 @@ namespace input {
|
|||||||
|
|
||||||
//% fixedInstances
|
//% fixedInstances
|
||||||
export class ColorSensor extends internal.UartSensor {
|
export class ColorSensor extends internal.UartSensor {
|
||||||
polling: boolean;
|
|
||||||
|
|
||||||
constructor(port: number) {
|
constructor(port: number) {
|
||||||
super(port)
|
super(port)
|
||||||
this.polling = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_deviceType() {
|
_deviceType() {
|
||||||
@ -46,15 +43,14 @@ namespace input {
|
|||||||
this._setMode(m)
|
this._setMode(m)
|
||||||
}
|
}
|
||||||
|
|
||||||
_initPolling() {
|
_query() {
|
||||||
if (!this.polling) {
|
if (this.mode == ColorSensorMode.Color)
|
||||||
input.internal.unsafePollForChanges(
|
return this.getNumber(NumberFormat.UInt8LE, 0)
|
||||||
50,
|
return 0
|
||||||
() => this.color(),
|
|
||||||
(prev, curr) => {
|
|
||||||
control.raiseEvent(this._id, curr);
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_update(prev: number, curr: number) {
|
||||||
|
control.raiseEvent(this._id, curr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -70,8 +66,10 @@ namespace input {
|
|||||||
//% weight=100 blockGap=8
|
//% weight=100 blockGap=8
|
||||||
//% group="Color Sensor"
|
//% group="Color Sensor"
|
||||||
onColorDetected(color: ColorSensorColor, handler: () => void) {
|
onColorDetected(color: ColorSensorColor, handler: () => void) {
|
||||||
this._initPolling();
|
|
||||||
control.onEvent(this._id, <number>color, handler);
|
control.onEvent(this._id, <number>color, handler);
|
||||||
|
this.setMode(ColorSensorMode.Color)
|
||||||
|
if (this.color() == color)
|
||||||
|
control.runInBackground(handler)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user