Compare commits
	
		
			9 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 5344717749 | ||
|  | 1bbf8a4473 | ||
|  | f1d9075c9d | ||
|  | cffbdb9eae | ||
|  | cc75ae57da | ||
|  | 068300c5f5 | ||
|  | 251f198441 | ||
|  | fe39902d10 | ||
|  | 030cd46c5f | 
| @@ -59,9 +59,9 @@ namespace sensors { | |||||||
|  |  | ||||||
|         constructor(port: number) { |         constructor(port: number) { | ||||||
|             super(port) |             super(port) | ||||||
|             this._setMode(ColorSensorMode.None); |  | ||||||
|             this.thresholdDetector = new sensors.ThresholdDetector(this.id()); |             this.thresholdDetector = new sensors.ThresholdDetector(this.id()); | ||||||
|             this.calibrating = false; |             this.calibrating = false; | ||||||
|  |             this.setMode(ColorSensorMode.ReflectedLightIntensity); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         _colorEventValue(value: number) { |         _colorEventValue(value: number) { | ||||||
| @@ -176,8 +176,8 @@ namespace sensors { | |||||||
|         //% group="Color Sensor" |         //% group="Color Sensor" | ||||||
|         //% blockGap=8 |         //% blockGap=8 | ||||||
|         color(): ColorSensorColor { |         color(): ColorSensorColor { | ||||||
|             this.poke(); |  | ||||||
|             this.setMode(ColorSensorMode.Color) |             this.setMode(ColorSensorMode.Color) | ||||||
|  |             this.poke(); | ||||||
|             return this.getNumber(NumberFormat.UInt8LE, 0) |             return this.getNumber(NumberFormat.UInt8LE, 0) | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -194,8 +194,8 @@ namespace sensors { | |||||||
|         //% group="Color Sensor" |         //% group="Color Sensor" | ||||||
|         //% blockGap=8 |         //% blockGap=8 | ||||||
|         rgbRaw(): number[] { |         rgbRaw(): number[] { | ||||||
|             this.poke(); |  | ||||||
|             this.setMode(ColorSensorMode.RgbRaw); |             this.setMode(ColorSensorMode.RgbRaw); | ||||||
|  |             this.poke(); | ||||||
|             return [this.getNumber(NumberFormat.UInt16LE, 0), this.getNumber(NumberFormat.UInt16LE, 2), this.getNumber(NumberFormat.UInt16LE, 4)]; |             return [this.getNumber(NumberFormat.UInt16LE, 0), this.getNumber(NumberFormat.UInt16LE, 2), this.getNumber(NumberFormat.UInt16LE, 4)]; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -248,8 +248,8 @@ namespace sensors { | |||||||
|         //% weight=87 blockGap=8 |         //% weight=87 blockGap=8 | ||||||
|         //% group="Color Sensor" |         //% group="Color Sensor" | ||||||
|         light(mode: LightIntensityMode) { |         light(mode: LightIntensityMode) { | ||||||
|             this.poke(); |  | ||||||
|             this.setMode(<ColorSensorMode><number>mode) |             this.setMode(<ColorSensorMode><number>mode) | ||||||
|  |             this.poke(); | ||||||
|             switch (mode) { |             switch (mode) { | ||||||
|                 case LightIntensityMode.ReflectedRaw: |                 case LightIntensityMode.ReflectedRaw: | ||||||
|                     return this.reflectedLightRaw(); |                     return this.reflectedLightRaw(); | ||||||
| @@ -279,8 +279,8 @@ namespace sensors { | |||||||
|          */ |          */ | ||||||
|         //% |         //% | ||||||
|         reflectedLightRaw(): number { |         reflectedLightRaw(): number { | ||||||
|             this.poke(); |  | ||||||
|             this.setMode(ColorSensorMode.RefRaw); |             this.setMode(ColorSensorMode.RefRaw); | ||||||
|  |             this.poke(); | ||||||
|             return this.getNumber(NumberFormat.UInt16LE, 0); |             return this.getNumber(NumberFormat.UInt16LE, 0); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								libs/core/dal.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								libs/core/dal.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -309,6 +309,8 @@ declare const enum DAL { | |||||||
|     DEVICE_TYPE_NXT_LIGHT = 2, |     DEVICE_TYPE_NXT_LIGHT = 2, | ||||||
|     DEVICE_TYPE_NXT_SOUND = 3, |     DEVICE_TYPE_NXT_SOUND = 3, | ||||||
|     DEVICE_TYPE_NXT_COLOR = 4, |     DEVICE_TYPE_NXT_COLOR = 4, | ||||||
|  |     DEVICE_TYPE_NXT_ULTRASONIC = 5, | ||||||
|  |     DEVICE_TYPE_NXT_TEMPERATURE = 6, | ||||||
|     DEVICE_TYPE_TACHO = 7, |     DEVICE_TYPE_TACHO = 7, | ||||||
|     DEVICE_TYPE_MINITACHO = 8, |     DEVICE_TYPE_MINITACHO = 8, | ||||||
|     DEVICE_TYPE_NEWTACHO = 9, |     DEVICE_TYPE_NEWTACHO = 9, | ||||||
|   | |||||||
| @@ -11,6 +11,8 @@ | |||||||
| #define DEVICE_TYPE_NXT_LIGHT 2 | #define DEVICE_TYPE_NXT_LIGHT 2 | ||||||
| #define DEVICE_TYPE_NXT_SOUND 3 | #define DEVICE_TYPE_NXT_SOUND 3 | ||||||
| #define DEVICE_TYPE_NXT_COLOR 4 | #define DEVICE_TYPE_NXT_COLOR 4 | ||||||
|  | #define DEVICE_TYPE_NXT_ULTRASONIC 5 | ||||||
|  | #define DEVICE_TYPE_NXT_TEMPERATURE 6 | ||||||
| #define DEVICE_TYPE_TACHO 7 | #define DEVICE_TYPE_TACHO 7 | ||||||
| #define DEVICE_TYPE_MINITACHO 8 | #define DEVICE_TYPE_MINITACHO 8 | ||||||
| #define DEVICE_TYPE_NEWTACHO 9 | #define DEVICE_TYPE_NEWTACHO 9 | ||||||
|   | |||||||
| @@ -82,7 +82,7 @@ namespace sensors.internal { | |||||||
|         poller: Poller; |         poller: Poller; | ||||||
|  |  | ||||||
|         constructor(p: number) { |         constructor(p: number) { | ||||||
|             this.port = p |             this.port = p; // 0-based | ||||||
|             this.connType = DAL.CONN_NONE |             this.connType = DAL.CONN_NONE | ||||||
|             this.devType = DAL.DEVICE_TYPE_NONE |             this.devType = DAL.DEVICE_TYPE_NONE | ||||||
|             this.iicid = '' |             this.iicid = '' | ||||||
| @@ -121,7 +121,7 @@ namespace sensors.internal { | |||||||
|  |  | ||||||
|         powerMM = control.mmap("/dev/lms_power", 2, 0) |         powerMM = control.mmap("/dev/lms_power", 2, 0) | ||||||
|  |  | ||||||
|         devPoller = new Poller(250, () => { return hashDevices(); }, |         devPoller = new Poller(500, () => { return hashDevices(); }, | ||||||
|             (prev, curr) => { |             (prev, curr) => { | ||||||
|                 detectDevices(); |                 detectDevices(); | ||||||
|             }); |             }); | ||||||
| @@ -279,42 +279,61 @@ void      cUiUpdatePower(void) | |||||||
|         for (let i = 0; i < conns.length; ++i) { |         for (let i = 0; i < conns.length; ++i) { | ||||||
|             r = (r << 8 | conns[i]); |             r = (r << 8 | conns[i]); | ||||||
|         } |         } | ||||||
|  |         //control.dmesg(`devices hash: ${r}`); | ||||||
|         return r; |         return r; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     let nonActivated = 0; |     let nonActivated = 0; | ||||||
|     function detectDevices() { |     function detectDevices() { | ||||||
|         //control.dmesg(`detect devices (${nonActivated} na)`) |         control.dmesg(`detect devices (${nonActivated} na)`) | ||||||
|         const conns = analogMM.slice(AnalogOff.InConn, DAL.NUM_INPUTS) |         const inDcm = analogMM.slice(AnalogOff.InDcm, DAL.NUM_INPUTS) | ||||||
|  |         const inConn = analogMM.slice(AnalogOff.InConn, DAL.NUM_INPUTS) | ||||||
|         let numChanged = 0; |         let numChanged = 0; | ||||||
|         const uartSensors: SensorInfo[] = []; |         const uartSensors: SensorInfo[] = []; | ||||||
|  |  | ||||||
|         for (const sensorInfo of sensorInfos) { |         for (const sensorInfo of sensorInfos) { | ||||||
|             const newConn = conns[sensorInfo.port] |             const newConn = inConn[sensorInfo.port] | ||||||
|             if (newConn == sensorInfo.connType) { |             if (newConn == sensorInfo.connType) { | ||||||
|                 // control.dmesg(`connection unchanged ${newConn} at ${sensorInfo.port}`) |                 // control.dmesg(`connection unchanged ${newConn} at ${sensorInfo.port}`) | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             numChanged++ |             numChanged++ | ||||||
|             sensorInfo.connType = newConn |             sensorInfo.connType = newConn | ||||||
|             sensorInfo.devType = DAL.DEVICE_TYPE_NONE |             sensorInfo.devType = DAL.DEVICE_TYPE_NONE; | ||||||
|             if (newConn == DAL.CONN_INPUT_UART) { |             switch (newConn) { | ||||||
|  |                 case DAL.CONN_INPUT_UART: { | ||||||
|                     control.dmesg(`new UART connection at ${sensorInfo.port}`) |                     control.dmesg(`new UART connection at ${sensorInfo.port}`) | ||||||
|                     updateUartMode(sensorInfo.port, 0); |                     updateUartMode(sensorInfo.port, 0); | ||||||
|                     uartSensors.push(sensorInfo); |                     uartSensors.push(sensorInfo); | ||||||
|             } else if (newConn == DAL.CONN_NXT_IIC) { |                     break; | ||||||
|                 control.dmesg(`new IIC connection at ${sensorInfo.port}`) |                 } | ||||||
|  |                 case DAL.CONN_NXT_IIC: { | ||||||
|  |                     control.dmesg(`new NXT IIC connection at ${sensorInfo.port}`) | ||||||
|                     sensorInfo.devType = DAL.DEVICE_TYPE_IIC_UNKNOWN |                     sensorInfo.devType = DAL.DEVICE_TYPE_IIC_UNKNOWN | ||||||
|                     sensorInfo.iicid = readIICID(sensorInfo.port) |                     sensorInfo.iicid = readIICID(sensorInfo.port) | ||||||
|                     control.dmesg(`IIC ID ${sensorInfo.iicid.length}`) |                     control.dmesg(`IIC ID ${sensorInfo.iicid.length}`) | ||||||
|             } else if (newConn == DAL.CONN_INPUT_DUMB) { |                     break; | ||||||
|  |                 } case DAL.CONN_NXT_DUMB: { // analog NXT sensor | ||||||
|  |                     control.dmesg(`new NXT analog connection at ${sensorInfo.port}`); | ||||||
|  |                     sensorInfo.devType = inDcm[sensorInfo.port]; | ||||||
|  |                     control.dmesg(`NXT analog dev type ${sensorInfo.devType}`); | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |                 case DAL.CONN_INPUT_DUMB: { | ||||||
|                     control.dmesg(`new DUMB connection at ${sensorInfo.port}`) |                     control.dmesg(`new DUMB connection at ${sensorInfo.port}`) | ||||||
|                     // TODO? for now assume touch |                     // TODO? for now assume touch | ||||||
|                     sensorInfo.devType = DAL.DEVICE_TYPE_TOUCH |                     sensorInfo.devType = DAL.DEVICE_TYPE_TOUCH | ||||||
|             } else if (newConn == DAL.CONN_NONE || newConn == 0) { |                     break; | ||||||
|  |                 } | ||||||
|  |                 case DAL.CONN_NONE: | ||||||
|  |                 case 0: { | ||||||
|                     //control.dmesg(`disconnect at port ${sensorInfo.port}`) |                     //control.dmesg(`disconnect at port ${sensorInfo.port}`) | ||||||
|             } else { |                     break; | ||||||
|  |                 } | ||||||
|  |                 default: { | ||||||
|                     control.dmesg(`unknown connection type: ${newConn} at ${sensorInfo.port}`) |                     control.dmesg(`unknown connection type: ${newConn} at ${sensorInfo.port}`) | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -427,20 +446,20 @@ void      cUiUpdatePower(void) | |||||||
|         constructor(port: number) { |         constructor(port: number) { | ||||||
|             super(port) |             super(port) | ||||||
|             this.mode = 0 |             this.mode = 0 | ||||||
|             this.realmode = 0 |             this.realmode = 0; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         _activated() { |         _activated() { | ||||||
|             this.realmode = 0 |             this.realmode = 0; | ||||||
|             this._setMode(this.mode) |             this._setMode(this.mode) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         protected _setMode(m: number) { |         protected _setMode(m: number) { | ||||||
|             //control.dmesg(`_setMode p=${this.port} m: ${this.realmode} -> ${m}`) |  | ||||||
|             let v = m | 0 |             let v = m | 0 | ||||||
|             this.mode = v |             this.mode = v | ||||||
|             if (!this.isActive()) return |             if (!this.isActive()) return | ||||||
|             if (this.realmode != this.mode) { |             if (this.realmode != this.mode) { | ||||||
|  |                 control.dmesg(`_setMode p=${this._port} m: ${this.realmode} -> ${v}`) | ||||||
|                 this.realmode = v |                 this.realmode = v | ||||||
|                 setUartMode(this._port, v) |                 setUartMode(this._port, v) | ||||||
|             } |             } | ||||||
| @@ -570,18 +589,19 @@ void      cUiUpdatePower(void) | |||||||
|         while (ports.length) { |         while (ports.length) { | ||||||
|             const port = ports.pop(); |             const port = ports.pop(); | ||||||
|             const status = waitNonZeroUartStatus(port) |             const status = waitNonZeroUartStatus(port) | ||||||
|             control.dmesg(`UART set mode ${status} at ${port}`); |             control.dmesg(`UART status ${status} at ${port}`); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function updateUartMode(port: number, mode: number) { |     function updateUartMode(port: number, mode: number) { | ||||||
|         control.dmesg(`UART set mode to ${mode} at ${port}`) |         control.dmesg(`UART update mode to ${mode} at ${port}`) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Connection + port, DAL.CONN_INPUT_UART) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Connection + port, DAL.CONN_INPUT_UART) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Type + port, 33) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Type + port, 33) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Mode + port, mode) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Mode + port, mode) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function setUartMode(port: number, mode: number) { |     function setUartMode(port: number, mode: number) { | ||||||
|  |         control.dmesg(`UART set mode ${mode} at ${port}`); | ||||||
|         const UART_PORT_CHANGED = 1 |         const UART_PORT_CHANGED = 1 | ||||||
|         while (true) { |         while (true) { | ||||||
|             if (port < 0) return |             if (port < 0) return | ||||||
| @@ -592,7 +612,7 @@ void      cUiUpdatePower(void) | |||||||
|                 control.dmesg(`UART clear changed at ${port}`) |                 control.dmesg(`UART clear changed at ${port}`) | ||||||
|                 uartClearChange(port) |                 uartClearChange(port) | ||||||
|             } else { |             } else { | ||||||
|                 control.dmesg(`UART status ${status}`); |                 control.dmesg(`UART status ${status} at ${port}`); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             pause(10) |             pause(10) | ||||||
| @@ -607,15 +627,16 @@ void      cUiUpdatePower(void) | |||||||
|             DAL.MAX_DEVICE_DATALENGTH) |             DAL.MAX_DEVICE_DATALENGTH) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     function getUartNumber(fmt: NumberFormat, off: number, port: number) { |     function getUartNumber(fmt: NumberFormat, off: number, port: number): number { | ||||||
|         if (port < 0) return 0 |         if (port < 0) return 0 | ||||||
|         let index = uartMM.getNumber(NumberFormat.UInt16LE, UartOff.Actual + port * 2) |         const index = uartMM.getNumber(NumberFormat.UInt16LE, UartOff.Actual + port * 2) | ||||||
|         return uartMM.getNumber(fmt, |         return uartMM.getNumber(fmt, | ||||||
|             UartOff.Raw + DAL.MAX_DEVICE_DATALENGTH * 300 * port + DAL.MAX_DEVICE_DATALENGTH * index + off) |             UartOff.Raw + DAL.MAX_DEVICE_DATALENGTH * 300 * port + DAL.MAX_DEVICE_DATALENGTH * index + off) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     export function setIICMode(port: number, type: number, mode: number) { |     export function setIICMode(port: number, type: number, mode: number) { | ||||||
|         if (port < 0) return; |         if (port < 0) return; | ||||||
|  |         control.dmesg(`iic set type ${type} mode ${mode} at ${port}`) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Connection + port, DAL.CONN_NXT_IIC) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Connection + port, DAL.CONN_NXT_IIC) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Type + port, type) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Type + port, type) | ||||||
|         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Mode + port, mode) |         devcon.setNumber(NumberFormat.Int8LE, DevConOff.Mode + port, mode) | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ namespace console._screen { | |||||||
|             console.addListener(log); |             console.addListener(log); | ||||||
|             brick.buttonUp.onEvent(ButtonEvent.Bumped, () => scroll(-3)) |             brick.buttonUp.onEvent(ButtonEvent.Bumped, () => scroll(-3)) | ||||||
|             brick.buttonDown.onEvent(ButtonEvent.Bumped, () => scroll(3)) |             brick.buttonDown.onEvent(ButtonEvent.Bumped, () => scroll(3)) | ||||||
|  |             brick.showConsole(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ namespace brick { | |||||||
|         ShowLines, |         ShowLines, | ||||||
|         Image, |         Image, | ||||||
|         Ports, |         Ports, | ||||||
|  |         Console, | ||||||
|         Custom |         Custom | ||||||
|     } |     } | ||||||
|     let screenMode = ScreenMode.None; |     let screenMode = ScreenMode.None; | ||||||
| @@ -197,6 +198,12 @@ namespace brick { | |||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     export function showConsole() { | ||||||
|  |         console.sendToScreen(); | ||||||
|  |         screenMode = ScreenMode.Console; | ||||||
|  |         clearScreen(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * An image |      * An image | ||||||
|      * @param image the image |      * @param image the image | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user