function ui_init()--------ui初始化 ----------------------------------------------------------------↓音乐↓--------------------------------------------------------------- function S_Pointer(t_So, t_Offset, _bit) local function getRanges() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v.type:sub(2, 2) == 'w' then table.insert(ranges, v) end end return ranges end local function Get_Address(N_So, Offset, ti_bit) local ti = gg.getTargetInfo() local S_list = getRanges() local t = {} local _t local _S = nil if ti_bit then _t = 32 else _t = 4 end for i in pairs(S_list) do local _N = S_list[i].internalName:gsub('^.*/', '') if N_So[1] == _N and N_So[2] == S_list[i].state then _S = S_list[i] break end end if _S then t[#t + 1] = {} t[#t].address = _S.start + Offset[1] t[#t].flags = _t if #Offset ~= 1 then for i = 2, #Offset do local S = gg.getValues(t) t = {} for _ in pairs(S) do if not ti.x64 then S[_].value = S[_].value & 0xFFFFFFFF end t[#t + 1] = {} t[#t].address = S[_].value + Offset[i] t[#t].flags = _t end end end _S = t[#t].address end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A end --遍历写法 local function readD ( a ) return gg.getValues ( { { address = a , flags = 4 } } ) [ 1 ].value end function setvalue(address,flags,value) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end function addListltems(address,flags,value,freeze) t={} t[1]={} t[1].address=address t[1].flags=flags t[1].value=value t[1].freeze=freeze gg.addListItems(t) end function xfnb(add,lx) return gg.getValues({ { address=add,flags = lx } })[1].value end local function RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_QWORD}})[1].value end function setvalue(address,flags,value) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end function addListltems(address,flags,value,freeze) t={} t[1]={} t[1].address=address t[1].flags=flags t[1].value=value t[1].freeze=freeze gg.addListItems(t) end local function RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_QWORD}})[1].value end function readPointer(name, offset, i) local re = gg.getRangesList(name) local x64 = gg.getTargetInfo().x64 local va = {[true] = 32, [false] = 4} if re[i or 1] then local addr = re[i or 1].start + offset[1] for i = 2, #offset do addr = gg.getValues({{address = addr, flags = va[x64]}}) if not x64 then addr[1].value = addr[1].value & 0xFFFFFFFF end addr = addr[1].value + offset[i] end return addr end end function gg.edits(addr, Table, name) local Table1 = {{}, {}} for k, v in ipairs(Table) do local value = {address = addr + v[3], value = v[1], flags = v[2], freeze = v[4]} if v[4] then Table1[2][#Table1[2] + 1] = value else Table1[1][#Table1[1] + 1] = value end end gg.addListItems(Table1[2]) gg.setValues(Table1[1]) gg.toast((name or "") .. "开启成功, 共修改" .. #Table .. "个值") end function LSQ_Chain(so, offset, format, value, type, Function)--模块设置, 偏移量, 功能参数, 修改值, 类型, 功能 getRanges = getRanges or (function() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v["type"]:sub(2, 2) == 'w' then--判断so是否可读可写 ranges[#ranges+1] = v end end return ranges end) local rest, ranges, sostart, valtype = {}, getRanges(), nil , gg.TYPE_DWORD if gg.getTargetInfo()["x64"] then--判断应用程序是否为64位 valtype = gg.TYPE_QWORD end for i in pairs(ranges) do local _name = ranges[i]["internalName"]:gsub('^.*/', '') if so[1] == _name and so[2] == ranges[i]["state"] then sostart = ranges[i]["start"] break end end if sostart then if offset[1] then for i = 1, #offset do rest = {{flags = valtype,address = sostart + offset[i]}} rest = gg.getValues(rest) if i == #offset then break end if valtype == gg.TYPE_DWORD then sostart = rest[1].value & 0xFFFFFFFF--对值进行补位操作 else sostart = rest[1].value end end end print(rest) if #rest == 1 then end return Format(rest, format, value, type, Function) end gg.toast("功能:" .. Function .. "开启失败") print("功能开启失败原因: 未找到静态头") return os.exit() end function Format(tab, format, value, type, Function) if format == "查看" then tab[1]["flags"] = type return print(gg.getValues(tab)) elseif format == "修改" then tab[1]["flags"] = type tab[1]["value"] = value return gg.setValues(tab) elseif format == "冻结" then tab[1]["flags"] = type tab[1]["freeze"] = true tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end end function split(szFullString, szSeparator) local nFindStartIndex = 1 local nSplitIndex = 1 local nSplitArray = {} while true do local nFindLastIndex = string.find(szFullString, szSeparator, nFindStartIndex) if not nFindLastIndex then nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, string.len(szFullString)) break end nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, nFindLastIndex - 1) nFindStartIndex = nFindLastIndex + string.len(szSeparator) nSplitIndex = nSplitIndex + 1 end return nSplitArray end function xgxc(szpy, qmxg) for x = 1, #(qmxg) do xgpy = szpy + qmxg[x]["offset"] xglx = qmxg[x]["type"] xgsz = qmxg[x]["value"] gg.setValues({[1] = {address = xgpy, flags = xglx, value = xgsz}}) xgsl = xgsl + 1 end end function xqmnb(qmnb) gg.clearResults() gg.setRanges(qmnb[1]["memory"]) gg.searchNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "开启失败") else gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "开启失败") else sl = gg.getResults(999999) sz = gg.getResultCount() xgsl = 0 if sz > 999999 then sz = 999999 end for i = 1, sz do pdsz = true for v = 4, #(qmnb) do if pdsz == true then pysz = {} pysz[1] = {} pysz[1].address = sl[i].address + qmnb[v]["offset"] pysz[1].flags = qmnb[v]["type"] szpy = gg.getValues(pysz) pdpd = qmnb[v]["lv"] .. ";" .. szpy[1].value szpd = split(pdpd, ";") tzszpd = szpd[1] pyszpd = szpd[2] if tzszpd == pyszpd then pdjg = true pdsz = true else pdjg = false pdsz = false end end end if pdjg == true then szpy = sl[i].address xgxc(szpy, qmxg) xgjg = true end end if xgjg == true then gg.toast(qmnb[2]["name"] .. "开启成功,共修改" .. xgsl .. "条数据") else gg.toast(qmnb[2]["name"] .. "开启失败") end end end end function setvalue(address, flags, value) local tt = {} tt[1] = {} tt[1].address = address tt[1].flags = flags tt[1].value = value gg.setValues(tt) end function read(address, flags) local tt = {} tt[1] = {} tt[1].address = address tt[1].flags = flags filzer = gg.getValues(tt)[1].value return filzer end function getbase(address) local tt = {} tt[1] = {} tt[1].address = address tt[1].flags = 32 filzer = gg.getValues(tt)[1].value return filzer end function S_Pointer(t_So, t_Offset, _bit) local function getRanges() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v.type:sub(2, 2) == 'w' then table.insert(ranges, v) end end return ranges end local function Get_Address(N_So, Offset, ti_bit) local ti = gg.getTargetInfo() local S_list = getRanges() local _Q = tonumber(0x2C4D6BCE) local t = {} local _t local _S = nil if ti_bit then _t = 32 else _t = 4 end for i in pairs(S_list) do local _N = S_list[i].internalName:gsub('^.*/', '') if N_So[1] == _N and N_So[2] == S_list[i].state then _S = S_list[i] break end end if _S then t[#t + 1] = {} t[#t].address = _S.start + Offset[1] t[#t].flags = _t if #Offset ~= 1 then for i = 2, #Offset do local S = gg.getValues(t) t = {} for _ in pairs(S) do if not ti.x64 then S[_].value = S[_].value & 0xFFFFFFFF end t[#t + 1] = {} t[#t].address = S[_].value + Offset[i] t[#t].flags = _t end end end _S = t[#t].address end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A end ----动态基址写法配置 function PS() end function setvalue(address,flags,value) PS('修改地址数值(地址,数值类型,要修改的值)') local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end ---静态基址写法配置 function split(szFullString, szSeparator) local nFindStartIndex = 1 local nSplitIndex = 1 local nSplitArray = {} while true do local nFindLastIndex = string.find(szFullString, szSeparator, nFindStartIndex) if not nFindLastIndex then nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, string.len(szFullString)) break end nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, nFindLastIndex - 1) nFindStartIndex = nFindLastIndex + string.len(szSeparator) nSplitIndex = nSplitIndex + 1 end return nSplitArray end function xgxc(szpy, qmxg) for x = 1, #(qmxg) do xgpy = szpy + qmxg[x]["offset"] xglx = qmxg[x]["type"] xgsz = qmxg[x]["value"] xgdj = qmxg[x]["freeze"] if xgdj == nil or xgdj == "" then gg.setValues({[1] = {address = xgpy, flags = xglx, value = xgsz}}) else gg.addListItems({[1] = {address = xgpy, flags = xglx, freeze = xgdj, value = xgsz}}) end xgsl = xgsl + 1 xgjg = true end end function xqmnb(qmnb) gg.clearResults() gg.setRanges(qmnb[1]["memory"]) gg.searchNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "失败") else gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "失败") else sl = gg.getResults(999999) sz = gg.getResultCount() xgsl = 0 if sz > 999999 then sz = 999999 end for i = 1, sz do pdsz = true for v = 4, #(qmnb) do if pdsz == true then pysz = {} pysz[1] = {} pysz[1].address = sl[i].address + qmnb[v]["offset"] pysz[1].flags = qmnb[v]["type"] szpy = gg.getValues(pysz) pdpd = qmnb[v]["lv"] .. ";" .. szpy[1].value szpd = split(pdpd, ";") tzszpd = szpd[1] pyszpd = szpd[2] if tzszpd == pyszpd then pdjg = true pdsz = true else pdjg = false pdsz = false end end end if pdjg == true then szpy = sl[i].address xgxc(szpy, qmxg) end end if xgjg == true then gg.toast(qmnb[2]["name"] .. "地址成功,共修改" .. xgsl .. "条数据") else gg.toast(qmnb[2]["name"] .. "失败") end end end end --仿XS写法配置 function xqmnb(Search,Modification) gg.clearResults() gg.setRanges(Search[1].memory) gg.searchNumber(Search[3].value,Search[3].type,false,536870912,0,-1) if gg.getResultCount()==0 then gg.toast(Search[2].name..'开启失败') return end local Result=gg.getResults(gg.getResultCount()) local sum for index=4,#Search do sum=0 for i=1,#Result do if gg.getValues({{address=Result[i].address+Search[index].offset,flags=Search[index].type}})[1].value~=Search[index].lv then Result[i].Usable=true sum=sum+1 end end if sum==#Result then gg.toast(Search[2].name..'开启失败') return end end local Data,Freeze,Freezes={},{},0 sum=0 for index,value in ipairs(Modification)do for index=1,#Result do if not Result[index].Usable then local Value={address=Result[index].address+value.offset,flags=value.type,value=value.value,freeze=true} if value.freeze then Freeze[#Freeze+1]=Value Freezes=Freezes+1 else Data[#Data+1]=Value end sum=sum+1 end end end gg.setValues(Data) gg.addListItems(Freeze) if Freezes==0 then gg.toast(Search[2].name..'开启成功,共修改'..sum..'条数据') else gg.toast(Search[2].name..'开启成功,共修改'..sum..'条数据,冻结'..Freezes..'条数据') end gg.clearResults() end -- 读取内存地址的函数 function readPointer(name, offset, i) local re = gg.getRangesList(name) local x64 = gg.getTargetInfo().x64 local va = {[true]=32, [false]=4} if re[i or 1] then local addr = re[i or 1].start + offset[1] for i = 2, #offset do addr = gg.getValues({{address=addr, flags=va[x64]}}) if not x64 then addr[1].value = addr[1].value & 0xFFFFFFFF end addr = addr[1].value + offset[i] end return addr end end -- 修改内存地址的函数 function gg.edits(addr, Table, name) local Table1 = {{}, {}} for k, v in ipairs(Table) do local value = {address = addr+v[3], value = v[1], flags = v[2], freeze = v[4]} if v[4] then Table1[2][#Table1[2]+1] = value else Table1[1][#Table1[1]+1] = value end end gg.addListItems(Table1[2]) gg.setValues(Table1[1]) gg.toast((name or "") .. "开启成功, 共修改"..#Table.."个值") end local Ranges=gg.getRangesList('/') local function Read(module,type) for k,v in pairs(Ranges) do if v['internalName']:match('[^/]*$')==module and v['type']==type then return v['start'] end end end function S_Pointer(t_So, t_Offset, _bit) local function getRanges() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v.type:sub(2, 2) == 'w' then table.insert(ranges, v) end end return ranges end local function Get_Address(N_So, Offset, ti_bit) local ti = gg.getTargetInfo() local S_list = getRanges() local t = {} local _t local _S = nil if ti_bit then _t = 32 else _t = 4 end for i in pairs(S_list) do local _N = S_list[i].internalName:gsub('^.*/', '') if N_So[1] == _N and N_So[2] == S_list[i].state then _S = S_list[i] break end end if _S then t[#t + 1] = {} t[#t].address = _S.start + Offset[1] t[#t].flags = _t if #Offset ~= 1 then for i = 2, #Offset do local S = gg.getValues(t) t = {} for _ in pairs(S) do if not ti.x64 then S[_].value = S[_].value & 0xFFFFFFFF end t[#t + 1] = {} t[#t].address = S[_].value + Offset[i] t[#t].flags = _t end end end _S = t[#t].address end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A end --遍历写法 local function readD ( a ) return gg.getValues ( { { address = a , flags = 4 } } ) [ 1 ].value end function setvalue(address,flags,value) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end function addListltems(address,flags,value,freeze) t={} t[1]={} t[1].address=address t[1].flags=flags t[1].value=value t[1].freeze=freeze gg.addListItems(t) end function xfnb(add,lx) return gg.getValues({ { address=add,flags = lx } })[1].value end local function RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_QWORD}})[1].value end function setvalue(address,flags,value) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end function addListltems(address,flags,value,freeze) t={} t[1]={} t[1].address=address t[1].flags=flags t[1].value=value t[1].freeze=freeze gg.addListItems(t) end local function RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_QWORD}})[1].value end ----------------------------------------------------------------------------------个美化个--------------------------------------------------------------------- ----------------------------------------------------------------------------------↓防封↓--------------------------------------------------------------------- function S_Pointer(t_So, t_Offset, _bit) local function getRanges() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v.type:sub(2, 2) == 'w' then table.insert(ranges, v) end end return ranges end local function Get_Address(N_So, Offset, ti_bit) local ti = gg.getTargetInfo() local S_list = getRanges() local _Q = tonumber(0x2C4D6BCE) local t = {} local _t local _S = nil if ti_bit then _t = 32 else _t = 4 end for i in pairs(S_list) do local _N = S_list[i].internalName:gsub('^.*/', '') if N_So[1] == _N and N_So[2] == S_list[i].state then _S = S_list[i] break end end if _S then t[#t + 1] = {} t[#t].address = _S.start + Offset[1] t[#t].flags = _t if #Offset ~= 1 then for i = 2, #Offset do local S = gg.getValues(t) t = {} for _ in pairs(S) do if not ti.x64 then S[_].value = S[_].value & 0xFFFFFFFF end t[#t + 1] = {} t[#t].address = S[_].value + Offset[i] t[#t].flags = _t end end end _S = t[#t].address end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A end ----动态基址写法配置 function PS() end function setvalue(address,flags,value) PS('修改地址数值(地址,数值类型,要修改的值)') local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) end ---静态基址写法配置 function split(szFullString, szSeparator) local nFindStartIndex = 1 local nSplitIndex = 1 local nSplitArray = {} while true do local nFindLastIndex = string.find(szFullString, szSeparator, nFindStartIndex) if not nFindLastIndex then nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, string.len(szFullString)) break end nSplitArray[nSplitIndex] = string.sub(szFullString, nFindStartIndex, nFindLastIndex - 1) nFindStartIndex = nFindLastIndex + string.len(szSeparator) nSplitIndex = nSplitIndex + 1 end return nSplitArray end function xgxc(szpy, qmxg) for x = 1, #(qmxg) do xgpy = szpy + qmxg[x]["offset"] xglx = qmxg[x]["type"] xgsz = qmxg[x]["value"] xgdj = qmxg[x]["freeze"] if xgdj == nil or xgdj == "" then gg.setValues({[1] = {address = xgpy, flags = xglx, value = xgsz}}) else gg.addListItems({[1] = {address = xgpy, flags = xglx, freeze = xgdj, value = xgsz}}) end xgsl = xgsl + 1 xgjg = true end end function xqmnb(qmnb) gg.clearResults() gg.setRanges(qmnb[1]["memory"]) gg.searchNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "失败") else gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) gg.refineNumber(qmnb[3]["value"], qmnb[3]["type"]) if gg.getResultCount() == 0 then gg.toast(qmnb[2]["name"] .. "失败") else sl = gg.getResults(999999) sz = gg.getResultCount() xgsl = 0 if sz > 999999 then sz = 999999 end for i = 1, sz do pdsz = true for v = 4, #(qmnb) do if pdsz == true then pysz = {} pysz[1] = {} pysz[1].address = sl[i].address + qmnb[v]["offset"] pysz[1].flags = qmnb[v]["type"] szpy = gg.getValues(pysz) pdpd = qmnb[v]["lv"] .. ";" .. szpy[1].value szpd = split(pdpd, ";") tzszpd = szpd[1] pyszpd = szpd[2] if tzszpd == pyszpd then pdjg = true pdsz = true else pdjg = false pdsz = false end end end if pdjg == true then szpy = sl[i].address xgxc(szpy, qmxg) end end if xgjg == true then gg.toast(qmnb[2]["name"] .. "地址成功,共修改" .. xgsl .. "条数据") else gg.toast(qmnb[2]["name"] .. "失败") end end end end --仿XS写法配置 function xqmnb(Search,Modification) gg.clearResults() gg.setRanges(Search[1].memory) gg.searchNumber(Search[3].value,Search[3].type,false,536870912,0,-1) if gg.getResultCount()==0 then gg.toast(Search[2].name..'开启失败') return end local Result=gg.getResults(gg.getResultCount()) local sum for index=4,#Search do sum=0 for i=1,#Result do if gg.getValues({{address=Result[i].address+Search[index].offset,flags=Search[index].type}})[1].value~=Search[index].lv then Result[i].Usable=true sum=sum+1 end end if sum==#Result then gg.toast(Search[2].name..'开启失败') return end end local Data,Freeze,Freezes={},{},0 sum=0 for index,value in ipairs(Modification)do for index=1,#Result do if not Result[index].Usable then local Value={address=Result[index].address+value.offset,flags=value.type,value=value.value,freeze=true} if value.freeze then Freeze[#Freeze+1]=Value Freezes=Freezes+1 else Data[#Data+1]=Value end sum=sum+1 end end end gg.setValues(Data) gg.addListItems(Freeze) if Freezes==0 then gg.toast(Search[2].name..'开启成功,共修改'..sum..'条数据') else gg.toast(Search[2].name..'开启成功,共修改'..sum..'条数据,冻结'..Freezes..'条数据') end gg.clearResults() end -- 读取内存地址的函数 function readPointer(name, offset, i) local re = gg.getRangesList(name) local x64 = gg.getTargetInfo().x64 local va = {[true]=32, [false]=4} if re[i or 1] then local addr = re[i or 1].start + offset[1] for i = 2, #offset do addr = gg.getValues({{address=addr, flags=va[x64]}}) if not x64 then addr[1].value = addr[1].value & 0xFFFFFFFF end addr = addr[1].value + offset[i] end return addr end end -- 修改内存地址的函数 function gg.edits(addr, Table, name) local Table1 = {{}, {}} for k, v in ipairs(Table) do local value = {address = addr+v[3], value = v[1], flags = v[2], freeze = v[4]} if v[4] then Table1[2][#Table1[2]+1] = value else Table1[1][#Table1[1]+1] = value end end gg.addListItems(Table1[2]) gg.setValues(Table1[1]) gg.toast((name or "") .. "开启成功, 共修改"..#Table.."个值") end ----------------------------------------------------------------------------------个防封个----------------------------------------------------------------------- -------------------------------------------------------------↓脚本配置↓----------------------------------------------------------- changan = {} local changan = changan local android = import('android.*') function write(fileName, content) --f = assert( io.open( fileName, 'w')) f:write( content ) f:close() if file.write(fileName, content) == false then gg.alert("请给框架和修改器 文件储存权限\n否则无法正常运行") os.exit() end end function panduan(rec) fille,err = io.open(rec) if fille == nil then return false else return true end end function pdcf(lujing) rec = "/sdcard/玖辞/配置文件/"..lujing fille,err = io.open(rec) if fille == nil then return false else return true end end sleep = gg.sleep if gg.isHTTPdump()==true and panduan("/sdcard/玖辞/配置文件/vpn.txt") == false then gg.alert("\n请先关闭加速器再启动脚本") os.exit() end function read(fileName) f = assert(io.open(fileName, 'r')) content = f:read("*all") f:close() return content end function wtcf(lujing,neirong) write("/sdcard/玖辞/配置文件/"..lujing,neirong) end function rdcf(lujing) return read("/sdcard/玖辞/配置文件/"..lujing) end function pmusic(x) if audiokg == "开" then tmp1 = 0 gg.playMusic(x) tmp1 = 1 end end if pdcf("audio") ~= true then wtcf("audio","开") end audiokg = rdcf("audio") function camusic(ress) tmp1 = 0 if audiokg == "开" then if panduan("/sdcard/玖辞/音频/"..ress) == true then pmusic("/sdcard/玖辞/音频/"..ress) tmp1 = 1 else download("https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/"..ress ,"/sdcard/玖辞/音频/"..ress) pmusic("/sdcard/玖辞/音频/"..ress) tmp1 = 1 end end end 开 = "开" 关 = "关" function checkimg(tmp) if panduan("/sdcard/玖辞/图片/"..tmp) ~= true then gg.toast("正在下载资源"..tmp.."\n请耐心等待") download("https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/"..tmp,"/sdcard/玖辞/图片/"..tmp) end end file.getdirs("/sdcard/玖辞/状态读取/") ckimg = { "小畜生logo", "check1", "arblackx", "check2", "exit", "sj", "hsj" } for i = 1,#ckimg do jindu = i checkimg(ckimg[i]) end context = app.context window = context:getSystemService("window") -- 获取窗口管理器 function getLayoutParams() LayoutParams = WindowManager.LayoutParams layoutParams = luajava.new(LayoutParams) if (Build.VERSION.SDK_INT >= 26) then -- 设置悬浮窗方式 layoutParams.type = LayoutParams.TYPE_APPLICATION_OVERLAY else layoutParams.type = LayoutParams.TYPE_PHONE end layoutParams.format = PixelFormat.RGBA_8888 -- 设置背景 layoutParams.flags = LayoutParams.FLAG_NOT_FOCUSABLE -- 焦点设置Finish layoutParams.gravity = Gravity.TOP|Gravity.LEFT -- 重力设置 layoutParams.width = LayoutParams.WRAP_CONTENT -- 布局宽度 layoutParams.height = LayoutParams.WRAP_CONTENT -- 布局高度 return layoutParams end function getj6() jianbian6 = luajava.new(GradientDrawable) jianbian6:setCornerRadius(20) jianbian6:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbian6:setColors(菜单小背景颜色) jianbian6:setStroke(3,菜单小背景边框)--边框宽度和颜色 return jianbian6 end function getseekgra() jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(10) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(其他控件背景) jianbians:setStroke(4,"0xeeffffff")--边框宽度和颜色 return jianbians end function getseekgra2() jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(8) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors({0xeeffffff,0xccffffff}) jianbians:setStroke(1,"0xee000000")--边框宽度和颜色 return jianbians end function 获取图片(txt) ntxt=string.sub(string.gsub(txt,"/","."),-10,-1) if string.find(tostring(txt),"http")~=nil then if panduan("/storage/emulated/0/图片/图标.png"..ntxt)==false then download(txt,"/storage/emulated/0/图片/图标.png"..ntxt) end txt="/storage/emulated/0/图片/图标.png"..ntxt end return luajava.getBitmapDrawable(txt) end jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(10) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(侧边按钮背景1) jianbians:setStroke(4,"0xaa000000")--边框宽度和颜色 slctb = jianbians jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(10) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(侧边按钮背景2) jianbians:setStroke(4,"0xaa000000")--边框宽度和颜色 slcta = jianbians slctc = luajava.loadlayout { GradientDrawable, color = "#11ffffff", cornerRadius = 8 } slctd = luajava.loadlayout { GradientDrawable, color = "#55ffffff", cornerRadius = 8 } slcte = luajava.loadlayout { GradientDrawable, color = "#11ffffff", cornerRadius = 12 } slctf = luajava.loadlayout { GradientDrawable, color = "#aa1E1C27", cornerRadius = 15 } function getjb() local jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(15) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors({0xff397EF8,0xff25C4FD}) jianbians:setOrientation(GradientDrawable.Orientation.LEFT_RIGHT) return jianbians end function chatbg2() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, luajava.loadlayout { GradientDrawable, color = "#aa0082FF", cornerRadius = 12 }) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, getjb()) -- 没点击的背景 return selector end function getshape9() jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(10) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(button颜色) jianbians:setStroke(4,"0xeeFFffff")--边框宽度和颜色 return jianbians end jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(10) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors({0xaaFF6EBF,0x660072ff}) jianbians:setStroke(4,"0xeeFFffff")--边框宽度和颜色 t3s=jianbians t4s=luajava.loadlayout { GradientDrawable, color = "#87000000", cornerRadius = 12 } t5s=jianbians t6s=luajava.loadlayout { GradientDrawable, color = "#87000000", cornerRadius = 12 } function getSelector3() t9s=getshape9() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, t4s) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, t9s) -- 没点击的背景 return selector end function getSelector5() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, t6s) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, t5s) -- 没点击的背景 return selector end function getSelector() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, slcta) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, slctb) -- 没点击的背景 return selector end function getSelector2() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, slctd) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, slctc) -- 没点击的背景 return selector end jianbian = luajava.new(GradientDrawable) jianbian:setCornerRadius(30) jianbian:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbian2 = luajava.new(GradientDrawable) jianbian2:setCornerRadius(30) jianbian2:setGradientType(GradientDrawable.LINEAR_GRADIENT) local isswitch YoYoImpl = luajava.getYoYoImpl() changan.menu = function(sview) if isswitch then return false end for i=1,#stab do _ENV["jmb"..i]=getSelector() end if #stab> #sview then gg.alert("菜单标题参数多于菜单配置,请检查") os.exit() end isswitch = true cebian = { LinearLayout, id = "侧边", visibility = "gone", layout_height = "230dp", layout_width = "58dp", orientation = "vertical", background = { GradientDrawable, color = "#00ffffff", cornerRadius = 10 }, } gund = { LinearLayout, orientation = "vertical", } for i = 1,#stab do _ENV["jm"..i]=luajava.loadlayout({ LinearLayout, id = "jm"..i, layout_height = "38.3dp", layout_width = "58dp", layout_marginTop = "2dp", layout_marginBottom = "2dp", background = _ENV["jmb"..i], onClick=function() changan.controlFlip(_ENV["jm"..i],500) 切换(i) end, { TextView, gravity = "center", textColor=侧边文字颜色, text = stab[i][1], layout_height = "38.3dp", layout_width = "58dp", --onClick = function() 切换(i) end }}) gund[#gund+1] = _ENV["jm"..i] end cebian[#cebian+1] = { ScrollView, layout_height = "fill_parent", layout_width = "fill_parent", gund } cebian = luajava.loadlayout(cebian) for i = 1,#stab do _ENV["layout"..i] = luajava.loadlayout( { ScrollView, background = getj6(), fillViewport = "true", padding = "2dp", id = "layout"..i, visibility = "gone", gravity="center", layout_width = "260dp", layout_height = "230dp", orientation = "vertical", { LinearLayout, --background = getj6(), id = "layoutm"..i, gravity = "top", layout_width = "260dp", orientation = "vertical", gravity = "center_horizontal", }, }) end _ENV["layout".. 4] = luajava.loadlayout( {LinearLayout, orientation = "horizontal", layout_width="wrap_content", layout_height="230dp", visibility = "gone", { ScrollView, background = getj6(), fillViewport = "true", padding = "3dp", id = "layouts".. 4, layout_width = "260dp", layout_height = "230dp", orientation = "vertical", { LinearLayout, --background = getj6(), id = "layoutm"..4, gravity = "top", layout_width = "260dp", orientation = "vertical", gravity = "center_horizontal", }}, {ScrollView, fillViewport = "true", id="ltg4", {LinearLayout, id="layoutg4", orientation="vertical", gravity="center", layout_width="230dp", layout_height="wrap_content", }} }) ckou = { LinearLayout, id = "chuangk", padding="4dp", visibility = "gone", layout_width = "wrap_content", layout_height = "wrap_content", orientation = "horizontal", cebian, } for i = 1,#stab do ckou[#ckou+1] = _ENV["layout"..i] end luajava.newThread(function() develo(ckou) end):start() ckou = luajava.loadlayout(ckou) title = luajava.loadlayout({ TextView, id = "title", textColor = "#000000", visibility = "gone", text = stab[1][2], gravity = "center", textSize = "24sp", layout_width = "fill_parent", }) control1=luajava.loadlayout({ ImageView, id = "control", hardwareAccelerated="true", layout_gravity = "left", background = xfcpic, layout_width = "40dp", layout_height = "40dp", }) frme=luajava.loadlayout({ FrameLayout, padding = "8dp", layout_width = "match_parent", layout_height = "wrap_content", orientation = "horizontal", background = beij2, gravity = "center", control1, title, { ImageView, id = "exitt", visibility = "gone", layout_gravity = "right", src = "/sdcard/玖辞/图片/arwhitex", layout_width = "20dp", layout_height = "20dp", layout_marginTop = "10dp", layout_marginRight = "14dp", } }) floatWindow = { LinearLayout, id = "motion", layout_width = "wrap_content", orientation = "vertical", gravity = "center_vertical", layout_height = "wrap_content", frme, ckou }local function invoke() local ok local RawX, RawY, x, y mainLayoutParams = getLayoutParams() floatWindow = luajava.loadlayout(floatWindow) local function invoke2() block('start') for k = 1,#stab do for i = 1,#sview[k] do _ENV["layoutm"..k]:addView(sview[k][i]) end end window:addView(floatWindow, mainLayoutParams) block('end') end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) block('join') control.onClick = function() 隐藏() end exitt.onClick = function() 隐藏() end jm4.onClick = function() changan.controlFlip(jm4,500) 切换(4) gundong() already = true changan.setedit("",qltname) changan.setedit("",qlticon) end local isMove hanshu = function(v, event) local Action = event:getAction() if Action == MotionEvent.ACTION_DOWN then isMove = false RawX = event:getRawX() RawY = event:getRawY() x = mainLayoutParams.x y = mainLayoutParams.y elseif Action == MotionEvent.ACTION_MOVE then isMove = true mainLayoutParams.x = tonumber(x) + (event:getRawX() - RawX) mainLayoutParams.y = tonumber(y) + (event:getRawY() - RawY) window:updateViewLayout(floatWindow, mainLayoutParams) end end motion.onTouch = hanshu control.onTouch = hanshu exitt.onTouch = hanshu for i = 1,#stab do --_ENV["jm"..i].onTouch = hanshu end end invoke(swib1,swib2) jm1:setBackground(slcta) gg.setVisible(false) luajava.setFloatingWindowHide(true) end corbk = true 当前ui = 1 function 切换(x) 当前ui = x luajava.runUiThread(function() for i = 1,#stab do _ENV["jm"..i]:setBackground(_ENV["jmb"..i]) _ENV["layout"..i]:setVisibility(View.GONE) end title:setText(stab[当前ui][2]) _ENV["layout"..当前ui]:setVisibility(View.VISIBLE) _ENV["jm"..当前ui]:setBackground(slcta) YoYoImpl:with("FadeIn"):duration(200):playOn(_ENV["layout"..当前ui]) end) end 显示 = 0 beij = luajava.new(GradientDrawable) beij:setCornerRadius(20) beij:setGradientType(GradientDrawable.LINEAR_GRADIENT) beij:setColors((大背景颜色)) beij:setStroke(6,大背景边框)--边框宽度和颜色 beij2 = luajava.loadlayout({ GradientDrawable, color = "#001E1C27", cornerRadius = 10 }) titlejb = luajava.new(GradientDrawable) titlejb:setCornerRadius(20) titlejb:setGradientType(GradientDrawable.LINEAR_GRADIENT) titlejb:setColors((标题颜色)) if 标题边框开关~=0 then titlejb:setStroke(6,标题边框颜色)--边框宽度和颜色 end function getcolor(cl) cl[1] = tonumber(math.ceil(cl[1]*2.6,0,5)) if cl[1] > 255 then cl[1] = "0xff" else cl[1] = "0x"..string.format("%x",cl[1]) end for i = 1,3 do cl[i+1] = string.format("%x",cl[i+1]) if string.len(cl[i+1]) == 1 then cl[i+1] = "0"..cl[i+1] end end cl = cl[1]..cl[2]..cl[3]..cl[4] return cl end function getrgb(cl) if string.sub(cl,1,1) == "#" then cl = "0x"..string.sub(cl,2,-1) end cl = { tonumber(string.sub(cl,0,4)),tonumber("0x"..string.sub(cl,5,6)),tonumber("0x"..string.sub(cl,7,8))} return cl end function 隐藏() luajava.runUiThread(function() --control:setBackground(luajava.getBitmapDrawable("/sdcard/污青Pro/图片/arlogo")) if tonumber(tostring(cebian:getVisibility())) == 8.0 then chuangk:setVisibility(View.VISIBLE) cebian:setVisibility(View.VISIBLE) title:setVisibility(View.VISIBLE) exitt:setVisibility(View.VISIBLE) frme:setBackground(titlejb) 显示=1 mainLayoutParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL window:updateViewLayout(floatWindow, mainLayoutParams) YoYoImpl:with("SlideInDown"):duration(200):playOn(cebian) _ENV["layout"..当前ui]:setVisibility(View.VISIBLE) YoYoImpl:with("FadeIn"):duration(800):playOn(_ENV["layout"..当前ui]) floatWindow:setBackground(beij) else 显示=0 luajava.runUiThread(function()mainLayoutParams.flags = LayoutParams.FLAG_NOT_FOCUSABLE window:updateViewLayout(floatWindow, mainLayoutParams) end) frme:setBackground(beij2) --control:setBackground(luajava.getBitmapDrawable("/sdcard/污青Pro/图片/arlogo")) title:setVisibility(View.GONE) exitt:setVisibility(View.GONE) floatWindow:setBackground(beij2) chuangk:setVisibility(View.GONE) cebian:setVisibility(View.GONE) _ENV["layout"..当前ui]:setVisibility(View.GONE) end end) end function guid() seed = { 'e','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f' } tb = {} for i = 1,32 do table.insert(tb,seed[math.random(1,16)]) end sid = table.concat(tb) return string.format('%s%s%s%s%s', string.sub(sid,1,8), string.sub(sid,10,12), string.sub(sid,21,22)) ..string.format('%s%s%s%s%s', string.sub(sid,1,6), string.sub(sid,21,25) ) end chazhi = {} chajv = {} function changan.seek(name,bian,smin,smax,nows) _ENV[bian] = nows thum=getseekgra() thum:setSize(60, 60) smin = tonumber(smin) smax = tonumber(smax) chajv[bian] = smax-smin chazhi[bian] = 1-smin if smin == nil then smin = 1 smax = 10 end truesmin = 1 truesmax = truesmin+chajv[bian] if not nows then nows = smin tnows = (smin-nows) else tnows = (nows-smin)+1 end if _ENV[bian] == nil then _ENV[bian] = 1.0 end if not name then name = "未设置" end local names = name..guid() rest = luajava.loadlayout({ LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", { LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", layout_marginTop = "5dp", layout_marginBottom = "5dp", layout_marginLeft = "10dp", layout_marginRight = "10dp", gravity = "center_vertical", background = getseekgra(), { TextView, gravity = "top", textColor=txtco, text = name..":"..nows, id = luajava.newId(names), layout_width = '110dp', layout_marginLeft = "5dp", layout_marginRight = "0dp", }, { See小畜生ar, layout_width = '100dp', min = truesmin, max = truesmax, progress = tnows, progressDrawable={getseekgra2()}, thumb=thum, onSee小畜生arChange = { onProgressChanged = function(See小畜生ar, var2, var3) if not var3 then return end local resultvar = tonumber(string.sub(var2,0,-3))-chazhi[bian] luajava.runUiThread(function() luajava.getIdValue(names):setText(name..":".. resultvar) end) _ENV[bian] = resultvar end }} }}) return rest end function changan.switch(name,func1,func2) local func = 开关(name,func1,func2) if not name then name = "未设置" end rest = luajava.loadlayout({ LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", { LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", layout_marginTop = "5dp", layout_marginBottom = "5dp", layout_marginLeft = "10dp", layout_marginRight = "10dp", gravity = "center_vertical", background = getseekgra(), { TextView, gravity = "top", text = name, layout_width = '140dp', layout_marginLeft = "10dp", layout_marginRight = "10dp", }, { Switch, gravity = "top", layout_width = 'match_parent', layout_hight = "10dp", --id=luajava.newId(tid), switchMinWidth = "20dp", onCheckedChange = function(Switch,var2,var3) if var2 == true then var2 = "开" else var2 = "关" end luajava.newThread(function() func() end):start() end, }} }) return rest end function changan.edit(name) _ENV[name] = name..guid() if not name then name = "" end rest = luajava.loadlayout({ LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", { LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", layout_marginTop = "5dp", layout_marginBottom = "5dp", layout_marginLeft = "10dp", layout_marginRight = "10dp", gravity = "center_vertical", background = getseekgra(), { EditText, gravity = "top", hint = name, gravity = "center", id = luajava.newId(_ENV[name]), layout_width = 'fill', layout_marginLeft = "10dp", layout_marginRight = "10dp", }} }) return rest end function changan.radio(radio) firadio = { LinearLayout, layout_width = 'fill_parent', layout_hight = "fill_parent", padding = "10dp", orientation = "vertical" } if type(radio[1]) == "string" or type(radio[1]) == "number" then firadio[#firadio+1] = { TextView,text = radio[1], textColor=txtco } end radios = { RadioGroup,background = getseekgra(), layout_width = 'fill_parent', } for i = 2,#radio do radios[#radios+1] = { RadioButton, layout_width = 'fill_parent', text = radio[i][1], textColor=txtco, onClick = function() luajava.newThread(function() pcall(radio[i][2]) end):start() end, } end firadio[#firadio+1] = radios return luajava.loadlayout(firadio) end function changan.check(cklist) local rest = { GridLayout, columnCount = '3', layout_width = 'match_parent', layout_height = "wrap_content", layout_marginLeft = "3dp", layout_marginRight = "3dp", gravity = "center" } for i = 1,#cklist do local name = cklist[i][1] local func1 = cklist[i][2] local func2 = cklist[i][3] if not name then name = "未设置" end rstt = changan.intcheck(name,func1,func2) rest[#rest+1] = rstt end return luajava.loadlayout({ LinearLayout,rest }) end function changan.intcheck(name,func1,func2) nid = name..guid() local func = 开关3(name,func1,func2,nid) if not name then name = "未设置" end local rest = luajava.loadlayout({ LinearLayout, layout_width = 'wrap_content', layout_height = "32dp", layout_marginTop = "1dp", layout_marginBottom = "1dp", padding = "1dp", { LinearLayout, onClick = function() luajava.newThread(function() func() end):start() end, layout_width = 'fill_parent', layout_height = "32dp", gravity = "center_vertical", { TextView, gravity = "left", text = name, textColor="#FFFFFFFF", textSize = "12sp", gravity="center", --layout_marginLeft="8dp", layout_width = '45dp', }, { FrameLayout, id = luajava.newId(nid), background = chec小畜生g, onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '38dp', layout_height = 'wrap_content', padding="1dp", { LinearLayout, layout_gravity="left", id = luajava.newId(nid.."k"), background = chec小畜生g1, onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '21dp', layout_height = '21dp', },{ LinearLayout, visibility="gone", layout_gravity="right", id = luajava.newId(nid.."g"), background = chec小畜生g2, onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '21dp', layout_height = '21dp', } }} }) return rest end function 开关3(name,func1,func2,nid) _ENV [ name ] = "关" if func1 == nil then func1 = "" end if func2 == nil then func2 = "" end if type(func1 ) == "function" then return function() namers = _ENV [ name ] if namers ~= "开" then luajava.runUiThread(function() luajava.getIdValue(nid.."k"):setVisibility(View.GONE) luajava.getIdValue(nid.."g"):setVisibility(View.VISIBLE) luajava.getIdValue(nid):setBackground(chec小畜生ga) end) _ENV [ name ] = "开" pcall(func1 ) else luajava.runUiThread(function() luajava.getIdValue(nid.."g"):setVisibility(View.GONE) luajava.getIdValue(nid.."k"):setVisibility(View.VISIBLE) luajava.getIdValue(nid):setBackground(chec小畜生g) end) _ENV [ name ] = "关" pcall(func2 ) end end end end function getShape(tmp0,tmp1,tmp2,tmp3) jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(tmp0) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(tmp1) jianbians:setOrientation(GradientDrawable.Orientation.LEFT_RIGHT) jianbians:setStroke(1,tmp3)--边框宽度和颜色 return jianbians end function getShape2(tmp0,tmp1,tmp2,tmp3) jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(tmp0) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(tmp1) jianbians:setOrientation(GradientDrawable.Orientation.LEFT_RIGHT) jianbians:setStroke(1,tmp3)--边框宽度和颜色 return jianbians end chec小畜生g=getShape( 45, {0xffB8B8B8,0xffB8B8B8}, 4,0xaa000000) chec小畜生ga=getShape( 45, {0xff0BBE56,0xff0BBE56}, 4,0xaa000000) chec小畜生g1=getShape2( 45, {0xffffffff,0xffffffff}, 4,0xaa000000) chec小畜生g2=getShape2( 45, {0xffffffff,0xffffffff}, 4,0xaa000000) function changan.button(txt,func) if not txt then txt = "未设置" end return luajava.loadlayout( { LinearLayout, layout_width = 'fill_parent', layout_hight = "wrap_content", { LinearLayout, layout_width = "fill_parent", gravity = "center_horizontal", layout_marginRight = "10dp", layout_marginLeft = "10dp", layout_marginTop = "5dp", layout_marginBottom = "5dp", background = getSelector3(), onClick = function() luajava.newThread(function() pcall(func) end):start() end, { TextView, --id = luajava.newId(tid), text = txt, textColor=txtco, textSize = "16sp", layout_width = "wrap_content", }, }}) end function changan.text(txt,color,size) if not txt then txt = "未设置文字" end if not color then color = "#ffffff" end if not size then size = "18sp" end return luajava.loadlayout( { TextView, text = txt, textSize = size, textColor = color, layout_width = "wrap_content", }) end corb = true function changan.setedit(name,txt) txt = tostring(txt) luajava.runUiThread(function() luajava.getIdValue(_ENV[name]):setText(txt) end) end function changan.getedit(name) gg.alert(edit) edit = tostring(luajava.getIdValue(_ENV[name]):getText()) return edit end function 开关(name,func1,func2) if func1 == nil then func1 = "" end if func2 == nil then func2 = "" end if type(func1) == "function" then return function() namers = _ENV[name] if namers ~= "开" then _ENV[name] = "开" pcall(func1) else _ENV[name] = "关" pcall(func2) end end end end function 开关2(name,func1,func2,nid) if func1 == nil then func1 = "" end if func2 == nil then func2 = "" end if type(func1) == "function" then return function() namers = _ENV[name] if namers ~= "开" then luajava.runUiThread(function() luajava.getIdValue(nid):setBackground(luajava.getBitmapDrawable("/storage/emulated/0/图片/图标.png")) end) _ENV[name] = "开" func1() else luajava.runUiThread(function() luajava.getIdValue(nid):setBackground(luajava.getBitmapDrawable("/storage/emulated/0/图片/图标.png")) end) _ENV[name] = "关" func2() end end end end function deve(t) luajava.newThread(function() gg.alert(tostring(t)) end):start() end changan.controlChange = function(control,colors) luajava.runUiThread(function() if type(colors) ~= "table" then end import "android.animation.ObjectAnimator" import "android.animation.ArgbEvaluator" import "android.animation.ValueAnimator" import "android.graphics.Color" colorAnim = ObjectAnimator:ofInt(control,"textColor", colors) colorAnim:setDuration(7000) colorAnim:setEvaluator(ArgbEvaluator()) colorAnim:setRepeatCount(ValueAnimator.INFINITE) colorAnim:setRepeatMode(ValueAnimator.REVERSE) colorAnim:start() end) end changan.controlRotetion = function(control,time) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" xuanzhuandonghua = ObjectAnimator:ofFloat(control, "rotation", { 0, 360 }) xuanzhuandonghua:setRepeatCount(0) xuanzhuandonghua:setRepeatMode(Animation.REVERSE) xuanzhuandonghua:setDuration(time) xuanzhuandonghua:start() end) end xuanzhuandonghua = nil -- 全局变量用于保存动画对象 changan.controlRotation2 = function(control, time) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" xuanzhuandonghua = ObjectAnimator:ofFloat(control, "rotation", { 0, 0 }) xuanzhuandonghua:setRepeatCount(0) xuanzhuandonghua:setRepeatMode(Animation.RESTART) xuanzhuandonghua:setDuration(time) xuanzhuandonghua:start() end) end -- 停止旋转动画 changan.stopRotation = function() if xuanzhuandonghua then xuanzhuandonghua:cancel() end end changan.controlFlip = function(control,time) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" xuanzhuandonghua1 = ObjectAnimator:ofFloat(control, "rotationY", {0, 360}) xuanzhuandonghua1:setRepeatCount(0) xuanzhuandonghua1:setRepeatMode(Animation.REVERSE) xuanzhuandonghua1:setDuration(time) xuanzhuandonghua1:start() end) end function tuic() gg.toast("悬浮窗已退出") window:removeView(floatWindow) luajava.setFloatingWindowHide(false) luajava.newThread(function() os.exit() end):start() bloc("end") end zidong = luajava.newThread(function() while true do if zdbf then logvid = luajava.getIdView("video") logvid.start(logvid) end gg.sleep(500) end end) url="https://api.qqsuu.cn/api/dm-xjj?type=video&apiKey=56ecfa25f1478b202b174b7e871a5a61" bloc = luajava.getBlock() local runnable = luajava.getRunnable(function() vidd=luajava.loadlayout({ VideoView, id = luajava.newId('video'), videoPath = url, layout_width = "fill_parent", layout_height = "wrap_content", }) bloc("end") end) local handler = luajava.getHandler() handler:post(runnable) bloc("join") web6 = luajava.loadlayout({FrameLayout, gravity="top|center_vertical", {LinearLayout, gravity="center",orientation="vertical", vidd,changan.button("换一个",function() zdbf=false changan.controlFlip(web6,2500) gg.sleep(500) logvid = luajava.getIdView("video") logvid:setVideoPath(url) gg.sleep(2000) zdbf=true end), },{LinearLayout, gravity="center", changan.switch("自动播放", function() zdbf = true end, function() zdbf=false logvid = luajava.getIdView("video") logvid.pause(logvid) end), }, } ) zdbf=false zidong:start() do local path = "/sdcard/.游客信息jj.lua" --用户信息 local r = io.open(path, "r") if r then qltname = r:read("*a") else qltname = "游客" .. math.random(1111111, 9999999) io.open(path, "w"):write(qltname) end local path = "/sdcard/.用户头像jj.lua" --用户信息 local r = io.open(path, "r") if r then qlticon = r:read("*a") else qlticon = "" io.open(path, "w"):write(qlticon) end end httpip="http://47.101.220.155/jj/caa.php" httpip2="http://47.101.220.155/jj/" function getu(name) fs=gg.makeRequest(httpip.."?name="..name.."&mode=get").content if fs=="00" then return "获取失败" else return fs end end function uplo(name,txt) fs=gg.makeRequest(httpip.."?txt="..txt.."&name="..name.."&mode=set").content end function uprec(name,txt) txt=string.bin2hex(txt) if string.len(txt)<=7000 then uplo(name,txt) else uplo(name,string.sub(txt,1,7000)) for i=2,(string.len(txt)/7000)-1 do fs=gg.makeRequest(httpip.."?txt="..string.sub(txt,(i-1)*7000,i*7000).."&name="..name.."&mode=set2").content end txt=string.sub(txt,math.floor(string.len(txt)/7000)*7000+1,-1) fs=gg.makeRequest(httpip.."?txt="..txt.."&name="..name.."&mode=set2").content end end function 修改名字(lttext) if string.len(lttext) <= 0 then return 0 end if string.len(lttext) >= 400 then gg.toast("用户名长度上限20字节") return 0 end local path = "/sdcard/.游客信息jj.lua" --用户信息 qltname = lttext io.open(path, "w"):write(qltname) gg.alert("修改成功\n"..lttext) local function invoke2() _ENV["ltg4"]:fullScroll(View.FOCUS_DOWN) end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) end function 修改头像(txt) local path2 = "" if string.find(txt,"emulated/0") ~= nil or string.find(txt,"/sdcard") ~= nil then gg.alert("") return 0 end if tonumber(txt) ~= nil then txt = "http://q1.qlogo.cn/g?b=qq&nk="..txt.."&s=100" end if string.find(txt,"http%%") ~= nil or string.find(txt,"https%%") ~= nil then gg.alert("格式有误,请重新输入") return 0 end txt = string.url(txt,"en") qlticon = txt io.open(path2, "w"):write(qlticon) local function invoke2() _ENV["ltg4"]:fullScroll(View.FOCUS_UP) end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) gg.alert("") ltfunc() end lastlttm = os.time()-3 function 发送聊天(lttext) if os.time()-lastlttm <= 3 then gg.alert(""..3 -(os.time()-lastlttm).."秒") return 0 end local server = "" --服务器地址 local chat_log = gg.makeRequest(server .. "lts.php?hq=true").content local uptime = gg.makeRequest(server .. "lts.php?updat=true").content if uptime then io.open(path, "w"):write(GT[2]) if string.len(lttext) <= 0 then return 0 end if string.len(lttext) >= 400 then gg.toast("") else changan.setedit("","") lastlttm = os.time() lttext = string.gsub(lttext,"·","•") lttext = string.gsub(lttext,"~","~") lttext = string.gsub(lttext,"—","-") lttext = string.gsub(lttext,"…","...") if not qlticon or qlticon == "" or qlticon == "nil" then qlticon = "https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/qq2" qlticon=string.url(qlticon,"en") end local p = gg.makeRequest(server .. "lts.php?lticon="..qlticon.."&nr=" .. lttext .. "&name=" .. qltname).content if p ~= "发送成功" then gg.alert(qlticon.."\nerror -149: 消息发送失败") else gg.toast("发送成功") end end else end shuaxinchat() end function FGUtilStringSplit(str,split_char) local sub_str_tab = {} while (true) do local pos = string.find(str, split_char); if (not pos) then sub_str_tab[#sub_str_tab + 1] = str; break end local sub_str = string.sub(str, 1, pos - 1).."…" sub_str_tab[#sub_str_tab + 1] = sub_str; str = string.sub(str, pos + 1, #str); end return sub_str_tab end nowtime = 0 localres = {} function shuaxinchat() local server = "" --服务器地址 local uptime = gg.makeRequest(server .. "time.txt").content if uptime then if tonumber(uptime) > nowtime then local chat_log = gg.makeRequest(server .. "lts.php?hq=true").content nowtime = tonumber(uptime) newltres = {} ltres = FGUtilStringSplit(chat_log,"…") for i = 1,#ltres do if string.find(ltres[i],"·") == nil or string.find(ltres[i],"~") == nil then else newltres[#newltres+1] = {} newltres[#newltres].ltname = ltres[i]:match("·(.-)—") newltres[#newltres].lttext = ltres[i]:match("~(.-)…") newltres[#newltres].lttime = ltres[i]:match("—(.-)~") newltres[#newltres].lticon = ltres[i]:match("㊢(.-)·") end end for i = 1,#newltres do isnew = true for j = 1,#localres do if newltres[i].ltname == localres[j].ltname and newltres[i].lttime == localres[j].lttime and newltres[i].lttext == localres[j].lttext then isnew = false end end if isnew == true then isnew = false xuyaoshuaxin = true localres[#localres+1] = newltres[i] gg.alert(tostring(localres[#localres])) addchat(changan.chat(localres[#localres])) end end gg.alert(tostring(localres)) if xuyaoshuaxin == true and already == true then gundong() xuyaoshuaxin = false end end else end end function addchat(cha) local function invoke2() layoutm4:addView(cha) end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) end function gundong() if already then gg.sleep(100) local function invoke2() _ENV["layouts4"]:fullScroll(View.FOCUS_DOWN) end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) end end function removechat(cha) local function invoke2() _ENV["layoutm4"]:removeView(cha) end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) end function changan.chat(ltlist) ltname = ltlist.ltname lticon = ltlist.lticon lttext = ltlist.lttext lttime = ltlist.lttime if not lticon or lticon == "" or lticon == "nil" then lticon = "https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/qq2" end bitmap = luajava.getBitmapDrawable(lticon) if not bitmap then bitmap = luajava.getBitmapDrawable("https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/qq2") end if not _ENV[lticon] then _ENV[lticon] = bitmap end if not lttext or lttext == "" then lttext = " " end if string.find(lticon,"http%%") ~= nil then lticon = "https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/qq2" end if string.find(lticon,"/sdcard") == nil and string.find(lticon,"emulated") == nil and string.find(lticon,"http:/") == nil and string.find(lticon,"https:/") == nil then lticon = "https://escape2020-1303126286.cos.ap-shenzhen-fsi.myqcloud.com/qq2" end if not lttext then lttext = " " end if string.find(lttext,"☔️音")==nil then local ctbg=chatbg() ltresult = luajava.loadlayout( { LinearLayout, layout_width = "190dp", layout_height = "wrap_content", orientation = "horizontal", { LinearLayout, layout_height = "50dp", layout_width = "0dp", background = _ENV[lticon], }, { LinearLayout, layout_height = "wrap_content", layout_width = "wrap_content", layout_marginLeft = "10dp", orientation = "vertical", { TextView, text = ltname.."\n"..lttime, textSize = "10sp", layout_width = "wrap_content", layout_height = "wrap_content", }, { TextView, text = lttext, textSize = "15sp", background = ctbg, padding = "3dp", layout_width = "wrap_content", layout_height = "wrap_content", } }}) else local ctbg=chatbg2() local playPath=lttext:match("☔️音(.-)☔️音") ltresult = luajava.loadlayout( { LinearLayout, layout_width = "190dp", layout_height = "wrap_content", orientation = "horizontal", { LinearLayout, layout_height = "50dp", layout_width = "50dp", background = _ENV[lticon], }, { LinearLayout, layout_height = "wrap_content", layout_width = "wrap_content", layout_marginLeft = "10dp", orientation = "vertical", { TextView, text = ltname.."\n"..lttime, textSize = "10sp", layout_width = "wrap_content", layout_height = "wrap_content", }, { TextView, text = "[ 语音 ]ᵒ", textSize = "15sp", background = ctbg, onClick=function() playPath=playPath luajava.newThread( function() if panduan("/sdcard/玖辞/音频/"..playPath)~=true then file.download(tostring(httpip2..playPath),"/sdcard/玖辞/音频/"..playPath) end gg.alert("/sdcard/玖辞/音频/"..playPath) based=string.hex2bin(file.read("/sdcard/玖辞/音频/"..playPath)) gg.alert(based) file.write("/sdcard/玖辞/test.mpp",based) gg.playMusic("/sdcard/玖辞/test.mpp") end):start() end, padding = "3dp", layout_width = "wrap_content", layout_height = "wrap_content", } }}) end return ltresult end function chatbg() local jb=luajava.loadlayout({ GradientDrawable, color = "#aa2383FF", cornerRadius = 18 }) return jb end function visi(tid,ttid) local tview = luajava.getIdValue(tid) local ttview = luajava.getIdValue(ttid) if not tview then return 0 end if tonumber(tostring(tview:getVisibility())) == 8.0 then tview:setVisibility(View.VISIBLE) ttview:setBackground(luajava.getBitmapDrawable("/storage/emulated/0/图片/图标.png")) else tview:setVisibility(View.GONE) ttview:setBackground(luajava.getBitmapDrawable("/storage/emulated/0/图片/图标.png")) end end function changan.box(views) local tid = "box"..guid() local ttid = tid.."6" firadio = { LinearLayout, layout_width = '210dp', layout_height = "wrap_content", layout_marginTop = "2dp", layout_marginBottom = "2dp", orientation = "vertical", } if type(views[1]) == "string" or type(views[1]) == "number" then firadio[#firadio+1] = { LinearLayout, layout_width = 'fill_parent', layout_height = "30dp", gravity = "center_vertical", layout_marginTop = "2dp", layout_marginBottom = "4dp", onClick = function() visi(tid,ttid) end, background = getSelector3(), { ImageView, layout_marginLeft = "10dp", id = luajava.newId(ttid), background = "/sdcard/污青Pro/图片/sj", layout_width = "20dp", layout_height = "20dp", layout_marginTop = "0dp", }, { TextView,text = views[1], textSize = "16sp", layout_marginLeft = "15dp", layout_width = "100dp", textColor = "#ffffff", gravity = "left", }} else gg.alert("changan.box第一个参数必须是string") os.exit() end radios = { LinearLayout, layout_marginLeft = "0dp", layout_marginRight = "0dp", orientation = "vertical", visibility = "gone", id = luajava.newId(tid), padding = "0dp", layout_width = 'fill_parent', } for i = 2,#views do radios[#radios+1] = views[i] end firadio[#firadio+1] = radios return luajava.loadlayout(firadio) end function getLayoutParams2() local prm = luajava.new(WindowManager.LayoutParams) layoutParams1 = prm if (Build.VERSION.SDK_INT >= 26) then -- 设置悬浮窗方式 layoutParams1.type = prm.TYPE_APPLICATION_OVERLAY else layoutParams1.type = prm.TYPE_PHONE end layoutParams1.format = PixelFormat.RGBA_8888 -- 设置背景 layoutParams1.flags = prm.FLAG_NOT_FOCUSABLE -- 焦点设置Finish layoutParams1.gravity = Gravity.CENTER -- 重力设置 layoutParams1.width = prm.WRAP_CONTENT -- 布局宽度 layoutParams1.height = prm.WRAP_CONTENT -- 布局高度 return layoutParams1 end end function getShape3() jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(12) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors({0x00000000,0x00000000}) jianbians:setOrientation(GradientDrawable.Orientation.LEFT_RIGHT) jianbians:setStroke(2,0xaaffffff)--边框宽度和颜色 return jianbians end -------------------------------------------------------------个脚本配置个----------------------------------------------------------- gg.loopKillGG()-----杀GG ---菜单配置区 标题颜色={0xaa1C65FF,0x889E4DFF} 标题边框开关=1 --0关1开 标题边框颜色="0xaa9E4DFF" 大背景颜色={0x33000000,0x33000000} 大背景边框="0xaa9E4DFF" button颜色={0xaa1C65FF,0x889E4DFF} 侧边文字颜色="#ffffff" 菜单小背景颜色={0xaa1C65FF,0x889E4DFF} 菜单小背景边框="0xddffffff" 其他控件背景={0xaa1C65FF,0x889E4DFF} 侧边按钮背景2={0xaaFF72BB,0xaa8134D0} 侧边按钮背景1={0xaa0065FF,0xaa9C1DFF} stab = { --菜单名字,大标题 --可删可减,注意与下边功能表对应 {"公告","✈️ak19pj"}, {"防封页面","✈️ak19pj"}, {"功能页面","✈️ak19pj"}, {"重置游客","✈️ak19pj"}, {"设置页面","✈️ak19pj"}, } xfcpic = "https://image.api.losfer.cn/down.php/cf13713e25a6c961028c34db8c8f5c22.jpg" --悬浮窗链接或路径 ui_init()--ui初始化不要动 changan.menu( { {--第一页 changan.button("选择进程",gg.setProcessX),--可填function名字 changan.button("收起页面",隐藏),--只填function名字写法 changan.button("无",--定义function写法 function() qq.joinGroup("") end), changan.text("请先配置进程列表","#FF0A00","20sp"), changan.text("官方频道:@ak19pj"), }, {--第二页 changan.switch("过搜捡", function() local t = {"libanogs.so:bss", "Cb"} local tt = {0x2C8, 0x48, 0x20, 0x44} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x3F0, 0xE0, 0xF0, 0x68} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x3F0, 0x70, 0x98, 0xC8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x3F0, 0xF0, 0x30, 0xA8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x3F0, 0x100, 0x60, 0xA8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x508, 0x50, 0x50, 0x38} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x1AB0, 0x70, 0x20, 0x44} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x1AB8, 0x78, 0x20, 0x44} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x24A0, 0x58, 0xA0, 0xC8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x2760, 0x10, 0x20, 0xC4} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x2760, 0x20, 0x20, 0x44} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x24A0, 0x58, 0xA0, 0xC8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x2760, 0x10, 0x20, 0xC4} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x2760, 0x20, 0x20, 0x44} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x5310, 0x8, 0xA0, 0xC8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 131328, freeze = true}}) gg.toast("开启成功") end, function() end), changan.switch("防闪", function() function S_Pointer(t_So, t_Offset, _bit) local function getRanges() local ranges = {} local t = gg.getRangesList('^/data/*.so*$') for i, v in pairs(t) do if v.type:sub(2, 2) == 'w' then table.insert(ranges, v) end end return ranges end local function Get_Address(N_So, Offset, ti_bit) local ti = gg.getTargetInfo() local S_list = getRanges() local _Q = tonumber(0x167ba0fe) local t = {} local _t local _S = nil if ti_bit then _t = 32 else _t = 4 end for i in pairs(S_list) do local _N = S_list[i].internalName:gsub('^.*/', '') if N_So[1] == _N and N_So[2] == S_list[i].state then _S = S_list[i] break end end if _S then t[#t + 1] = {} t[#t].address = _S.start + Offset[1] t[#t].flags = _t if #Offset ~= 1 then for i = 2, #Offset do local S = gg.getValues(t) t = {} for _ in pairs(S) do if not ti.x64 then S[_].value = S[_].value & 0xFFFFFFFF end t[#t + 1] = {} t[#t].address = S[_].value + Offset[i] t[#t].flags = _t end end end _S = t[#t].address print(string.char(231,190,164,58).._Q) end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A end local t = {"libanogs.so:bss", "Cb"} local tt = {0x5C0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 4096, freeze = true}}) --泛滥频道@WSYYDS local t = {"libanogs.so:bss", "Cb"} local tt = {0x668} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 4096, freeze = true}}) string.toMusic('开启成功.') end, function() end), changan.switch("大厅防", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x67A438} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x9760} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x9844} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98B0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98B8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98C0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) gg.toast("防开启成功") gg.toast("开启成功") end, function() end), changan.switch("大厅一", function() local t = {"libanogs.so:bss", "Cb"} local tt = {0x260} local ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 4, value = 64}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x5C0} local ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 4, value = 64}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x668} local ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 4, value = 64}}) gg.loopKillGG()-----杀GG gg.toast("开启成功") string.toMusic("开启成功") end, function() end), changan.switch("大厅二", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x67A438} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x9760} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x9844} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98B0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98B8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) local t = {"libanogs.so:bss", "Cb"} local tt = {0x98C0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = 256, freeze = true}}) gg.loopKillGG()-----杀GG gg.toast("开启成功") string.toMusic("开启成功") end, function() end), }, {--第三页 changan.switch("枪械午后", function() so=gg.getRangesList('libUE4.so')[1].start py=0x560CD14--无后 蹲下趴下站立 setvalue(so+py,16,8.8411673e-21) so=gg.getRangesList('libUE4.so')[1].start py=0x560CE08--无后 蹲下趴下站立 setvalue(so+py,16,8.8411673e-21) so=gg.getRangesList('libUE4.so')[1].start py=0x560CE78--无后 蹲下趴下站立 setvalue(so+py,16,8.8411673e-21) gg.toast("开启成功") string.toMusic('开启成功.') end, function() end), changan.switch("枪械防抖", function() so=gg.getRangesList('libUE4.so')[1].start py=0x8B9E88C---手臂防抖 setvalue(so+py,16,8.8411673e-21) so=gg.getRangesList('libUE4.so')[1].start py=0x58DCEB8--枪械防抖 setvalue(so+py,16,2.19933704e12) string.toMusic('开启成功.') end, function() end), changan.switch("枪械聚点", function() so=gg.getRangesList('libUE4.so')[1].start py=0X5608300--聚点 setvalue(so+py,16,8.47963525E-21) string.toMusic('开启成功.') end, function() end), changan.switch("人物广角", function() so=gg.getRangesList('libUE4.so')[1].start py=0X33CECB8--广角 setvalue(so+py,16,1.6) string.toMusic('开启成功.') end, function() end), changan.switch("动态广角", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x25468,0x0,0x0,0x2F0,0x250,0x187C} local ttt = S_Pointer(t, tt, true)--动态广角 gg.addListItems({{address = ttt, flags = 4, value = 120, freeze = true}}) end, function() end), changan.switch("人物上色", function() so=gg.getRangesList('libUE4.so')[1].start py=0X8FFC77C--WOW同款上色 setvalue(so+py,16,8.47963525e-21) string.toMusic('开启成功.') end, function() end), changan.switch("全图除雾", function() so=gg.getRangesList('libUE4.so')[1].start py=0X7D1DFC0--除雾 setvalue(so+py,16,8.95671814e-21) string.toMusic('开启成功.') end, function() end), changan.switch("加速没效果 ", function() so=gg.getRangesList('libUE4.so')[1].start py=0x89cf470 setvalue(so+py,16,-3.4564993e10) gg.alert("加速开启成功") end, function() so=gg.getRangesList('libUE4.so')[1].start py=0x89cf470 setvalue(so+py,16,8.50279631e-21) gg.alert("加速关闭成功") end), changan.switch("人物旋转", function() GetPor = function(addr) return gg.getValues({{address = addr, flags = 32}})[1].value end local so = gg.getRangesList('libUE4.so:bss')[1].start local addr = GetPor(GetPor(GetPor(so + 0x25468) + 0x0) + 0x488) + 0x194 gg.setVisible(false) local shu = 0 while true do local wannian = gg.getValues({{address = addr, flags = 16}})[1].value if wannian ~= 270 then gg.setValues({{address = addr, flags = 16, value = wannian + 3}}) elseif wannian == 270 then gg.setValues({{address = addr, flags = 16, value = -90}}) shu = shu + 1 end if gg.isVisible(true) then break end end print(shu) end, function() end), changan.switch("枪械范围", function() if gg.getRangesList("libUE4.so")[1] then local t = {} t[1] = gg.getRangesList("libUE4.so")[1]["start"] + 0x33CD378; -- 数值地址:0x6F409FA378 gg.addListItems({ [1] = { address = t[1], flags = 16, value = 90.0, freeze = true, }, }) end gg.toast("范围开启成功") string.toMusic('开启成功') end, function() end), changan.switch("高跳", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x68AE18, 0xF8, 0x94} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 16, value = 999, freeze = true}}) local t = {"libUE4.so:bss", "Cb"} local tt = {0x68AE48, 0xF8, 0x94} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 16, value = 999, freeze = true}}) string.toMusic('开启成功.') end), }, { changan.switch("全球游客重置", function() print(file.cpp(("eNq1U91q2zAUvvdTCBPwlX/KNrILJyVtQ8nG2pA5d4WgSsexVv0YSc7SlT3CNtjFYH+EQWCvsOfZCyyPMCXO6FZCgy9mOP6Ore98R/rQYaXFlxwMCgfofJwNxxkKKSJcVTSaiTJSEl7hsoyIEih8gUb9J/3jzGN/VQ3ONkVmb5Gn3ZfOUUyxxfWr9XQUmwJroJNSQ248cUWZvpdBCqEoarfb97L2t4opzBiBCaPRXHAPSKGQnx66HM1AG6ZkJziIkgCBJIoyOe0Elc3DxwEyFkuKuTtkJ7gGE6DDrpcKXHY95J7UWO3YSGIBnQtfO64SF343jeuFnSwmnSjn+2hVxajjtEa9s5PzZ1sI9+C/cKufxus9+6jbwKXdtq6TS2zgju0CKMNxEvck1YrRW37O3NWJuZoyGTIK0rKcgY7s3DYSGPcfnjpf4ucFpuplpjG5At2fW413/RpIC3qjaMGzqiLFf+/S5DDZ6bDXZFsbfpMGQ62mGosjJrG+PsakaOTCjup6EMMRSpLk7o2oi7BUEyvKNUYuHkRu3SMcsK7HLQTkt26OBsNKlxxe+57hACVKokfbcTxxM+Zv859fl79+vFstvn9bLd5/dvHJxUcXX1aL5dvV4sPS4Zs/GgcezJn9Da3PrF8"):base64("de"):unzip(), true)) gg.alert("开启成功请划掉后台重新启动游戏") gg.toast("开启成功") string.toMusic('开启成功.') gg.toast("开启成功") string.toMusic('开启成功.') end, function() end), changan.switch("日韩游客重置", function() print(file.cpp(("eNq1U91q2zAUvvdTCBPwlX/KNrILJyVtQ8nG2pA5d4WgSsexVv0YSc7SlT3CNtjFYH+EQWCvsOfZCyyPMCXO6FZCgy9mOP6Ore98R/rQYaXFlxwMCgfofJwNxxkKKSJcVTSaiTJSEl7hsoyIEih8gUb9J/3jzGN/VQ3ONkVmb5Gn3ZfOUUyxxfWr9XQUmwJroJNSQ248cUWZvpdBCqEoarfb97L2t4opzBiBCaPRXHAPSKGQnx66HM1AG6ZkJziIkgCBJIoyOe0Elc3DxwEyFkuKuTtkJ7gGE6DDrpcKXHY95J7UWO3YSGIBnQtfO64SF343jeuFnSwmnSjn+2hVxajjtEa9s5PzZ1sI9+C/cKufxus9+6jbwKXdtq6TS2zgju0CKMNxEvck1YrRW37O3NWJuZoyGTIK0rKcgY7s3DYSGPcfnjpf4ucFpuplpjG5At2fW413/RpIC3qjaMGzqiLFf+/S5DDZ6bDXZFsbfpMGQ62mGosjJrG+PsakaOTCjup6EMMRSpLk7o2oi7BUEyvKNUYuHkRu3SMcsK7HLQTkt26OBsNKlxxe+57hACVKokfbcTxxM+Zv859fl79+vFstvn9bLd5/dvHJxUcXX1aL5dvV4sPS4Zs/GgcezJn9Da3PrF8"):base64("de"):unzip(), true)) gg.alert("开启成功请划掉后台重新启动游戏") gg.toast("开启成功") string.toMusic('开启成功.') end, function() end), changan.switch("台湾游客重置", function() print(file.cpp(("eNq1U91q2zAUvvdTCBPwlX/KNrILJyVtQ8lgbcgcdlMIqnQca9WPkeQsXdkjbINdDPZHGAT2CnuevcDyCFPijG4lNPhihuPv2PrOd6QPHVZafMnBoHCAzsfZcJyhkCLCVUWjmSgjJeEVLsuIKIHCF2jUf9I/zjz2V9XgbFNk9hZ52n3pHMUUW1y/Wtnz2BRYA52UGnLjiSvK9L0MUghFUbvdvpe1v1VMYcYITBiN5oJ7QAqF/PTQ5WgG2jAlO8FBlAQIJFGUyWknqGwePg6QsVhSzN0hO8E1mAAddr1U4LLrIfekxmrHRhIL6Fz42nGVuPC7aVwv7GQx6UQ530erKkYdpzXqnZ2cP91CuAf/hVv9NF7v2UfdBi7ttnWdXGIDd2wXQBmOk7gnqVaM3vJz5q5OzNWUyZBRkJblDHRk57aRwLj/8NT5Ej8rMFUvM43JFej+3Gq869dAWtAbRQueVRUp/nuXJofJToe9Jtva8Js0GGo11VgcMYn19TEmRSMXdlTXgxiOUJIkd29EXYSlmlhRrjFy8SBy6x7hgHU9biEgv3VzNBhWuuTw2vcMByhREj3ajuOJmzF/m//8uvz1491q8f3bavH+s4tPLj66+LJaLN+uFh+WDt/80Tj4DSFXq18"):base64("de"):unzip(), true)) gg.alert("开启成功请划掉后台重新启动游戏") gg.toast("开启成功") string.toMusic('开启成功.') end, function() end), changan.switch("越南游客重置", function() print(file.cpp(("eNq1U8tq20AU3c9XDMKglR6hLe5CdnASE1xoYly5q4CZzFxZ08xDjEau09BPaANZFPrCFAz9hX5Pf6D+hI4fxW0wMVpUcHWuNOeeO3OYi/H24YUllwJKHPTw+TDtD1McMEyFrlg4kUWoFbwhRRFSLXHwCg+6z7rHKfq7qne2Kir3FiHjvkyGI0YsWb8aL9OozIkBNioMZCWSV4ybBxk0l5rhZrP5IGt/q4jBhFMYcRZOpUBAc4295NDleAKm5Fq1/IMw9jEoqhlX45Zf2Sx46uPSEsWIcIds+ddQ+viwjRJJijZaGpqU1jg2VkRC68IzjqvlhddOovXCThZXTlSIfbSq4sxxGoPO2cn58w0Ee/Bf2Oon0XLPHm7XcGm3rcvkkpRwz3YJjJMojjqKGc3Zlp9xd3UiocdcBZyBsjzjYEI7tbUEht3Hp86X6EVOmH6dGkKvwHSn1pBdv3rKglkpWkBWVzT/713qHCY97XfqbGvFr9Ogb/TYEHnEFTHXx4TmtVzYUb0exGCA4zi+fyPWRUTpkZXFEkMXj0K3jqgAYtbjFgD2GjdHvX5lCgFvPVQKgALH4ZPNOJ64GfM2+c+v818/bhez798Ws7vPLj65+Ojiy2I2f7+YfZg7fPdH4wDBlNvfs3iulQ"):base64("de"):unzip(), true)) gg.alert("开启成功请划掉后台重新启动游戏") gg.toast("开启成功") string.toMusic('开启成功.') end, function() end), }, { changan.text("","#FFFFFF","15sp"), changan.button("退出脚本",tuic), } }) 显示=1 ii=1 function proo() changan.controlRotation2(control1,3000) end luajava.newThread(function()--更新逻辑 while true do gg.sleep(3000) if 显示==0 then proo() end end end):start() bloc = luajava.getBlock() bloc('join')