draw.text("☠️BY.素质能☠️",150,150) draw.text("@QZZQSZNSQ",210,210) function yjpz() string.toMusic('请选择游戏进程') gg.setProcessX() end local json =json local g = {} g.file = gg.getFile() g.sel = nil gqlb={"请先搜索歌曲",} idb={"1010"} SN,gc=1,nil g.config = gg.getFile():gsub("%lua$", "").."cfg" function bei() g.data = loadfile("-- WSG PRO 1.0.9(109)\n"..g.config) if g.data ~= nil then g.sel = g.data() g.data = nil end if g.sel == nil then g.sel = {"请输入歌曲名","10"} end end bei() --搜索歌曲 function start(name,sl) fw=gg.makeRequest("http://music.163.com/api/search/get?s="..name.."&type=1&offset=0&total=true&limit="..sl) return fw end --歌词 --播放音乐 function play(id,name) gg.toast("正在播放音乐:"..name,true) gg.playMusic("http://music.163.com/song/media/outer/url?id="..id..".mp3") end --停止播放 function stop() gg.toast("正在停止音乐") for i=1,100 do gg.playMusic("stop") gg.playMusic("stop") gg.playMusic("stop") end end ---- function Play(gqlb,idb) SN = gg.choice(gqlb,nil,ts) if SN == nil then XGCK =-1 else sn=gg.choice({"播放歌曲","播放并下载"},nil,"歌曲:"..gqlb[SN]) if sn == nil then end if sn == 1 then play(idb[SN],gqlb[SN]) end if sn == 2 then local XEY=gg.makeRequest("http://music.163.com/song/media/outer/url?id="..idb[SN]..".mp3").content local XEY1=gg.getFile():gsub("[^/]+$","")..gqlb[SN]..".mp3" io.open(XEY1,"w"):write(XEY) gg.alert("提示:\n\n音乐已成功下载位置:\n\n"..XEY1) end XGCK=-1 end end function zjson(jsonr) local str = jsonr -- 匹配Json Key的正则表达式 local pattern = "\"[%w]+\":" string.gsub(str, pattern, function(v) if string.find(str, v) then str = string.gsub(str, v, string.gsub(v, "\"", "")) end end) str = string.gsub(str, ":", "=") str = string.gsub(str, "%[", "{") str = string.gsub(str, "%]", "}") local data = "-- WSG PRO 1.0.9(109)\nreturn " .. str local res = load(data)() return res end function json(con) res=zjson(con) zd=res.result.songCount pd=go3-zd if pd <= 0 then else go3=zd end ts="《"..go1.."》找到"..zd.."首歌曲,当前显示"..go3.."首" gqlb={} idb={} for i=1,go3 do gqlb[i]=res.result.songs[i].name idb[i]=res.result.songs[i].id end --print(idb) end function YY998() Obtain=gg.makeRequest("https://api.uomg.com/api/rand.music?sort=热歌榜&format=json").content muchen=Obtain:match('url":"(.-)","picurl') gg.playMusic(muchen) end --主页 do local ok, err = pcall(require, '中文模块') if not ok then error('中文模块加载失败,请确保是使用RLGG执行,或者尝试重启RLGG') end end -- 查看映射关系请看 https://gitee.com/rlyun/rlgg/tree/master/%E4%B8%AD%E6%96%87%E6%A8%A1%E5%9D%97 print(中文函数()) --创建自定义中文函数 中文函数({ 自定义1=print, 自定义2=gg.alert, }) 打印('自定义1==print',自定义1==print) 语音("欢迎使用BY.素质能lua") 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 end return _S end local _A = string.format('0x%X', Get_Address(t_So, t_Offset, _bit)) return _A 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 getFloat(addr) local tt={} tt[1]={} tt[1].address=addr tt[1].flags=16 return gg.getValues(tt)[1].value end function getZZ(addr) local tt={} tt[1]={} tt[1].address=addr tt[1].flags=4 return gg.getValues(tt)[1].value end function writeFloat(addr,value) local tt={} tt[1]={} tt[1].address=addr tt[1].flags=16 tt[1].value=value gg.setValues(tt) end function HaoGe(Nc,Type,Search,Write) gg.clearResults() gg.setRanges(Nc) gg.setVisible(false) gg.searchNumber(Search[1][1],Type) local count=gg.getResultCount() local result=gg.getResults(count) gg.clearResults() local data={} local base=Search[1][2] if(count>0)then for i,v in ipairs(result)do v.isUseful=true end for k=2,#Search do local tmp={} local offset=Search[k][2]-base local num=Search[k][1] for i,v in ipairs(result)do tmp[#tmp+1]={} tmp[#tmp].address=v.address+offset tmp[#tmp].flags=v.flags end tmp=gg.getValues(tmp) for i,v in ipairs(tmp)do if(tostring(v.value)~=tostring(num))then result[i].isUseful=false end end end for i,v in ipairs(result)do if(v.isUseful)then data[#data+1]=v.address end end if(#data>0)then gg.toast("\n found"..#data.."data\n Start offset") local t={} local base=Search[1][2] for i=1,#data do for k,w in ipairs(Write)do offset=w[2]-base t[#t+1]={} t[#t].address=data[i]+offset t[#t].flags=Type t[#t].value=w[1] if(w[3]==true)then local item={} item[#item+1]=t[#t] item[#item].freeze=true gg.addListItems(item) end end end gg.setValues(t) gg.sleep(400) gg.toast("\n"..Name.."success\n Altogether"..#t.."data") else gg.toast("\n"..Name.."failure") return false end else gg.toast("\n"..Name.."failure") return false 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 SearchWrite(Search, Write, Type) gg.clearResults() gg.setVisible(false) gg.searchNumber(Search[1][1], Type) local count = gg.getResultCount() local result = gg.getResults(count) gg.clearResults() local data = {} local base = Search[1][2] if (count > 0) then for i, v in ipairs(result) do v.isUseful = true end for k=2, #Search do local tmp = {} local offset = Search[k][2] - base local num = Search[k][1] for i, v in ipairs(result) do tmp[#tmp+1] = {} tmp[#tmp].address = v.address + offset tmp[#tmp].flags = v.flags end tmp = gg.getValues(tmp) for i, v in ipairs(tmp) do if ( tostring(v.value) ~= tostring(num) ) then result[i].isUseful = false end end end for i, v in ipairs(result) do if (v.isUseful) then data[#data+1] = v.address end end if (#data > 0) then local t = {} local base = Search[1][2] for i=1, #data do for k, w in ipairs(Write) do offset = w[2] - base t[#t+1] = {} t[#t].address = data[i] + offset t[#t].flags = Type t[#t].value = w[1] if (w[3] == true) then local item = {} item[#item+1] = t[#t] item[#item].freeze = true gg.addListItems(item) end end end gg.setValues(t) else return false end else return false end end function Fxs(Search, Write,Neicun,Mingcg,Shuzhiliang) gg.clearResults() gg.setRanges(Neicun) gg.setVisible(false) gg.searchNumber(Search[1][1], Search[1][3]) local count = gg.getResultCount() local result = gg.getResults(count) gg.clearResults() local data = {} local base = Search[1][2] if (count > 0) then for i, v in ipairs(result) do v.isUseful = true end for k=2, #Search do local tmp = {} local offset = Search[k][2] - base local num = Search[k][1] for i, v in ipairs(result) do tmp[#tmp+1] = {} tmp[#tmp].address = v.address + offset tmp[#tmp].flags = Search[k][3] end tmp = gg.getValues(tmp) for i, v in ipairs(tmp) do if ( tostring(v.value) ~= tostring(num) ) then result[i].isUseful = false end end end for i, v in ipairs(result) do if (v.isUseful) then data[#data+1] = v.address end end if (#data > 0) then gg.toast(Mingcg.."搜索到"..#data.."条数据") local t = {} local base = Search[1][2] if Shuzhiliang == "" and Shuzhiliang > 0 and Shuzhiliang < #data then Shuzhiliang=Shuzhiliang else Shuzhiliang=#data end for i=1, Shuzhiliang do for k, w in ipairs(Write) do offset = w[2] - base t[#t+1] = {} t[#t].address = data[i] + offset t[#t].flags = w[3] t[#t].value = w[1] if (w[4] == true) then local item = {} item[#item+1] = t[#t] item[#item].freeze = true gg.addListItems(item) end end end gg.setValues(t) gg.toast(Mingcg.."已修改"..#t.."条数据") gg.addListItems(t) else gg.toast(Mingcg.."开启失败", false) return false end else gg.toast("搜索失败") return false 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"] 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 readPointer = function(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 gg.edits = function(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 fastsearch(search, write) gg.setVisible(false) gg.clearResults() gg.setRanges(search[1][3]) gg.searchNumber(search[1][1], search[1][2]) if gg.getResultsCount() == 0 then gg.toast("Not Found") return false else local result = gg.getResults(gg.getResultsCount()) gg.clearResults() for i = 2, #search do local mtp = {} for w, r in ipairs(result) do mtp[#mtp + 1] = { address = r.address + search[i][2], flags = search[i][3] } end mtp = gg.getValues(mtp) local hook = {} for w, r in ipairs(mtp) do if r.value == search[i][1] then hook[#hook + 1] = result[w] end end result = hook end if #result > 0 then local tb = {{}, {}} for i, v in ipairs(result) do --- 遍历每个结果 for _, vv in ipairs(write) do local p = {address = v.address + vv[2], flags = vv[3], value = vv[1], freeze = vv[4]} if vv[4] then --- true 就是冻结 table.insert(tb[2], p) else table.insert(tb[1], p) end end end gg.addListItems(tb[2]) gg.setValues(tb[1]) gg.toast("获取成功" .. (#tb[1] + #tb[2]) .. "条结果") else gg.toast("Not Found") end end end function PS() 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 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 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 ----------------------------------破解by:无情 AS防封项目电报主频道:@asnbyyds 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) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) 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 ckimg = { "wangyang2",--图片 "jiao1", "jiao2", "exit", } for i = 1,#ckimg do jindu = i checkimg(ckimg[i]) end local 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 jiaojiao=luajava.getStateListDrawable() jiaojiao:addState({ android.R.attr.state_pressed }, luajava.getBitmapDrawable("/sdcard/长安/图片/jiao1")) -- 点击时候的背景 jiaojiao:addState({ -android.R.attr.state_pressed }, luajava.getBitmapDrawable("/sdcard/长安/图片/jiao2")) -- 没点击的背景 slctb = luajava.loadlayout { GradientDrawable, color = "#00000000", cornerRadius = 0 } slcta = luajava.loadlayout { GradientDrawable, color = "#33ffffff", cornerRadius = 0 } slctc = luajava.loadlayout { GradientDrawable, color = "#11ffffff", cornerRadius = 0 } slctd = luajava.loadlayout { GradientDrawable, color = "#55ffffff", cornerRadius = 0 } slcte = luajava.loadlayout { GradientDrawable, color = "#11ffffff", cornerRadius = 0 } slctf = luajava.loadlayout { GradientDrawable, color = "#00000000", cornerRadius = 0 } function getSelector3() selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, slcte) -- 点击时候的背景 selector:addState({ -android.R.attr.state_pressed }, slctf) -- 没点击的背景 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) local isswitch YoYoImpl = luajava.getYoYoImpl() changan.switch = function(sview) if isswitch then return false end 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 suofang = function(v, event) local Action = event:getAction() if Action == MotionEvent.ACTION_DOWN then isMove = false RawX = event:getRawX() RawY = event:getRawY() x = mainLayoutParams.height y = mainLayoutParams.width if x==0 or x==-2 then x=810 y=950 end elseif Action == MotionEvent.ACTION_MOVE then isMove = true mubx=tonumber(x) + (event:getRawY() - RawY) if mubx>=300 and mubx<=810 then mainLayoutParams.height = mubx end muby=tonumber(y) + (event:getRawX() - RawX) if muby>=300 and muby<=950 then mainLayoutParams.width = muby end window:updateViewLayout(floatWindow, mainLayoutParams) end end isswitch = true dingbian = luajava.loadlayout({ LinearLayout, id = "顶边", visibility = "gone", layout_height = "wrap_content", layout_width = "wrap_content", orientation = "horizontal", background = { GradientDrawable, color = "#00613703", cornerRadius = 0 }, gravity="center_horizontal", {LinearLayout, id=luajava.newId("jm1"), { TextView, text = stab[1], id=luajava.newId("jm1t"), layout_height = "28dp", layout_width = "90dp", layout_marginTop="0dp", layout_marginBottom="0dp", gravity="center", onClick = function() 切换(1) end, onTouch = hanshu }}, {LinearLayout, id=luajava.newId("jm2"), {TextView, text = stab[2], id=luajava.newId("jm2t"), layout_height = "28dp", layout_width = "90dp", layout_marginTop="0dp", layout_marginBottom="0dp", gravity="center", onClick = function() 切换(2) end, onTouch = hanshu }}, {LinearLayout, id=luajava.newId("jm3"), {TextView, id=luajava.newId("jm3t"), text = stab[3], layout_height = "28dp", layout_width = "90dp", layout_marginTop="0dp", layout_marginBottom="0dp", gravity="center", onClick = function() 切换(3) end, onTouch = hanshu }}, }) layout1 = luajava.loadlayout({ ScrollView, --fillViewport="true", padding = "0dp", id = "layout1", visibility = "visible", layout_width = "250dp", layout_height = "wrap_content", orientation = "horizontal", { LinearLayout, id = "layouta", gravity="top", layout_width = 'match_parent', layout_height = "match_parent", orientation = "vertical", } }) layout2 = luajava.loadlayout({ ScrollView, fillViewport="true", padding = "0dp", id = "layout2", visibility = "gone", layout_width = "250dp", layout_height = "wrap_content", orientation = "horizontal", { LinearLayout, id = "layoutb", layout_width = 'match_parent', layout_height = "match_parent", orientation = "vertical", } }) layout3 = luajava.loadlayout({ ScrollView, fillViewport="true", padding = "0dp", id = "layout3", visibility = "gone", layout_width = "250dp", layout_height = "wrap_content", orientation = "horizontal", { LinearLayout, id = "layoutc", layout_width = 'match_parent', layout_height = "match_parent", orientation = "vertical", } }) suof=luajava.loadlayout({ImageView, src="/sdcard/长安/图片/wangyang2", layout_width="48dp", layout_height="48dp", }) suof.onTouch=suofang ckou = luajava.loadlayout({ LinearLayout, id = "chuangk", visibility = "gone", layout_width = "match_parent", layout_height = "match_parent", orientation = "vertical", background = { GradientDrawable, color = "#00613703", cornerRadius = 0 }, dingbian,layout1,layout2,layout3 }) title = luajava.loadlayout({LinearLayout, id = "title", visibility = "gone", gravity="center_vertical", { TextView, text = stext, id = "exit", style="bold", textColor="#ffffff", gravity="center", textSize = "20sp", layout_marginTop = "4dp", layout_marginBottom = "4dp", layout_width = "270dp", },{ ImageView, --id = "exit", --src = "/sdcard/长安/图片/exit", layout_width = "0dp", layout_height = "0dp", layout_marginTop = "0dp", layout_marginLeft = "0dp", }}) motion=luajava.loadlayout({FrameLayout, id = "motion", layout_width = "match_parent", layout_height="match_parent", gravity="center", {LinearLayout, --id = "motion", layout_width = "match_parent", layout_height="match_parent", orientation = "vertical", gravity = "center_vertical", layout_height = "wrap_content", { LinearLayout, orientation="horizontal", { ImageView, id = "control", background = "/sdcard/长安/图片/wangyang2", layout_width = "48dp", layout_height = "48dp", }, {LinearLayout, background = luajava.loadlayout {GradientDrawable,color = "#99000000",cornerRadius = 40}, layout_width = "match_parent", layout_height = "270dp", orientation = "vertical", visibility="gone", id="chuangkou", gravity = "center", title, ckou }, } },{LinearLayout, background=jiaojiao, id="jiaobiao", visibility="gone", layout_width = "15dp", layout_height = "16dp", layout_gravity="right|bottom", onClick=function() end } }) floatWindow = {LinearLayout, layout_height = "270dp", layout_height = "318dp", motion} local function invoke() local ok local RawX, RawY, x, y floatWindow = luajava.loadlayout(floatWindow) local function invoke2() block('start') for i = 1,#sview[1] do layouta:addView(sview[1][i]) end for i = 1,#sview[2] do layoutb:addView(sview[2][i]) end for i = 1,#sview[3] do layoutc:addView(sview[3][i]) 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 exit.onClick = function() gg.toast("悬浮窗已退出") window:removeView(floatWindow) luajava.setFloatingWindowHide(false) end local isMove jiaobiao.onTouch = suofang control.onTouch = hanshu end return invoke(swib1,swib2) end 当前ui = 1 function 切换(x) 当前ui=x jm1t=luajava.getIdValue("jm1t") jm2t=luajava.getIdValue("jm2t") jm3t=luajava.getIdValue("jm3t") luajava.runUiThread(function() if 当前ui == 1 then layout1:setVisibility(View.VISIBLE) layout2:setVisibility(View.GONE) layout3:setVisibility(View.GONE) jm1t:setText(string.fromHtml(""..stab[1])) jm2t:setText(string.fromHtml(""..stab[2])) jm3t:setText(string.fromHtml(""..stab[3])) elseif 当前ui == 2 then layout2:setVisibility(View.VISIBLE) layout1:setVisibility(View.GONE) layout3:setVisibility(View.GONE) jm2t:setText(string.fromHtml(""..stab[2])) jm1t:setText(string.fromHtml(""..stab[1])) jm3t:setText(string.fromHtml(""..stab[3])) elseif 当前ui == 3 then layout3:setVisibility(View.VISIBLE) layout2:setVisibility(View.GONE) layout1:setVisibility(View.GONE) jm3t:setText(string.fromHtml(""..stab[3])) jm2t:setText(string.fromHtml(""..stab[2])) jm1t:setText(string.fromHtml(""..stab[1])) end end) luajava.runUiThread(function() if 当前ui == 1 then layout1:setVisibility(View.VISIBLE) YoYoImpl:with("FadeIn"):duration(200):playOn(layout1) elseif 当前ui == 2 then layout2:setVisibility(View.VISIBLE) YoYoImpl:with("FadeIn"):duration(200):playOn(layout2) elseif 当前ui == 3 then layout3:setVisibility(View.VISIBLE) YoYoImpl:with("FadeIn"):duration(200):playOn(layout3) end --floatWindow:setBackground(beij) end) end 显示 = 0 beij = luajava.loadlayout({ GradientDrawable, color = "#00000000", cornerRadius = 0 }) beij2 = luajava.loadlayout({ GradientDrawable, color = "#00000000", cornerRadius = 0 }) 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 function 隐藏() luajava.runUiThread(function() if tonumber(tostring(dingbian:getVisibility())) == 8.0 then chuangk:setVisibility(View.VISIBLE) chuangkou:setVisibility(View.VISIBLE) jiaobiao:setVisibility(View.VISIBLE) if not yck then ycg=810 yck=950 end mainLayoutParams.height=ycg mainLayoutParams.width=yck window:updateViewLayout(floatWindow, mainLayoutParams) dingbian:setVisibility(View.VISIBLE) luajava.runUiThread(function() mainLayoutParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL window:updateViewLayout(floatWindow, mainLayoutParams) end) YoYoImpl:with("SlideInDown"):duration(100):playOn(dingbian) luajava.runUiThread(function() title:setVisibility(View.VISIBLE) YoYoImpl:with("SlideInLeft"):duration(100):playOn(title) if 当前ui == 1 then layout1:setVisibility(View.VISIBLE) YoYoImpl:with("SlideInLeft"):duration(100):playOn(layout1) elseif 当前ui == 2 then layout2:setVisibility(View.VISIBLE) YoYoImpl:with("SlideInLeft"):duration(100):playOn(layout2) elseif 当前ui == 3 then layout3:setVisibility(View.VISIBLE) YoYoImpl:with("SlideInLeft"):duration(100):playOn(layout3) end floatWindow:setBackground(beij) end) else luajava.runUiThread(function()mainLayoutParams.flags = LayoutParams.FLAG_NOT_FOCUSABLE window:updateViewLayout(floatWindow, mainLayoutParams) end) title:setVisibility(View.GONE) floatWindow:setBackground(beij2) ycg=mainLayoutParams.height yck=mainLayoutParams.width mainLayoutParams.height=200 mainLayoutParams.width=200 window:updateViewLayout(floatWindow, mainLayoutParams) jiaobiao:setVisibility(View.GONE) chuangk:setVisibility(View.GONE) chuangkou:setVisibility(View.GONE) dingbian:setVisibility(View.GONE) layout1:setVisibility(View.GONE) layout2:setVisibility(View.GONE) layout3:setVisibility(View.GONE) end end) end mainLayoutParams = getLayoutParams() function newradio(radio) firadio={LinearLayout, layout_width = 'match_parent', layout_height = "match_parent", orientation="horizontal" } if type(radio[1])=="string" or type(radio[1])=="number" then --firadio[#firadio+1]={TextView,text=radio[1],textColor="#ffffff",} end radios={RadioGroup,orientation="horizontal",gravity="center",background="#00C92E37",layout_width = 'match_parent',} for i=2,#radio do radios[#radios+1]={ RadioButton, text=radio[i][1], textColor="#ffffff", textSize="11sp", onClick=function() luajava.newThread(function() pcall(radio[i][2]) end):start() end, } end firadio[#firadio+1]=radios return luajava.loadlayout(firadio) 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] = "开" func1() else _ENV[name] = "关" func2() end end end end function newcheck(radio) firadio={LinearLayout,layout_width = 'match_parent',layout_height = "match_parent",orientation="vertical"} if type(radio[1])=="string" or type(radio[1])=="number" then firadio[#firadio+1]={TextView,text=radio[1],textColor="#ffffff",} end radios={LinearLayout,orientation="horizontal",gravity="center",background="#00C92E37",layout_width = 'match_parent',} for i=2,#radio do local name = radio[i][1] local func1 = radio[i][2] local func2 = radio[i][3] local nid = radio[i][4] if not name then name = "未设置" end nid = name..guid() local func = 开关(nid,func1,func2) radios[#radios+1]={CheckBox, text=radio[i][1], textSize="9sp", textColor="#ffffff", onClick=function() luajava.newThread(function() pcall(func) end):start() end, } end firadio[#firadio+1]=radios return luajava.loadlayout(firadio) end -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- stext="☠️BY.素质能☠️"---大标题 stab={"防封页面","国际服功能","音乐菜单"}---三个菜单名字 changan.switch({---newcheck多选 一个一行 newradio单选 { luajava.loadlayout({TextView, text="", gravity="center", layout_height="match_parent", layout_width="match_parent", textColor="#ffffff", textSize="9sp", }), newcheck({nil, {"防窥屏", function() 禁止录屏() 语音("防窥屏开启成功") gg.toast("防窥屏开启成功") end, function() 解除禁止录屏() 语音("防窥屏关闭成功") gg.toast("防窥屏关闭成功") end },{"点我选择进程", function() string.toMusic('已配置修改器 请选择游戏进程') gg.setProcessX() gg.setConfig("隐藏辅助", 23) gg.setConfig("运行守护", 0) gg.setConfig("冻结间隔", 33000) end, function() end } }), newradio({nil, {"全局离线[开]", function() gg.clearResults() gg.setRanges(16384) gg.searchNumber("1445669757", gg.TYPE_DWORD, false, gg.SIGN_EQUAL, 0, -1) gg.refineNumber("", gg.TYPE_DWORD) gg.getResults(50000) gg.editAll("16843522", gg.TYPE_DWORD) gg.alert("全局离线开启成功") 语音("全局离线开启成功") gg.toast("全局离线开启成功") end, },{"全局离线[关]", function() gg.clearResults() gg.setRanges(16384) gg.searchNumber("16843522", gg.TYPE_DWORD, false, gg.SIGN_EQUAL, 0, -1) gg.refineNumber("", gg.TYPE_DWORD) gg.getResults(50000) gg.editAll("1445669757", gg.TYPE_DWORD) gg.alert("国际服全局离线关闭成功") string.toMusic('全局离线关闭成功') gg.alert("全局离线关闭成功") 语音("全局离线关闭成功") gg.toast("全局离线关闭成功") end }, }), newcheck({nil, {"大厅防封1『防enen』", function() gg.clearResults() gg.setRanges(16384) gg.searchNumber("282584257676671", 32, false, gg.SIGN_EQUAL, 0, -1) gg.searchNumber("282584257676671", 32, false, gg.SIGN_EQUAL, 0, -1) gg.getResults(10000) gg.editAll("3,561,941,515,270,348,629", 32) gg.setRanges(gg.REGION_CODE_APP) gg.setVisible(false) gg.searchNumber("h7f 45 4c 46 02 01 01 00 00 00 00 00 00", gg.TYPE_BYTE) gg.getResults(9999) gg.editAll("h00 00 80 D2 C0 03 5F D6", gg.TYPE_BYTE) gg.clearResults() gg.setRanges(gg.REGION_CODE_APP) gg.searchNumber("h03 00 B7 00 01 00 00 00", gg.TYPE_BYTE) gg.getResults(9999) gg.editAll("h00 00 80 D2 C0 03 5F D6", gg.TYPE_BYTE) so=gg.getRangesList('libUE4.so')[1].start py=0x12 setvalue(so+py,2,183) function setvalue(address,flags,value) local refinevalues={} refinevalues[1]={} refinevalues[1].address=address refinevalues[1].flags=flags refinevalues[1].value=value gg.setValues(refinevalues) end so=gg.getRangesList('libanogs.so')[1].start setvalue(so + "0x5934B4", 4, "h 00 00 00 00") setvalue(so + "0x5935BC", 4, "h 00 00 00 00") setvalue(so + "0x59373C", 4, "h 00 00 00 00") setvalue(so + "0x593B74", 4, "h 00 00 00 00") setvalue(so + "0x594694", 4, "h 00 00 00 00") setvalue(so + "0x591420", 4, "h 00 00 00 00") setvalue(so + "0x591680", 4, "h 00 00 00 00") setvalue(so + "0x591830", 4, "h 00 00 00 00") setvalue(so + "0x591A20", 4, "h 00 00 00 00") setvalue(so + "0x591DE8", 4, "h 00 00 00 00") setvalue(so + "0x592164", 4, "h 00 00 00 00") setvalue(so + "0x592710", 4, "h 00 00 00 00") qmnb = { {["memory"] = 16384}, {["name"] = ""}, {["value"] = 282584257676671, ["type"] = 32}, {["lv"] = 65794, ["offset"] = 4, ["type"] = 32}, } qmxg = { {["value"] = 0, ["offset"] = 0, ["type"] = 32}, {["value"] = 0, ["offset"] = 4, ["type"] = 32}, {["value"] = 0, ["offset"] = 8, ["type"] = 32}, {["value"] = 0, ["offset"] = 12, ["type"] = 32}, {["value"] = 0, ["offset"] = 16, ["type"] = 32}, {["value"] = 0, ["offset"] = 20, ["type"] = 32}, {["value"] = 0, ["offset"] = 24, ["type"] = 32}, {["value"] = 0, ["offset"] = 32, ["type"] = 32}, {["value"] = 0, ["offset"] = 40, ["type"] = 32}, {["value"] = 0, ["offset"] = 52, ["type"] = 32}, {["value"] = 0, ["offset"] = 56, ["type"] = 32}, } xqmnb(qmnb) so=gg.getRangesList('libUE4.so')[1].start py=0x12 setvalue(so+py,1,-73) so=gg.getRangesList('libUE4.so')[1].start py=0x80D80BC setvalue(so+py,2,0) so=gg.getRangesList('libUE4.so')[1].start py=0x319DE90 setvalue(so+py,2,0) gg.clearResults() gg.setRanges(16384) gg.searchNumber('1702249838',gg.TYPE_DWORD,false,gg.SIGN_EQUAL,0,-1) gg.searchNumber('1702249838',gg.TYPE_DWORD,false,gg.SIGN_EQUAL,0,-1) jg=gg.getResults(100) sl=gg.getResultCount() for i = 1, sl do dzy=jg[i].address gg.addListItems({[1] = {address = dzy,flags = gg.TYPE_DWORD,freeze = true,value = 0}}) end gg.clearResults() gg.setRanges(16384) gg.searchNumber('1934189056;1634616675;1684368482;1634100548;7629941',gg.TYPE_DWORD,false,gg.SIGN_EQUAL,0,-1) gg.searchNumber('1934189056;1634616675;1684368482;1634100548;7629941',gg.TYPE_DWORD,false,gg.SIGN_EQUAL,0,-1) jg=gg.getResults(100) sl=gg.getResultCount() for i = 1, sl do dzy=jg[i].address gg.addListItems({[1] = {address = dzy,flags = gg.TYPE_DWORD,freeze = true,value = 0}}) end gg.alert("大厅防封1开启成功") 语音("大厅防封1开启成功") gg.toast("大厅防封1开启成功") end, function() gg.alert("无法关闭") end },{"大厅防封2『防AR』", function() gg.alert("未更新") 语音("未更新") gg.toast("未更新") end, function() gg.alert("无法关闭") end },{"大厅防封3『不知道防啥』", function() gg.alert("未更新") 语音("未更新") gg.toast("未更新") end, function() gg.alert("无法关闭") end }, }), },{--------------以下是列表二,跟上面的一样 内容自填 newradio({nil, {"加速[开]", function() so=gg.getRangesList('libUE4.so')[1].start py=0x7F4B3CC setvalue(so+py,4,505453825) gg.alert("人物加速开启成功") 语音("人物加速开启成功") gg.toast("人物加速开启成功") end },{"加速[关]", function() so=gg.getRangesList("libUE4.so")[1].start py=0x7F4B3CC setvalue(so+py,4,505453824) gg.alert("人物加速关闭成功") 语音("人物加速关闭成功") gg.toast("人物加速关闭成功") end }, }), newcheck({nil, {"无后", function() so=gg.getRangesList('libUE4.so')[1].start py=0x4E43488 --79974820 setvalue(so+py,4,449318186) gg.alert("枪械无后开启成功") 语音("枪械无后开启成功") gg.toast("枪械无后开启成功") end, function() gg.alert("无法关闭") end },{"防抖", function() so=gg.getRangesList('libUE4.so')[1].start py=0x5A292B8 setvalue(so+py,4,1409287170) gg.alert("枪械防抖开启成功") 语音("枪械防抖开启成功") gg.toast("枪械防抖开启成功") end, function() gg.alert("无法关闭") end },{"聚点", function() so=gg.getRangesList('libUE4.so')[1].start py=0x4E40E10 setvalue(so+py,4,505425152) gg.alert("枪械聚点开启成功") 语音("枪械聚点开启成功") gg.toast("枪械聚点开启成功") end, function() gg.alert("无法关闭") end },{"瞬击", function() so=gg.getRangesList('libUE4.so')[1].start py=0x7F86B3C --131743832 setvalue(so+py,4,506015752) gg.alert("枪械瞬击开启成功") 语音("枪械瞬击开启成功") gg.toast("枪械瞬击开启成功") end, function() gg.alert("无法关闭") end },{"广角", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x39E20, 0x0, 0x2E8, 0x160, 0x2CC} local ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 500}}) gg.alert("人物广角开启成功") 语音("人物广角开启成功") gg.toast("人物广角开启成功") end, function() gg.alert("无法关闭") end }, }), newcheck({nil, {"除雾", function() so=gg.getRangesList("libUE4.so")[1].start py=0x7082E5C setvalue(so+py,4,706675684) gg.alert("全图除雾开启成功") 语音("全图除雾开启成功") gg.toast("全图除雾开启成功") end, function() gg.alert("无法关闭") end },{"范围", function() KEG=gg.prompt({'请输入范围大小(建议50~80),范围越大Bug越多'},{[1]='70'},{[1]='number'}) if KEG == nil or KEG[1] == '' or KEG[1] == '0' then gg.toast("❌范围取消") else so=gg.getRangesList('libUE4.so')[1].start py=0x2F36F58 setvalue(so+py,16,KEG[1]) string.toMusic("范围\n开启成功") end gg.alert("自改范围开启成功") 语音("自改范围开启成功") gg.toast("自改范围开启成功") end, function() gg.alert("无法关闭") end },{"特效", function() gg.clearResults() gg.setRanges(gg.REGION_ANONYMOUS) gg.searchNumber("10;11", gg.TYPE_FLOAT, false) gg.searchNumber("11", gg.TYPE_FLOAT, false) gg.getResults(200) gg.editAll("10", gg.TYPE_FLOAT) gg.toast("特效增大正在开启") gg.clearResults() gg.setRanges(gg.REGION_CODE_APP) gg.searchNumber("-305132800;-409010176;-509587455;-442564256;-443547640;-444334072", gg.TYPE_DWORD, false) gg.searchNumber("-305132800", gg.TYPE_DWORD, false) gg.getResults(200) gg.editAll("0", gg.TYPE_FLOAT) gg.alert("特效增大开启成功") 语音("特效增大开启成功") gg.toast("特效增大开启成功") end, function() gg.alert("无法关闭") end },{"秒趴", function() qmnb = { {["memory"] = 32}, {["name"] = "秒趴已开启"}, {["value"] = 1068708659, ["type"] = 32}, {["lv"] = 4590068740424885862, ["offset"] = -4, ["type"] = 32}, {["lv"] = 4586465858796126209, ["offset"] = -8, ["type"] = 32}, } qmxg = { {["value"] = 999, ["offset"] = 0, ["type"] = 16}, } xqmnb(qmnb) gg.alert("人物秒趴开启成功") 语音("人物秒趴开启成功") gg.toast("人物秒趴开启成功") end, function() gg.alert("无法关闭") end },{"地震", function() gg.searchNumber("0.20000000298~0.30000001192F;53.0F;30.0F;1.0F::512", gg.TYPE_FLOAT, false, gg.SIGN_EQUAL, 0, -1, 0) gg.processResume() revert = gg.getResults(100, nil, nil, nil, nil, nil, nil, nil, nil) local t = gg.getResults(100, nil, nil, nil, nil, nil, nil, nil, nil) for i, v in ipairs(t) do if v.flags == gg.TYPE_FLOAT then v.value = "25" v.freeze = true end end gg.addListItems(t) t = nil gg.processResume() --全枪地震 gg.alert("地震开启成功") 语音("地震开启成功") gg.toast("地震开启成功") end, function() gg.alert("无法关闭") end }, }), newcheck({nil, {"变大", function() t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x9C8,0x170,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"}--挽念电报群@PMKNB666 tt = {0x2B7760,0x6E0,0x310,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x3D8928,0x540,0xCB0,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x6C8,0x170,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B79F8,0x7A0,0x310,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x310,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0xD90,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0xA10,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0x690,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x1110,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0x310,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x139000,0x878,0x8E0,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x690,0x180,0x0,0x50} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x9C8,0x170,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B7760,0x6E0,0x310,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x3D8928,0x540,0xCB0,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x6C8,0x170,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B79F8,0x7A0,0x310,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x310,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0xD90,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0xA10,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0x690,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x1110,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0x310,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x139000,0x878,0x8E0,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x690,0x180,0x0,0x58} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x9C8,0x170,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B7760,0x6E0,0x310,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x3D8928,0x540,0xCB0,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x390DC8,0x6C8,0x170,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B79F8,0x7A0,0x310,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0x310,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x10A0,0xD90,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0xA10,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"} tt = {0x2B76D8,0x1220,0x690,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"}--贫民窟@PMKNB666 tt = {0x2B76D8,0x10A0,0x1110,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"}--贫民窟@PMKNB666 tt = {0x2B76D8,0x1220,0x310,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) t = {"libUE4.so:bss", "Cb"}--贫民窟@PMKNB666 tt = {0x139000,0x878,0x8E0,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true)--贫民窟@PMKNB666 gg.setValues({{address = ttt, flags = 16, value = 2}}) local t = {"libUE4.so:bss", "Cb"}--贫民窟电报频道@PMKNB666 tt = {0x2B76D8,0x10A0,0x690,0x180,0x0,0x54} ttt = S_Pointer(t, tt, true) gg.setValues({{address = ttt, flags = 16, value = 2}}) gg.alert("枪械变大开启成功") 语音("枪械变大开启成功") gg.toast("枪械变大开启成功") end, function() gg.alert("无法关闭") end },{"爬墙", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x39E20, 0x0, 0x78, 0x2E8, 0x200, 0x2F0} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 16, value = 999, freeze = true}}) gg.alert("人物爬墙开启成功") 语音("人物爬墙开启成功") gg.toast("人物爬墙开启成功") end, function() gg.alert("无法关闭") end },{"飞天", function() gg.clearResults() gg.setRanges(gg.REGION_ANONYMOUS) gg.searchNumber("1.0;45.0;443.0;55.0:17", gg.TYPE_FLOAT, false, gg.SIGN_EQUAL, 0, -1, 0) gg.refineNumber("1.0", gg.TYPE_FLOAT, false, gg.SIGN_EQUAL, 0, -1, 0) revert = gg.getResults(20, nil, nil, nil, nil, nil, nil, nil, nil) gg.editAll("0", gg.TYPE_FLOAT) gg.clearResults() gg.alert("人物飞天开启成功") 语音("人物飞天开启成功") gg.toast("人物飞天开启成功") end, function() gg.alert("无法关闭") end },{"无后", function() so=gg.getRangesList('libUE4.so')[1].start py=0x4E43488 --79974820 setvalue(so+py,4,449318186) gg.alert("100%无后开启成功") 语音("100%无后开启成功") gg.toast("100%无后开启成功") end, function() gg.alert("无法关闭") end },{"防抖", function() so=gg.getRangesList("libUE4.so")[1].start py=0x7E3CEE0 setvalue(so+py,4,839123713) gg.alert("100%防抖开启成功") 语音("100%防抖开启成功") gg.toast("100%防抖开启成功") end, function() gg.alert("无法关闭") end }, }), },{--------------以下是列表三 newradio({nil, {"搜索音乐", function() search = gg.prompt({ "输入要搜索的歌曲\n可加上歌手名字", "设置显示数量(数字)", },g.sel,{ "text", }) if not search then return end gg.saveVariable(search,g.config) bei() go1=search[1] go3=search[2] jg=start(go1,go3) if jg.code == 200 then fh=jg.content fh=json(fh) --print(fh) Play(gqlb,idb) else function inspect() gg.alert("访问网络异常,错误代码:\n\n"..jg.code) end if not pcall(inspect) then print("网络异常,请先连接上网络") os.exit() end end XGCK=-1 end },{"关闭播放", function() gg.playMusic("stop") gg.playMusic("stop") gg.playMusic("stop") end }, }), }}) luajava.runUiThread(function() luajava.getIdValue("jm1t"):setText(string.fromHtml(""..stab[1])) luajava.getIdValue("jm2t"):setText(string.fromHtml(""..stab[2])) luajava.getIdValue("jm3t"):setText(string.fromHtml(""..stab[3])) end) gg.setVisible(false) luajava.setFloatingWindowHide(true) local block = luajava.getBlock() block("join")