Swift package SenseHat
for Raspberry Pi Sense Hat
data:image/s3,"s3://crabby-images/6e8d6/6e8d60ff29cf421e5e77dd9143017655e61259f4" alt="Photo Photo"
Features:
- ✅ blink with LED - that what everyone starts from playing with Raspberry Pi;
- ✅ get/set color to individual pixels;
- ✅ set color to all pixels in one shot;
- ✅ get/set all pixels in one shot (to/from Data);
- ✅ show 8x8 characters on LCD matrix (supported ascii, extended latin, box drawings elements, block elements, Hiragana, Greek, sga);
- ✅ show arbitrary text (8x8 font, horizontal scroll);
- ✅ rotating of LED matrix 0º/90º/180º/270º;
- ✅ set orientation of LED matrix 0º/90º/180º/270º and make all get/set primitives respect it;
- ✅ read joystick;
- ✅ read humidity and pressure sensors;
- ✅ read gyroscope/accelerometer/magnitometer sensors;
- ✅ snake game;
- ✅ life game;
TODO:
- improve gyroscope/accelerometer/magnetometer sensors reading;
- add conversion of RGB color to Rgb565;
- add Cyrillic font 8x8;
- add 3x5 font;
- replace C fonts with Swift ones;
- show arbitrary image on LED matrix;
- show preprocessed video;
- menu to show readings from any of available sensors;
- mode for rotating screen depending on gyro readings;
- emulator of SenseHat LED matrix for Web;
- Kalman filtering for accelerometer/gyro/magnetometer;
- add analog clock demo app.
Usage
Instantiating
// Look over all frame buffer devices in `/dev/` for one of Sense Hat.
// Use default orientation `.up`
guard let senseHat = SenseHat() else {
fatalError("Can't initialise Raspberry Pi Sense Hat")
}
Parameter orientation
could be used for other orientations” SenseHat(orientation: .left)
.
Parameter frameBufferDevice
could be use for specific frame buffer device: SenseHat(frameBufferDevice: "/dev/fb0")
.
Both parameters could be used: SenseHat(frameBufferDevice: "/dev/fb0", orientation: .down)
.
Parameter orientation defines where top of the LED matrix will be. Here are example of the same character "1"
shown with different orientations:
Set all LEDs of matrix to specific color
senseHat.set(color: .red) // sets all LEDs of matrix to red
data:image/s3,"s3://crabby-images/b2120/b212035ee5578de0eb66c9c48ccf5349827ac5cd" alt="Red"
senseHat.set(color: .black) // sets all LEDs of matrix to black, literally turns them off
data:image/s3,"s3://crabby-images/c560f/c560f932032b33fe45244e2e3e4fb28dbb0cb6ee" alt="Black"
Set specific LED of matrix to specific color
senseHat.set(color: .black) // clear
senseHat.set(x: 0, y: 0, color: .white) // set most top left LED to white using function syntax
senseHat[7, 7] = .green // set most bottom right LED to green using subscript syntax
data:image/s3,"s3://crabby-images/ade96/ade96396ed9436df2cd51597f626368d1e16baeb" alt="White and green"
Coordinates x
and y
should belong to 0..<7
range.
Show character on LED matrix
senseHat.show(character: Character("A"), color: .blue)
data:image/s3,"s3://crabby-images/f9095/f90955b726e6c474db46a326e4e888457392db6e" alt="A"
senseHat.show(character: Character("π"), color: .yellow, background: .blue)
data:image/s3,"s3://crabby-images/1ac5e/1ac5e82dd1371d12708d35ec4c0c07ee57c7e9e3" alt="pi"
Show string on LED matrix
senseHat.show(string: "Hello! ", secPerChar: 0.5, color: .yellow, background: .blue)
data:image/s3,"s3://crabby-images/36f2e/36f2e8bc94cadebc0d5c97a1699878d5080613ff" alt="Hello!"
senseHat.orientation = .left
senseHat.show(string: "Απόλλων ", secPerChar: 0.5, color: .red, background: .darkGray)
data:image/s3,"s3://crabby-images/c80f8/c80f820acb651436a9e1be8cde557c955d02d345" alt="Greek"
senseHat.orientation = .right
senseHat.show(string: "ここからそこまで ", secPerChar: 0.5, color: .white, background: .brown)
data:image/s3,"s3://crabby-images/655c0/655c0ba8c359f690e9b4751faf469da29ca5552e" alt="Hiragana"
senseHat.orientation = .down
senseHat.show(string: "Fußgängerübergänge ", secPerChar: 0.5, color: .white, background: .purple)
data:image/s3,"s3://crabby-images/fab91/fab91199153513094843b9f17ebc67c7153ea7c2" alt="deutsch"
Reading humidity sensor
if let h = senseHat.humidity() {
let strH = String(format: "%.1lf", h.H_rH)
senseHat.show(string: "Humidity \(strH)% rH ", secPerChar: 0.5, color: .yellow, background: .black)
let strT = String(format: "%.1lf", h.T_DegC)
senseHat.show(string: "Temperature \(strT)ºC", secPerChar: 0.5, color: .yellow, background: .black)
} else {
print("Cannot read humidity sensor")
}
data:image/s3,"s3://crabby-images/4d926/4d9260f3e3f5922c15d1af73efcc50ccbaeef17f" alt="humidity"
Reading pressure sensor
if let p = senseHat.pressure() {
let strP = String(format: "%.1lf", p.P_hPa)
let strT = String(format: "%.1lf", p.T_DegC)
senseHat.show(string: "Pressure \(strP) hPa ", secPerChar: 0.5, color: .yellow, background: .black)
senseHat.show(string: "Temperature \(strT)ºC", secPerChar: 0.5, color: .yellow, background: .black)
} else {
print("Cannot read pressure sensor")
}
data:image/s3,"s3://crabby-images/e2f6c/e2f6c173d0668ef772b7ab44dce3ae985b560987" alt="pressure"
Useful links
Unfortunately Data sheet or Programmer’s manual for Raspberry Pi Sense Hat doesn’t exist or I have failed to find it. Here are some useful links:
data:image/s3,"s3://crabby-images/2d5a2/2d5a22738a80127bd463b38c970ae643d76a1ab6" alt="Buy Me A Coffee"
data:image/s3,"s3://crabby-images/25cdb/25cdbbb54842b2597102311231982b510e3999e8" alt="Blinking Blinking"
Swift package
SenseHat
for Raspberry Pi Sense HatFeatures:
TODO:
Usage
Instantiating
Parameter
orientation
could be used for other orientations”SenseHat(orientation: .left)
. ParameterframeBufferDevice
could be use for specific frame buffer device:SenseHat(frameBufferDevice: "/dev/fb0")
. Both parameters could be used:SenseHat(frameBufferDevice: "/dev/fb0", orientation: .down)
.Parameter orientation defines where top of the LED matrix will be. Here are example of the same character
"1"
shown with different orientations:.up
.left
.right
.down
Set all LEDs of matrix to specific color
data:image/s3,"s3://crabby-images/b2120/b212035ee5578de0eb66c9c48ccf5349827ac5cd" alt="Red"
data:image/s3,"s3://crabby-images/c560f/c560f932032b33fe45244e2e3e4fb28dbb0cb6ee" alt="Black"
Set specific LED of matrix to specific color
data:image/s3,"s3://crabby-images/ade96/ade96396ed9436df2cd51597f626368d1e16baeb" alt="White and green"
Coordinates
x
andy
should belong to0..<7
range.Show character on LED matrix
data:image/s3,"s3://crabby-images/f9095/f90955b726e6c474db46a326e4e888457392db6e" alt="A"
data:image/s3,"s3://crabby-images/1ac5e/1ac5e82dd1371d12708d35ec4c0c07ee57c7e9e3" alt="pi"
Show string on LED matrix
data:image/s3,"s3://crabby-images/36f2e/36f2e8bc94cadebc0d5c97a1699878d5080613ff" alt="Hello!"
data:image/s3,"s3://crabby-images/c80f8/c80f820acb651436a9e1be8cde557c955d02d345" alt="Greek"
data:image/s3,"s3://crabby-images/655c0/655c0ba8c359f690e9b4751faf469da29ca5552e" alt="Hiragana"
data:image/s3,"s3://crabby-images/fab91/fab91199153513094843b9f17ebc67c7153ea7c2" alt="deutsch"
Reading humidity sensor
data:image/s3,"s3://crabby-images/4d926/4d9260f3e3f5922c15d1af73efcc50ccbaeef17f" alt="humidity"
Reading pressure sensor
data:image/s3,"s3://crabby-images/e2f6c/e2f6c173d0668ef772b7ab44dce3ae985b560987" alt="pressure"
Useful links
Unfortunately Data sheet or Programmer’s manual for Raspberry Pi Sense Hat doesn’t exist or I have failed to find it. Here are some useful links:
Rgb565
;