-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhitechnic-irseeker-v1-SMUX-test1.c
85 lines (73 loc) · 2.54 KB
/
hitechnic-irseeker-v1-SMUX-test1.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#pragma config(Sensor, S1, HTSMUX, sensorI2CCustom)
//*!!Code automatically generated by 'ROBOTC' configuration wizard !!*//
/*
* $Id: hitechnic-irseeker-v1-SMUX-test1.c 133 2013-03-10 15:15:38Z xander $
*/
/**
* hitechnic-irseeker-v1.h provides an API for the HiTechnic IR Seeker. This program
* demonstrates how to use that API.
*
* Changelog:
* - 0.1: Initial release
* - 0.2: More comments
*
* Credits:
* - Big thanks to HiTechnic for providing me with the hardware necessary to write and test this.
*
* License: You may use this code as you wish, provided you give credit where it's due.
*
* THIS CODE WILL ONLY WORK WITH ROBOTC VERSION 3.59 AND HIGHER.
* Xander Soldaat (xander_at_botbench.com)
* 25 November 2009
* version 0.2
*/
#include "drivers/hitechnic-sensormux.h"
#include "drivers/hitechnic-irseeker-v1.h"
// The sensor is connected to the first port
// of the SMUX which is connected to the NXT port S1.
// To access that sensor, we must use msensor_S1_1. If the sensor
// were connected to 3rd port of the SMUX connected to the NXT port S4,
// we would use msensor_S4_3
// Give the sensor a nice easy to use name
const tMUXSensor HTIRS = msensor_S1_1;
task main () {
int _dir = 0;
int dcS1, dcS2, dcS3, dcS4, dcS5 = 0;
nxtDisplayCenteredTextLine(0, "HiTechnic");
nxtDisplayCenteredBigTextLine(1, "IR Seekr");
nxtDisplayCenteredTextLine(3, "SMUX Test");
nxtDisplayCenteredTextLine(5, "Connect SMUX to");
nxtDisplayCenteredTextLine(6, "S1 and IRS to");
nxtDisplayCenteredTextLine(7, "SMUX Port 1");
wait1Msec(2000);
while(true) {
eraseDisplay();
// read all of the sensors' values at once,
// exit the app if an error occurs
if (! HTIRSreadAllStrength(HTIRS, dcS1, dcS2, dcS3, dcS4, dcS5)) {
nxtDisplayTextLine(4, "ERROR!!");
wait1Msec(2000);
StopAllTasks();
}
// read the direction from which the signal is coming,
// exit the app if an error occurs
_dir = HTIRSreadDir(HTIRS);
if (_dir < 0) {
nxtDisplayTextLine(4, "ERROR!!");
wait1Msec(2000);
StopAllTasks();
}
// display the info from the sensor
nxtDisplayTextLine(0,"HT IR Seeker");
nxtDisplayTextLine(2, "dir: %d", _dir);
nxtDisplayTextLine(3, "S1: %3d", dcS1);
nxtDisplayTextLine(4, "S2: %3d", dcS2);
nxtDisplayTextLine(5, "S3: %3d", dcS3);
nxtDisplayTextLine(6, "S4: %3d", dcS4);
nxtDisplayTextLine(7, "S5: %3d", dcS5);
wait10Msec(100);
}
}
/*
* $Id: hitechnic-irseeker-v1-SMUX-test1.c 133 2013-03-10 15:15:38Z xander $
*/