Skip to content

Commit 8b01d94

Browse files
authored
Merge pull request #37 from codecae/revert-36-vtx_presave_fix
Revert "Vtx presave fix"
2 parents 00b1ce3 + b51c1a8 commit 8b01d94

File tree

2 files changed

+8
-7
lines changed

2 files changed

+8
-7
lines changed

sdcard/SCRIPTS/BF/X9/vtx.lua

+1-1
Original file line numberDiff line numberDiff line change
@@ -1 +1 @@
1-
return{read=88,write=89,eepromWrite=false,reboot=false,saveMaxRetries=2,saveTimeout=300,title="VTX",minBytes=5,text={},fields={{t="Band",x=25,y=14,sp=50,min=1,max=5,vals={2},to=SMLSIZE,table={"A","B","E","F","R"},upd=function(self)self.updateVTXFreq(self)end},{t="Channel",x=25,y=24,sp=50,min=1,max=8,vals={3},to=SMLSIZE,upd=function(self)self.updateVTXFreq(self)end},{t="Power",x=25,y=34,sp=50,min=1,vals={4},to=SMLSIZE,upd=function(self)self.updatePowerTable(self)end},{t="Pit",x=25,y=44,sp=50,min=0,max=1,vals={5},to=SMLSIZE,table={[0]="OFF","ON"}},{t="Dev",x=100,y=14,sp=32,write=false,ro=true,vals={1},to=SMLSIZE,table={[3]="SmartAudio",[4]="Tramp",[255]="None"}},{t="Freq",x=100,y=24,sp=32,min=5000,max=6000,to=SMLSIZE,ro=true}},freqLookup={{5865,5845,5825,5805,5785,5765,5745,5725},{5733,5752,5771,5790,5809,5828,5847,5866},{5705,5685,5665,5645,5885,5905,5925,5945},{5740,5760,5780,5800,5820,5840,5860,5880},{5658,5695,5732,5769,5806,5843,5880,5917}},postLoad=function(self)if self.values[2]==0 or self.values[3]==0 or self.values[4]==0 then self.values={}end end,preSave=function(self)local a={}local b=(self.values[2]-1)*8+self.values[3]-1;a[1]=bit32.band(b,0xFF)a[2]=bit32.rshift(b,8)a[3]=self.values[4]a[4]=self.values[5]self.values=a end,updatePowerTable=function(self)if self.values and not self.fields[3].table then if self.values[1]==3 then self.fields[3].table={25,200,500,800}self.fields[3].max=4 elseif self.values[1]==4 then self.fields[3].table={25,100,200,400,600}self.fields[3].max=5 end end end,updateVTXFreq=function(self)if(#self.values or 0)>=self.minBytes then if(self.fields[2].value or 0)>0 and(self.fields[3].value or 0)>0 then self.fields[6].value=self.freqLookup[self.values[2]][self.values[3]]end end end}
1+
return{read=88,write=89,eepromWrite=false,reboot=false,saveMaxRetries=2,saveTimeout=300,title="VTX",minBytes=5,text={},fields={{t="Band",x=25,y=14,sp=50,min=1,max=5,vals={2},to=SMLSIZE,table={"A","B","E","F","R"},upd=function(self)self.updateVTXFreq(self)end},{t="Channel",x=25,y=24,sp=50,min=1,max=8,vals={3},to=SMLSIZE,upd=function(self)self.updateVTXFreq(self)end},{t="Power",x=25,y=34,sp=50,min=1,vals={4},to=SMLSIZE,upd=function(self)self.updatePowerTable(self)end},{t="Pit",x=25,y=44,sp=50,min=0,max=1,vals={5},to=SMLSIZE,table={[0]="OFF","ON"}},{t="Dev",x=100,y=14,sp=32,write=false,ro=true,vals={1},to=SMLSIZE,table={[3]="SmartAudio",[4]="Tramp",[255]="None"}},{t="Freq",x=100,y=24,sp=32,min=5000,max=6000,to=SMLSIZE,ro=true}},freqLookup={{5865,5845,5825,5805,5785,5765,5745,5725},{5733,5752,5771,5790,5809,5828,5847,5866},{5705,5685,5665,5645,5885,5905,5925,5945},{5740,5760,5780,5800,5820,5840,5860,5880},{5658,5695,5732,5769,5806,5843,5880,5917}},postLoad=function(self)if self.values[2]==0 or self.values[3]==0 or self.values[4]==0 then self.values={}end end,preSave=function(self)local a={}local b=(self.values[2]-1)*8+self.values[3]-1;self.values[2]=bit32.band(b,0xFF)self.values[3]=bit32.rshift(b,8)for c=2,self.minBytes do a[c-1]=self.values[c]end;self.values=a end,updatePowerTable=function(self)if self.values and not self.fields[3].table then if self.values[1]==3 then self.fields[3].table={25,200,500,800}self.fields[3].max=4 elseif self.values[1]==4 then self.fields[3].table={25,100,200,400,600}self.fields[3].max=5 end end end,updateVTXFreq=function(self)if(#self.values or 0)>=self.minBytes then if(self.fields[2].value or 0)>0 and(self.fields[3].value or 0)>0 then self.fields[6].value=self.freqLookup[self.values[2]][self.values[3]]end end end}

src/SCRIPTS/BF/X9/vtx.lua

+7-6
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ return {
66
reboot = false,
77
saveMaxRetries = 2,
88
saveTimeout = 300, -- 3s
9-
title = "VTX",
9+
title = "VTX",
1010
minBytes = 5,
1111
text = {},
1212
fields = {
@@ -29,13 +29,14 @@ return {
2929
self.values = {}
3030
end
3131
end,
32-
preSave = function(self)
32+
preSave = function(self)
3333
local valsTemp = {}
3434
local channel = (self.values[2]-1)*8 + self.values[3]-1
35-
valsTemp[1] = bit32.band(channel,0xFF)
36-
valsTemp[2] = bit32.rshift(channel,8)
37-
valsTemp[3] = self.values[4]
38-
valsTemp[4] = self.values[5]
35+
self.values[2] = bit32.band(channel,0xFF)
36+
self.values[3] = bit32.rshift(channel,8)
37+
for i=2,self.minBytes do
38+
valsTemp[i-1] = self.values[i]
39+
end
3940
self.values = valsTemp
4041
end,
4142
updatePowerTable = function(self)

0 commit comments

Comments
 (0)