Compare commits
11 Commits
69dfa4bbe8
...
master
Author | SHA1 | Date | |
---|---|---|---|
2d055ef04f | |||
8abf5ba17d | |||
1a2adbffdf | |||
6294807ed3 | |||
017f5b29ee | |||
b66ad843a7 | |||
d50b67fed1 | |||
2b086083cd | |||
efc5ac36f6 | |||
24e30d7e12 | |||
0fb56b4447 |
163
checklist.json
163
checklist.json
@ -1,163 +0,0 @@
|
||||
[
|
||||
{
|
||||
"Артикул": "Зарядно за LiPo акумулаторни батерии",
|
||||
"Модел": "XK1866 микро USB зарядно LiPo батерии",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "6.90лв.",
|
||||
"Сума": "6.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Акумулатор 12V/9Ah VIPOW",
|
||||
"Модел": "AKU 12/9AH VIPOW",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "35.00лв.",
|
||||
"Сума": "35.00лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Вакуум помпа ZD192",
|
||||
"Модел": "IN ZD192",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "5.90лв.",
|
||||
"Сума": "5.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Step-up DC-DC адаптер",
|
||||
"Модел": "TV K ADAP USB 5V-12V 1A 5.5*2.1MM",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "12.90лв.",
|
||||
"Сума": "12.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Преход SMA M - BNC M",
|
||||
"Модел": "F1027 SMA M-BNC M",
|
||||
"Кол-во": "2",
|
||||
"Ед. цена": "3.80лв.",
|
||||
"Сума": "7.60лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Преход SMA M - BNC Ж",
|
||||
"Модел": "F1028 SMA M-BNC M",
|
||||
"Кол-во": "2",
|
||||
"Ед. цена": "3.80лв.",
|
||||
"Сума": "7.60лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Преход SMA Ж - SMA Ж",
|
||||
"Модел": "F1025 SMA Ж-SMA Ж",
|
||||
"Кол-во": "2",
|
||||
"Ед. цена": "3.60лв.",
|
||||
"Сума": "7.20лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Пасивен балун комплект приемник/предавател QUICK",
|
||||
"Модел": "OHR BALUN QUICK K-T",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "9.50лв.",
|
||||
"Сума": "9.50лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Букса BNC-RG58-за кримпване",
|
||||
"Модел": "F411 BNC 50 КРИМ RG58",
|
||||
"Кол-во": "6",
|
||||
"Ед. цена": "0.80лв.",
|
||||
"Сума": "4.80лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Букса SMA-RG58-No reverse",
|
||||
"Модел": "F1020 SMA-RG58 NOREV",
|
||||
"Кол-во": "2",
|
||||
"Ед. цена": "3.90лв.",
|
||||
"Сума": "7.80лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Човка за поялник ZD C1-2",
|
||||
"Модел": "IN CH ZD C1-2",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "2.90лв.",
|
||||
"Сума": "2.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Човка за поялник PK353T",
|
||||
"Модел": "IN CH PK353T",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "3.90лв.",
|
||||
"Сума": "3.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Резистори 9W - Резистори 9W: 1Ω",
|
||||
"Модел": "R 9W",
|
||||
"Кол-во": "5",
|
||||
"Ед. цена": "0.65лв.",
|
||||
"Сума": "3.25лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Резистори 9W - Резистори 9W: 0.1Ω",
|
||||
"Модел": "R 9W",
|
||||
"Кол-во": "5",
|
||||
"Ед. цена": "0.65лв.",
|
||||
"Сума": "3.25лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Кондензатор полиестерен 100nF/250V MKT",
|
||||
"Модел": "100N/250V MKP GER",
|
||||
"Кол-во": "2",
|
||||
"Ед. цена": "0.60лв.",
|
||||
"Сума": "1.20лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Кондензатор керамичен 1nF/100V X7R",
|
||||
"Модел": "1N/100V X7R GERM",
|
||||
"Кол-во": "8",
|
||||
"Ед. цена": "0.13лв.",
|
||||
"Сума": "1.04лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Резистори 9W - Резистори 9W: 10Ω",
|
||||
"Модел": "R 9W",
|
||||
"Кол-во": "5",
|
||||
"Ед. цена": "0.65лв.",
|
||||
"Сума": "3.25лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Ферит 27х14,5х11мм",
|
||||
"Модел": "POR T106-2",
|
||||
"Кол-во": "1",
|
||||
"Ед. цена": "3.86лв.",
|
||||
"Сума": "3.86лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Ферит мини 9,5 х 10,5 х 2мм",
|
||||
"Модел": "FERIT MINI",
|
||||
"Кол-во": "5",
|
||||
"Ед. цена": "0.35лв.",
|
||||
"Сума": "1.75лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Ардуино 61 - Релеен модул с две релета",
|
||||
"Модел": "ARDUINO61 RELAY MODULE 2*10A/250V",
|
||||
"Кол-во": 1,
|
||||
"Ед. цена": "5.95лв.",
|
||||
"Сума": "5.95лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Ардуино 64 - Контролен панел TM4638",
|
||||
"Модел": "ARDUINO64 CONTROL PANEL TM4638",
|
||||
"Кол-во": 1,
|
||||
"Ед. цена": "9.90лв.",
|
||||
"Сума": "9.90лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Ардуино 40 - Енкодер",
|
||||
"Модел": "ARDUINO40 ENCODER",
|
||||
"Кол-во": 1,
|
||||
"Ед. цена": "3.00лв.",
|
||||
"Сума": "3.00лв."
|
||||
},
|
||||
{
|
||||
"Артикул": "Копче за потенциометър KP3",
|
||||
"Модел": "KP 3",
|
||||
"Кол-во": 3,
|
||||
"Ед. цена": "0.90лв.",
|
||||
"Сума": "2.70лв."
|
||||
}
|
||||
]
|
130
main.py
130
main.py
@ -3,42 +3,137 @@ import pigpio
|
||||
import time
|
||||
import datetime
|
||||
import asyncio
|
||||
import os
|
||||
from RPi import GPIO
|
||||
from itertools import cycle
|
||||
|
||||
PTT_IS_ON = False
|
||||
modulations = {
|
||||
"ssb":"./modulations/ssb.sh",
|
||||
"fmrds":"./modulations/fmrds.sh"
|
||||
|
||||
|
||||
bands = {
|
||||
"80m":[3.5, 4],
|
||||
"40m":[7, 7.3],
|
||||
"20m":[14, 14.35],
|
||||
"10m":[28, 29.7],
|
||||
"2m":[144,146],
|
||||
"70cm":[430,440]
|
||||
}
|
||||
|
||||
# Setup for encoder
|
||||
band = cycle(bands)
|
||||
CURRENT_BAND:str = None
|
||||
|
||||
|
||||
def next_band():
|
||||
global CURRENT_BAND
|
||||
CURRENT_BAND = next(band)
|
||||
FREQUENCY = bands[CURRENT_BAND][0]
|
||||
print(FREQUENCY)
|
||||
print(CURRENT_BAND)
|
||||
|
||||
return FREQUENCY
|
||||
|
||||
def prev_band():
|
||||
global CURRENT_BAND
|
||||
CURRENT_BAND = list(bands.keys())[list(bands.keys()).index(CURRENT_BAND)-1]
|
||||
print(CURRENT_BAND)
|
||||
FREQUENCY = bands[CURRENT_BAND][0] + 1
|
||||
return FREQUENCY
|
||||
|
||||
FREQUENCY = next_band()
|
||||
clk=17
|
||||
dt=27
|
||||
sw=22
|
||||
GPIO.setmode(GPIO.BCM)
|
||||
GPIO.setup(clk, GPIO.IN, pull_up_down=GPIO.PUD_DOWN)
|
||||
|
||||
clkLastState = GPIO.input(clk)
|
||||
|
||||
|
||||
async def rotary(clk=clk, dt=dt, sw=sw, step=0.025):
|
||||
GPIO.setmode(GPIO.BCM)
|
||||
|
||||
GPIO.setup(clk, GPIO.IN, pull_up_down=GPIO.PUD_DOWN)
|
||||
GPIO.setup(dt, GPIO.IN, pull_up_down=GPIO.PUD_DOWN)
|
||||
GPIO.setup(sw, GPIO.IN, pull_up_down=GPIO.PUD_DOWN)
|
||||
|
||||
global FREQUENCY, clkLastState
|
||||
|
||||
try:
|
||||
while True:
|
||||
clkState = GPIO.input(clk)
|
||||
dtState = GPIO.input(dt)
|
||||
swState = GPIO.input(sw)
|
||||
if swState == GPIO.HIGH:
|
||||
print("yeet")
|
||||
if clkState != clkLastState:
|
||||
if FREQUENCY > bands[CURRENT_BAND][1]:
|
||||
FREQUENCY = next_band()
|
||||
print(FREQUENCY)
|
||||
if FREQUENCY < bands[CURRENT_BAND][0]:
|
||||
FREQUENCY = prev_band()
|
||||
print(FREQUENCY)
|
||||
if dtState != clkState:
|
||||
FREQUENCY += step
|
||||
else:
|
||||
FREQUENCY -= step
|
||||
# print(round(FREQUENCY, 3))
|
||||
clkLastState = clkState
|
||||
await asyncio.sleep(.01)
|
||||
except KeyboardInterrupt:
|
||||
print("\nBye")
|
||||
finally:
|
||||
print("AAAAA")
|
||||
GPIO.cleanup()
|
||||
|
||||
|
||||
# 1. Hook up the screen and buttons
|
||||
# * the screen should show the frequency we're at
|
||||
# * read the buttons
|
||||
# 2. Encoder [x]
|
||||
# * Change frequency in the scope of a given band
|
||||
PTT_IS_ON:bool = False
|
||||
modulations = cycle(["./modulations/ssb.sh", "./modulations/fmrds.sh"])
|
||||
|
||||
|
||||
# init GPIO
|
||||
pi = pigpio.pi()
|
||||
# button pin
|
||||
pi.set_mode(10, pigpio.INPUT)
|
||||
# modulation change pin(change this)
|
||||
|
||||
async def run_command(*args):
|
||||
process = await asyncio.create_subprocess_exec(*args, stdout=asyncio.subprocess.PIPE, stderr=asyncio.subprocess.PIPE)
|
||||
print("Started: %s, pid=%s" % (args, process.pid), flush=True)
|
||||
|
||||
|
||||
async def button_press(gpio:int, level) -> bool:
|
||||
global PTT_IS_ON
|
||||
while True:
|
||||
if(pi.read(gpio)!=0):
|
||||
PTT_IS_ON = True
|
||||
if(pi.read(gpio)==0):
|
||||
PTT_IS_ON = False
|
||||
await asyncio.sleep(.5)
|
||||
|
||||
async def main(mod, freq:float):
|
||||
asyncio.create_task(button_press(10, pigpio.EITHER_EDGE))
|
||||
async def button_press(gpio:int, level):
|
||||
# TODO: light an LED
|
||||
global PTT_IS_ON
|
||||
if(pi.read(gpio)!=0):
|
||||
PTT_IS_ON = True
|
||||
if(pi.read(gpio)==0):
|
||||
PTT_IS_ON = False
|
||||
await asyncio.sleep(.01)
|
||||
|
||||
|
||||
# async def frequency(gpio):
|
||||
# # TODO write this function after hooking up the encoder
|
||||
|
||||
async def main():
|
||||
# TODO change after figuring out the logic
|
||||
task_created = False
|
||||
asyncio.create_task(rotary())
|
||||
print("Ready")
|
||||
cached_frequency = FREQUENCY
|
||||
|
||||
while True:
|
||||
if FREQUENCY != cached_frequency:
|
||||
cached_frequency = FREQUENCY
|
||||
asyncio.create_task(run_command("./display", str(format(round(FREQUENCY,3), "7f"))))
|
||||
await button_press(10, pigpio.EITHER_EDGE)
|
||||
|
||||
if (PTT_IS_ON and not task_created):
|
||||
asyncio.create_task(run_command(modulations[mod], str(freq)))
|
||||
asyncio.create_task(run_command(next(modulations), str(FREQUENCY)))
|
||||
task_created = True
|
||||
elif (task_created and not PTT_IS_ON):
|
||||
await asyncio.sleep(1)
|
||||
@ -46,8 +141,9 @@ async def main(mod, freq:float):
|
||||
task_created = False
|
||||
await asyncio.sleep(.5)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
try:
|
||||
asyncio.run(main("fmrds", 430))
|
||||
asyncio.run(main())
|
||||
except KeyboardInterrupt:
|
||||
print("\n")
|
||||
|
64
rotary.py
Normal file
64
rotary.py
Normal file
@ -0,0 +1,64 @@
|
||||
from functools import wraps, partial
|
||||
from RPi import GPIO
|
||||
from time import sleep
|
||||
from itertools import cycle
|
||||
|
||||
clkLastState = GPIO.input(clk)
|
||||
counter = next_band()
|
||||
|
||||
|
||||
bands = {
|
||||
"80m":[3.5, 4],
|
||||
"40m":[7, 7.3],
|
||||
"20m":[14, 14.35],
|
||||
"10m":[28, 29.7],
|
||||
"2m":[144,146],
|
||||
"70cm":[430,440]
|
||||
}
|
||||
|
||||
# Setup for encoder
|
||||
band = cycle(bands)
|
||||
CURRENT_BAND = None
|
||||
step = 0.025
|
||||
|
||||
|
||||
def next_band():
|
||||
global CURRENT_BAND
|
||||
CURRENT_BAND = next(band)
|
||||
counter = bands[CURRENT_BAND][0]
|
||||
print(counter)
|
||||
print(CURRENT_BAND)
|
||||
|
||||
return counter
|
||||
|
||||
def prev_band():
|
||||
global CURRENT_BAND
|
||||
CURRENT_BAND = list(bands.keys())[list(bands.keys()).index(CURRENT_BAND)-1]
|
||||
print(CURRENT_BAND)
|
||||
counter = bands[CURRENT_BAND][0] + 1
|
||||
return counter
|
||||
|
||||
async def main_loop(clk, dt, sw):
|
||||
try:
|
||||
clkState = GPIO.input(clk)
|
||||
dtState = GPIO.input(dt)
|
||||
swState = GPIO.input(sw)
|
||||
if swState == GPIO.HIGH:
|
||||
print("yeet")
|
||||
if clkState != clkLastState:
|
||||
if counter > bands[CURRENT_BAND][1]:
|
||||
counter = next_band()
|
||||
if counter < bands[CURRENT_BAND][0]:
|
||||
counter = prev_band()
|
||||
if dtState != clkState:
|
||||
counter += step
|
||||
else:
|
||||
counter -= step
|
||||
# print(round(counter, 3))
|
||||
clkLastState = clkState
|
||||
sleep(0.01)
|
||||
except KeyboardInterrupt:
|
||||
print("\nBye")
|
||||
finally:
|
||||
print("AAAAA")
|
||||
GPIO.cleanup()
|
Reference in New Issue
Block a user