Configurable OLED screen rotation (#359)

* Read rotation from the 1st command line arg

* Configure screen rotation during installation

* Better argument validation + use human readable arguments

* Cleanup
This commit is contained in:
Daniel Markstedt 2021-10-20 19:33:06 -07:00 committed by GitHub
parent dbaf5dcd30
commit 269b718ec7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 52 additions and 3 deletions

View File

@ -139,9 +139,18 @@ function installRaScsiScreen() {
echo "IMPORTANT: This configuration requires a OLED screen to be installed onto your RaSCSI board." echo "IMPORTANT: This configuration requires a OLED screen to be installed onto your RaSCSI board."
echo "See wiki for more information: https://github.com/akuker/RASCSI/wiki/OLED-Status-Display-(Optional)" echo "See wiki for more information: https://github.com/akuker/RASCSI/wiki/OLED-Status-Display-(Optional)"
echo "" echo ""
echo "Press enter to continue or CTRL-C to exit" echo "Do you want to use the recommended screen rotation (180 degrees)?"
echo "Press Y/n and Enter, or CTRL-C to exit"
read REPLY read REPLY
if [ "$REPLY" == "N" ] || [ "$REPLY" == "n" ]; then
echo "Proceeding with 0 degrees rotation."
ROTATION="0"
else
echo "Proceeding with 180 degrees rotation."
ROTATION="180"
fi
sudo systemctl stop monitor_rascsi || true sudo systemctl stop monitor_rascsi || true
updateRaScsiGit updateRaScsiGit
@ -170,6 +179,8 @@ function installRaScsiScreen() {
echo "Installing the monitor_rascsi.service configuration..." echo "Installing the monitor_rascsi.service configuration..."
sudo cp -f "$BASE/src/oled_monitor/monitor_rascsi.service" /etc/systemd/system/monitor_rascsi.service sudo cp -f "$BASE/src/oled_monitor/monitor_rascsi.service" /etc/systemd/system/monitor_rascsi.service
sudo sed -i /^ExecStart=/d /etc/systemd/system/monitor_rascsi.service
sudo sed -i "8 i ExecStart=$BASE/src/oled_monitor/start.sh --rotation=$ROTATION" /etc/systemd/system/monitor_rascsi.service
sudo systemctl daemon-reload sudo systemctl daemon-reload
sudo systemctl enable monitor_rascsi sudo systemctl enable monitor_rascsi

View File

@ -29,6 +29,7 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
# THE SOFTWARE. # THE SOFTWARE.
from time import sleep from time import sleep
from sys import argv, exit
import logging import logging
from board import I2C from board import I2C
from adafruit_ssd1306 import SSD1306_I2C from adafruit_ssd1306 import SSD1306_I2C
@ -60,7 +61,20 @@ print (oled)
print () print ()
print ("Will update the OLED display every " + str(delay_time_ms) + "ms (approximately)") print ("Will update the OLED display every " + str(delay_time_ms) + "ms (approximately)")
# Attempt to read the first argument to the script; fall back to 2 (180 degrees)
if len(argv) > 1:
if str(argv[1]) == "0":
rotation = 0
elif str(argv[1]) == "180":
rotation = 2
else:
exit("Only 0 and 180 are valid arguments for screen rotation.")
else:
print("Defaulting to 180 degrees screen rotation.")
rotation = 2
# Clear display. # Clear display.
oled.rotation = rotation
oled.fill(0) oled.fill(0)
oled.show() oled.show()

View File

@ -70,5 +70,29 @@ else
fi fi
fi fi
echo "Starting OLED Screen..." # parse arguments
python3 rascsi_oled_monitor.py while [ "$1" != "" ]; do
PARAM=$(echo "$1" | awk -F= '{print $1}')
VALUE=$(echo "$1" | awk -F= '{print $2}')
case $PARAM in
-r | --rotation)
ROTATION=$VALUE
;;
*)
echo "ERROR: unknown parameter \"$PARAM\""
exit 1
;;
esac
case $VALUE in
0 | 180 )
;;
*)
echo "ERROR: invalid option \"$VALUE\""
exit 1
;;
esac
shift
done
echo "Starting OLED Screen with $ROTATION degrees rotation..."
python3 rascsi_oled_monitor.py "${ROTATION}"