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 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 local Offset_Yx = function(Tab,KT) gg.setVisible(false) gg.clearResults() gg.setRanges(Tab["内存"]) gg.searchNumber(Tab["主特征码"][1], Tab["主特征码"][2], false, gg.SIGN_EQUAL, 0, -1, 0) local results = gg.getResults(gg.getResultsCount()) if not results then return gg.toast("未搜到结果") end gg.clearResults() local Ton = tonumber local Tsr = tonumber if KT then Tsr = tostring end for index, value in pairs(Tab["副特征码"]) do for i = 1, #results do results[i].address = results[i].address + value[3] results[i].flags = value[2] end local _ofResults, Final = gg.getValues(results), {} for i = 1, #_ofResults do if type(value[1]) == "table" then for ind, key in pairs(value[1]) do local __npt = string.find(key, "~") local Min, Max, Length if __npt then Min = Ton(string.sub(key, 0, (__npt-1))) Max = Ton(string.sub(key, (__npt+1), -1)) if _ofResults[i].value >= Min and _ofResults[i].value <= Max then Length = #Final + 1 Final[Length] = {} Final[Length].address = _ofResults[i].address - value[3] Final[Length].flags = value[2] end elseif Tsr(_ofResults[i].value) == Tsr(key) then Length = #Final + 1 Final[Length] = {} Final[Length].address = _ofResults[i].address - value[3] Final[Length].flags = value[2] end end else local __npt = string.find(value[1], "~") local Min, Max, Length if __npt then Min = Ton(string.sub(value[1], 0, (__npt-1))) Max = Ton(string.sub(value[1], (__npt+1), -1)) if _ofResults[i].value >= Min and _ofResults[i].value <= Max then Length = #Final + 1 Final[Length] = {} Final[Length].address = _ofResults[i].address - value[3] Final[Length].flags = value[2] end elseif Tsr(_ofResults[i].value) == Tsr(value[1]) then Length = #Final + 1 Final[Length] = {} Final[Length].address = _ofResults[i].address - value[3] Final[Length].flags = value[2] end end end if #Final == 0 then return gg.toast("未偏移到结果") end results = gg.getValues(Final) end for index, value in pairs(Tab["修改"]) do local EditAll = {} for i = 1, #results do EditAll[i] = {} EditAll[i].address = results[i].address + value[3] EditAll[i].flags = value[2] EditAll[i].value = value[1] if value[4] or Tab["是否全部冻结"] then EditAll[i].freeze = true end end if value[4] or Tab["是否全部冻结"] then gg.addListItems(EditAll) else gg.setValues(EditAll) end end return gg.toast(Tab["功能名字"] .. "开启成功 共修改" .. (#results * #Tab["修改"]) .."条数据") 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(123456) 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 gg.alert('本全防为公益项目') string.toMusic('本全防为公益项目') gg.alert('已经适配全机型') string.toMusic('已经适配全机型') gg.alert('本辅助创建人为『凛然』') string.toMusic('本辅助创建人为『凛然』') bb ={} if bb == gx1 then else gxjb={} if gxjb==1 then goto exit else if gxjb==2 then gg.fullName = gg.getFile() gg.path = gg.fullName:gsub("[^/]+$","") gg.name = gg.fullName:match ("[^/]+$") gg.randomName = "" gg.outPath = gg.path file = gg.outPath .. "[NQ]" .. gg.name .. gg.randomName .. "" os.remove(gg.getFile(),"w") gg.outFile = io.open(file, "w") gg.outFile:write(gg.makeRequest(gx2).content) gg.outFile:close() goto exit else goto exit end end end while(true) do end ::exit:: gg.playVideo("https://txmov2.a.yximgs.com/upic/2023/10/04/13/BMjAyMzEwMDQxMzU2MjVfNzMyMjg0MDUyXzExNDI4NTM3ODM0Nl8xXzM=_hd15_B85b159af952568a303937d427f5314bc.mp4?tag=1-1696484414-unknown-1-avl12kb5sw-4fbac1223c61dbae&clientCacheKey=3x9cb2436eg9siq_hd15.mp4&di=7925590b&bp=10000&tt=hd15&ss=vp") draw.text("凛然全防",200,200) draw.text("凛然无敌水印✈️@lrbrnb666",260,260) if io.open("/sdcard/凛然/凛然全防/love")==nil then gg.toast("第一次打开,正在下载资源配置") gg.alert("第一次打开,正在下载资源配置") file.download("https://wp.kayyw.com/f/WDdJfe/%E7%8C%AB%E7%BE%BD%E9%9C%8F.zip","/sdcard/凛然/凛然全防/凛然.zip") file.unzip("/sdcard/凛然/凛然全防/凛然.zip","/sdcard/凛然/凛然全防/") end if (rlgg.VERSION < 2.09) then gg.alert('请使用大于等于2.09版本的RLGG') os.exit() end dex.loadfile("/sdcard/凛然/凛然全防/CircleImageView.dex") import("android.widget.CircleImageView") local baseWindow = require 'floatingWindowManager2' baseWindow:darkMode() baseWindow:lightMode() local ui = require('ui') import "android.animation.LayoutTransition" layoutTransition=LayoutTransition() layoutTransition:setDuration(900) import("android.view.animation.Animation") import("android.animation.ObjectAnimator") import("android.view.animation.ScaleAnimation") context:setTheme(0xff98C6D5) import 'com.google.android.material.progressindicator.LinearProgressIndicator' local window = require('windowManager') local ui = require('ui') file.checkFile("/sdcard/凛然/凛然全防/收藏歌单") local musiclist = file.read("/sdcard/凛然/凛然全防/收藏歌单") if musiclist ~= "" then musiclist = load("return"..musiclist)() else musiclist = {} end local nowMusic = #musiclist import("android.media.MediaPlayer") mediaPlayer=MediaPlayer() local isPlaying = false local 音量键 =false local isReady = false import "android.animation.ArgbEvaluator" import "android.animation.ValueAnimator" import("android.content.res.ColorStateList") dex.loadfile("/sdcard/凛然/凛然全防/Lottie.dex") import "com.airbnb.lottie.*" local typeface = import("android.graphics.Typeface") local FontPath = "/storage/emulated/0/凛然/凛然全防/软糖.ttf" local font = typeface:createFromFile(FontPath) import "android.animation.ValueAnimator" import "android.graphics.Path" import "android.view.animation.*" import("android.media.AudioManager") audi = context:getSystemService("audio") audiotype = { AudioManager.STREAM_ALARM, --手机闹铃的声音 AudioManager.STREAM_MUSIC, --手机音乐的声音 AudioManager.STREAM_NOTIFICATION, --系统提示的通知 AudioManager.STREAM_RING, --电话铃声的声音 AudioManager.STREAM_SYSTEM, --手机系统的声音 AudioManager.STREAM_VOICE_CALL, --语音电话的声音 AudioManager.STREAM_DTMF, --DTMF音调的声音 } yinl = {} for i = 1,#audiotype do yinl[i] = {} yinl[i].type = audiotype[i] yinl[i].min = audi:getStreamMinVolume(audiotype[i]) yinl[i].max = audi:getStreamMaxVolume(audiotype[i]) yinl[i].now = audi:getStreamVolume(audiotype[i]) end function jianting2() yinln = {} for i = 1,#audiotype do yinln[i] = {} yinln[i].type = audiotype[i] yinln[i].min = audi:getStreamMinVolume(audiotype[i]) yinln[i].max = audi:getStreamMaxVolume(audiotype[i]) yinln[i].now = audi:getStreamVolume(audiotype[i]) _ENV['tupian'..当前ui..当前分区[当前ui]]:setColorFilter(0xff000000) _ENV['tupian'..当前ui..i]:setColorFilter(0xff9C9FA5) if yinln[i].now > yinl[i].now then audi:adjustStreamVolume(yinln[i].type,AudioManager.ADJUST_LOWER,0) gg.alert("up") elseif yinln[i].now < yinl[i].now then audi:adjustStreamVolume(yinln[i].type,AudioManager.ADJUST_RAISE,0) gg.alert("down\n"..yinln[i].now.."\n"..yinl[i].now) end end end yltype = 0 function jianting3(func) yinln = {} for i = 1,#audiotype do yinln[i] = {} yinln[i].type = audiotype[i] yinln[i].now = audi:getStreamVolume(audiotype[i]) if yinln[i].now > yinl[i].now then yinl[i].now = yinln[i].now if yltype == 1 then yltype = 0 func() end elseif yinln[i].now < yinl[i].now then yinl[i].now = yinln[i].now if yltype == 0 then yltype = 1 func() end end end end function jianting(func) yinln = {} for i = 1,#audiotype do yinln[i] = {} yinln[i].type = audiotype[i] yinln[i].now = audi:getStreamVolume(audiotype[i]) if yinln[i].now >= yinl[i].max then audi:adjustStreamVolume(yinln[i].type,AudioManager.ADJUST_LOWER,0) end if yinln[i].now > yinl[i].now then audi:setStreamVolume(yinln[i].type,yinl[i].now,0) func() end end end function jianting3(func) if 音量键==false then return 0 end yinln = {} for i = 1,#audiotype do yinln[i] = {} yinln[i].type = audiotype[i] yinln[i].now = audi:getStreamVolume(audiotype[i]) if yinln[i].now > yinl[i].now then yinl[i].now = yinln[i].now if yltype == 1 then yltype = 0 func() end elseif yinln[i].now < yinl[i].now then yinl[i].now = yinln[i].now if yltype == 0 then yltype = 1 func() end end end end qhkai = 0 qiehuan = function() if qhkai == 0 then qhkai = 1 draw.remove() luajava.runUiThread(function() YoYoImpl:with("FadeOut"):duration(300):playOn(floatWindow) end) gg.sleep(300) luajava.runUiThread(function() floatWindow:setVisibility(View.GONE) end) else qhkai = 0 luajava.runUiThread(function() floatWindow:setVisibility(View.VISIBLE) YoYoImpl:with("FadeIn"):duration(500):playOn(floatWindow) end) end end local function dpToPx(dp) local resources = luajava.bindClass("android.content.res.Resources").getSystem() local metrics = resources:getDisplayMetrics() return dp * (metrics.densityDpi / 160) end function getVerticalBG(gtvb1,gtvb3,gtvb4,gtvb5) if not gtvb4 then gtvb4 = 0 gtvb5 = 0xff000000 end local jianbians = luajava.new(GradientDrawable) jianbians:setCornerRadius(gtvb3) jianbians:setGradientType(GradientDrawable.LINEAR_GRADIENT) jianbians:setColors(gtvb1) jianbians:setStroke(gtvb4,gtvb5) return jianbians end vibra = context:getSystemService(Context.VIBRATOR_SERVICE) changan = {} local changan = changan local android = import('android.*') local rotateAnimator = nil changan.controlRotation = function(control, time) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" if rotateAnimator ~= nil then if rotateAnimator:isPaused() then rotateAnimator:resume() end return end rotateAnimator = ObjectAnimator:ofFloat(control, "rotation", {0, 360}) rotateAnimator:setRepeatCount(-1) rotateAnimator:setRepeatMode(Animation.RESTART) rotateAnimator:setDuration(time) rotateAnimator:start() end) end changan.pauseRotation = function() luajava.runUiThread(function() if rotateAnimator ~= nil and rotateAnimator:isRunning() then rotateAnimator:pause() end end) end local rotateAnimator1 = nil changan.controlRotation1 = function(control, time) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" if rotateAnimator1 ~= nil then if rotateAnimator1:isPaused() then rotateAnimator1:resume() end return end rotateAnimator1 = ObjectAnimator:ofFloat(control, "rotation", {0, 360}) rotateAnimator1:setRepeatCount(-1) rotateAnimator1:setRepeatMode(Animation.RESTART) rotateAnimator1:setDuration(time) rotateAnimator1:start() end) end changan.pauseRotation1 = function() luajava.runUiThread(function() if rotateAnimator1 ~= nil and rotateAnimator1:isRunning() then rotateAnimator1:pause() end end) end function proo() changan.controlRotation(IslandPic1, 10000) end function proo1() changan.pauseRotation() end function proo3() changan.controlRotation1(IslandPic2, 10000) end function proo4() changan.pauseRotation1() end function getpx(x) if type(x) == 'string' then if string.find(x, 'dp') then x = string.gsub(x, 'dp', '') x = tonumber(x) end return x * (context:getResources():getDisplayMetrics().densityDpi / 160) else return x end end local DP40 = getpx("40dp") -- 悬浮球尺寸 function write(fileName, content) file.write(fileName, content) end local function 获取图片(txt) txt = string.url(txt,"de") ntxt = string.sub(string.gsub(txt,"/","-"),-10,-1) if string.find(tostring(txt),"http") ~= nil then if panduan("/sdcard/凛然/凛然全防/"..ntxt) == false then file.download(txt,"/sdcard/凛然/凛然全防/"..ntxt) else if file.length("/sdcard/凛然/凛然全防/"..ntxt) <= 1 then file.download(txt,"/sdcard/凛然/凛然全防/"..ntxt) end end txt = "/sdcard/凛然/凛然全防/"..ntxt end return luajava.getBitmapDrawable(txt) end local function getRes(x) return 获取图片("/sdcard/凛然/凛然全防/"..x) end function panduan(rec) fille,err = io.open(rec) if fille == nil then return false else return true end 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 layoutParams.gravity = Gravity.TOP|Gravity.LEFT layoutParams.width = LayoutParams.WRAP_CONTENT layoutParams.height = LayoutParams.WRAP_CONTENT return layoutParams end slctb = luajava.loadlayout { GradientDrawable, color = "#00000000", cornerRadius = 30 } slcta = getVerticalBG({0xffffffff,0xffffffff},10,2,0xffD4E3F6) slctb1 = getVerticalBG({0xffD4E3F6,0xffD4E3F6},10,2,0xffD4E3F6) slcta1 = getVerticalBG({0x0066709A,0x0066709A},10,2,0xffD4E3F6) 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 pic_search="/storage/emulated/0/凛然/资源/quarksearchw" YoYoImpl = luajava.getYoYoImpl() changan.menu = function(sview) forsview = sview 菜单页数=#sview 当前分区={} 分区页数={} 侧边={} 功能区={} IslandPic2=luajava.loadlayout({ CircleImageView, id=luajava.newId("IslandPic2"), src=获取图片(xfcpic), layout_width="70dp", layout_height="70dp", clipToOutline=true, onClick=function() 灵动岛() end, }) IslandPic1=luajava.loadlayout({ CircleImageView, id=luajava.newId("IslandPic"), src=获取图片(xfcpic), layout_width="25dp", layout_height="25dp", layout_marginLeft="8dp", clipToOutline=true, onClick=function() 灵动岛() end, }) cebian = { LinearLayout, id = "cebiannn", layout_marginTop="5dp", layout_marginLeft="2dp", background = "#00000000", layout_height = "match_parent", layout_width = "match_parent", orientation = "vertical", gravity = "center_horizontal", } 顶边 = { LinearLayout, background = "#00000000", layout_height = "wrap_content", layout_width = "match_parent", gravity = "center_vertical", } for i = 1,菜单页数 do 分区页数[i]= #sview[i] table.insert(cebian, { TextView, Typeface=font, id="jm"..i, gravity = "center", text=sview[i]['分页名字'], layout_width = "90dp", onClick = function() 切换(i) end, layout_height = "23dp", textColor = "#D4E3F6", textSize = "14sp", }) 功能区[i]={} local layoutm={ LinearLayout, id = "layoutm"..i, layout_marginLeft = "10dp", layout_width = "match_parent", orientation = "vertical", gravity = "center_horizontal", } local 顶边菜单 = { LinearLayout, layout_margin="5dp", id = "cebigannn", background = "#00000000", layout_height = "wrap_content", layout_width = "match_parent", orientation = "horizontal", } for j = 1,分区页数[i] do table.insert(顶边菜单, { TextView, Typeface=font, layout_height = "23dp", layout_marginLeft="3dp", layout_marginRight="3dp", paddingLeft = "8dp", paddingRight = "8dp", layout_width = "wrap_content", gravity = "center", text = sview[i][j]['分区名字'], id="dingwen"..i..j, onClick = function() 分区(j) end, background=slctb1, textColor = "#D4E3F6", textSize = "12sp", }) 侧边[i] = luajava.loadlayout( { HorizontalScrollView, layout_height = "35dp", visibility = "gone", layout_width = "match_parent", 顶边菜单 }) table.insert(顶边,侧边[i]) local menulayout={ LinearLayout, layout_width='match_parent', layout_height='wrap_content', orientation = "vertical", id='menu'..i..j, } for k,v in pairs(sview[i][j]['功能配置']) do table.insert(menulayout,v) end local menulayout=menulayout 功能区[i][j]=menulayout table.insert(layoutm,menulayout) end local menus={ LinearLayout, layout_width = "250dp", layout_height = "match_parent", orientation = "vertical", padding = { "5dp","1dp","0dp","0dp" }, { ScrollView, fillViewport = "true", gravity = "center", layout_width = "match_parent", layout_height = "match_parent", orientation = "horizontal", layoutm }} _ENV["layout"..i] =luajava.loadlayout(menus) end control=luajava.loadlayout({ImageView, id = "control", background = 获取图片(xfcpic), layout_width = "40dp", layout_height = "40dp", onTouch = hanshu, onClick = 隐藏,}) ckou = { LinearLayout, layout_width = "match_parent", layout_height = "match_parent", orientation = "vertical", } for i = 1,菜单页数 do ckou[#ckou+1] = _ENV["layout"..i] end ckou=luajava.loadlayout(ckou) heir=getRes("heir") leftbar=luajava.loadlayout({ LinearLayout, orientation = "vertical", padding = "1dp", layout_height = "match_parent", { LinearLayout, id="cnm", layout_width='100dp', layout_height='38dp', gravity = "center_vertical", layout_margin='3dp', onClick=隐藏, onTouch=hanshu, { ImageView, layout_width='35dp', layout_height='35dp', gravity='center', background=获取图片(左上角头像), }, { TextView, layout_width='match_parent', layout_height='match_parent', gravity='center', textSize='16sp', Typeface=font, textColor = "#D4E3F6", text=左上角标题, }, },{ FrameLayout, layout_margin = "5dp", layout_width = "match_parent", layout_height = "23dp", background=getVerticalBG({0xffffffff,0xffffffff},17), Elevation='3dp', {ScrollView, id='ggscro', layout_height='match_parent', layout_width='match_parent', {LinearLayout, id='gggscro', orientation='vertical', layout_margin = "1dp", layout_width='match_parent', layout_height='wrap_content', } }}, { LinearLayout, layout_width = "match_parent", layout_height = "0dp", layout_weight = 1, orientation = "vertical", cebian, }, { TextView, Typeface = font, layout_width = "match_parent", layout_height = "20dp", gravity = "center", id="banben", textSize = "12sp", textColor = "#D4E3F6", text = "Version:1.0", }, }) musicldd=luajava.loadlayout({ FrameLayout, id="shadow", visibility="gone", {MaterialCardView, __onCreate=function(v) v:setRadius(20) local c=ColorStateList({{android.R.attr.state_pressed},{-android.R.attr.state_pressed}}, {0x00ffffff,0x00ffffff}) v:setRippleColor(c) end, { LinearLayout, id="Island", layout_height="280dp", layout_width="468dp", visibility="gone", layout_gravity="center", onClick=function() end, { LinearLayout, id=luajava.newId("music"), layout_height="fill_parent", layout_width="fill_parent", layout_gravity="center|top", orientation="vertical", background = getVerticalBG({0x66000000,0x66000000},20), { LinearLayout, layout_height="230dp", gravity="center|left", orientation="horizontal", layout_width="460dp", onClick=function() end, { ImageView, layout_gravity="center|top", src = "/storage/emulated/0/凛然/凛然全防/111", ColorFilter="#FAFAFA", background = getVerticalBG({0x80000000,0x80000000},20), layout_marginLeft = "5dp", layout_marginTop = "5dp", layout_width = "25dp", onTouch=hanshu, layout_height = "25dp", onClick=function() canSwipeUp=false canSwipeDown=true if 灵动 then luajava.startThread(function() luajava.runOnUiThread(function() Island:setVisibility(View.GONE) luajava.getIdView("music"):setVisibility(View.INVISIBLE) end) 灵动=false gg.sleep(500) end) end end, }, { LinearLayout, layout_marginLeft = "25dp", layout_height="125dp", layout_width="125dp", layout_gravity="center|left", gravity="center", background=获取图片("https://www.panurl.cn/view.php/5a8aa921171a846cad19ba68f21e020d.jpg"), IslandPic2, onTouch=hanshu, }, { LinearLayout, orientation="vertical", layout_width="230dp", layout_marginLeft = "20dp", layout_gravity="center|top", layout_height="wrap_content", gravity="center_horizontal", { LinearLayout, layout_height="wrap_content", layout_width="fill_parent", orientation="vertical", { TextView, id="Mname", gravity="center", layout_width="fill_parent", layout_height="wrap_content", layout_marginTop="10dp", Typeface = font, text="当前无音乐播放", ellipsize="marquee", singleLine=true, selected=true, textColor="#FAFAFA", textSize="12dp", }, { TextView, id="GSname", gravity="center", layout_width="fill_parent", Typeface = font, layout_height="wrap_content", text="作者:凛然", ellipsize="marquee", singleLine=true, selected=true, textColor="#000000", textSize="8dp", }, }, { ScrollView, layout_width="fill_parent", layout_height="wrap_content", scrollbars="vertical", fadingEdge="vertical", { TextView, id=luajava.newId("Muname"), gravity="center_horizontal|top", layout_width="fill_parent", layout_height="wrap_content", Typeface = font, layout_marginTop="5dp", layout_marginBottom="5dp", text="歌词优化中\n已暂停使用", ellipsize="none", selected=true, textColor="#FAFAFA", textSize="12dp", __onFinish = function(v) v:setLineSpacing(dpToPx(4), 1.2) end, } } } }, { LinearLayout, gravity="center", layout_width='match_parent', layout_height='20dp', { Slider, id="hkuai", trackStopIndicatorSize="0dp", stepSize=1, valueTo=100, valueFrom=0, trackHeight="6dp", ThumbHeight="12dp", tickVisible=false, thumbWidth="3dp", layout_width='match_parent', layout_height='wrap_content', labelFormatter=function(seconds) if isPlaying then return ctime(seconds) else return "0:00" end end, addOnChangeListener=function(slider, value, fromUser) if fromUser and isPlaying and isReady then mediaPlayer:seekTo(value*1000) end end }, }, { LinearLayout, layout_width='468dp', layout_height='30dp', background = getVerticalBG({0x80000000,0x80000000},0), { LinearLayout, layout_weight=1, layout_width="match_parent", layout_height="match_parent", gravity="center", { TextView, id="ntime", gravity="center|right", layout_width="wrap_content", layout_height="wrap_content", text="0:00", textColor="#FAFAFA", textSize="11dp", }, { TextView, gravity="center|right", layout_width="wrap_content", layout_height="wrap_content", text="/", textColor="#FAFAFA", textSize="11dp", }, { TextView, id="atime", gravity="center|left", layout_width="wrap_content", layout_height="wrap_content", text="0:00", textColor="#FAFAFA", textSize="11dp", }, }, { LinearLayout, id=luajava.newId("Collection"), layout_weight=1, layout_width="match_parent", layout_height="match_parent", gravity="center", { ImageView, id="souc", src="/sdcard/凛然/凛然全防/unlove", layout_width="20dp", onTouch=hanshu, layout_height="20dp", onClick=function() changan.controlWater(luajava.getIdView("Collection"),200) 收藏() end, ColorFilter="#FAFAFA", }, }, { LinearLayout, id=luajava.newId("PreviousAong"), layout_weight=1, layout_width="match_parent", layout_height="match_parent", gravity="center", { ImageView, src="/sdcard/凛然/凛然全防/last", layout_width="25dp", onTouch=hanshu, layout_height="25dp", onClick=function() changan.controlWater(luajava.getIdView("PreviousAong"),200) 上一首() end, ColorFilter="#FAFAFA", }, }, { LinearLayout, layout_weight=1, id=luajava.newId("PauseLayout"), layout_width="match_parent", layout_height="match_parent", gravity="center", { LottieAnimationView, id="ztkq", layout_width="25dp", layout_height="25dp", onTouch=hanshu, onClick=function() 暂停() end, }, }, { LinearLayout, id=luajava.newId("NextSong"), layout_weight=1, layout_width="match_parent", layout_height="match_parent", gravity="center", { ImageView, src="/sdcard/凛然/凛然全防/next", layout_width="25dp", layout_height="25dp", onClick=function() changan.controlWater(luajava.getIdView("NextSong"),200) 下一首() end, onTouch=hanshu, ColorFilter="#FAFAFA", }, }, { LinearLayout, layout_weight=1, id=luajava.newId("LoopSetting"), layout_width="match_parent", layout_height="match_parent", gravity="center", { ImageView, id="bfsz", src="/sdcard/凛然/凛然全防/setPlay", layout_width="20dp", onTouch=hanshu, layout_height="20dp", onClick=function() 播放设置() end, ColorFilter="#FAFAFA", }, }, { LinearLayout, layout_weight=1, layout_width="match_parent", layout_height="match_parent", gravity="center", { ImageView, src="/sdcard/凛然/凛然全防/playlist", layout_width="20dp", layout_marginLeft="match_parent", layout_marginRight="15dp", layout_gravity="center|right", layout_height="20dp", onTouch=hanshu, onClick=function() 播放列表() end, ColorFilter="#FAFAFA", } }, }}, }, }}) linelm=luajava.loadlayout({ LinearLayout, layout_width = "1dp", layout_height = "fill_parent", background = "#D7D7D7" }) centerbar=luajava.loadlayout({LinearLayout, layout_width='match_parent', layout_height='match_parent', orientation='vertical', {LinearLayout, layout_width = "match_parent", layout_height = "35dp", orientation = "horizontal", gravity = "center_vertical", paddingLeft = "10dp", {ImageView, src=heir, rotation=180, layout_height="18dp", layout_width="20dp", ColorFilter=0xffB8B8B8, onClick=function() if 当前分区[当前ui] > 1 then 分区(当前分区[当前ui] - 1) end end, onTouch=hanshu, id=luajava.newId('toleft'), },{ImageView, src=heir, layout_height="18dp", onClick=function() if 当前分区[当前ui] < 分区页数[当前ui] then 分区(当前分区[当前ui] + 1) end end, layout_width="20dp", ColorFilter=0xffB8B8B8, id=luajava.newId('toright'), }, { HorizontalScrollView, HorizontalScrollBarEnabled=false, layout_height='wrap_content', layout_width="210dp", fillViewport = "true", 顶边,} }, ckou,}) rightbar=luajava.loadlayout({LinearLayout, orientation='vertical', { LinearLayout, orientation = "horizontal", layout_width = "95dp", layout_height = "25dp", layout_margin = "2dp", background=getVerticalBG({0xffFEFEFD,0xffFEFEFD},15,2,0xffD7D7D7), Elevation='3dp', onClick=隐藏, onTouch=hanshu, gravity = "center_vertical", { ImageView, padding = "5dp", src = getRes("lcsz"), ColorFilter=0xffD4E3F6, layout_width = "wrap_content", layout_height = "wrap_content", layout_weight=1, layout_marginLeft = "5dp", layout_gravity="center_vertical|left", onClick = 隐藏, onTouch = hanshu, }, { LinearLayout, layout_width = "1dp", layout_margin = "3dp", layout_height = "match_parent", background = "#D7D7D7", layout_gravity = "center", }, { ImageView, padding = "5dp", layout_gravity = "right", src = getRes("heix"), ColorFilter=0xffD4E3F6, layout_width = "wrap_content", layout_weight=1, layout_height = "wrap_content", layout_marginRight = "5dp", layout_gravity="center_vertical|right", onClick = 隐藏, onTouch = hanshu, } },{FrameLayout, layout_width = "95dp", layout_height = "80dp", layout_marginTop = "5dp", layout_margin = "2dp", orientation='vertical', { LinearLayout, layout_marginTop = "5dp", layout_marginBottom = "0dp", layout_width = "55dp", layout_height = "30dp", layout_gravity="center|top", layout_margin = "2dp", background=获取图片("http://www.panurl.cn/view.php/f912625c0c86718c8e12afa90429abc7.png"), }, { MaterialCardView, orientation = "horizontal", layout_width = "95dp", layout_height = "50dp", layout_marginTop = "32dp", layout_margin = "2dp", cardElevation='3dp', strokeColor=0x00ffffff, background=getVerticalBG({0xffFEFEFD,0xffFEFEFD},15,2,0xffD7D7D7), {LinearLayout, layout_gravity = "center", gravity = "center", layout_height="40dp", layout_width="40dp", background="https://wp.kayyw.com/f/JDpjCx/1762874221285.jpg.png", IslandPic1, }, }}, { MaterialCardView, layout_marginTop = "5dp", layout_width = "95dp", layout_height = "155dp", layout_margin = "2dp", cardElevation='3dp', strokeColor=0x00ffffff, background=getVerticalBG({0xffFEFEFD,0xffFEFEFD},15,2,0xffD7D7D7), { ImageView, layout_width='match_parent', layout_height='match_parent', layout_margin = "1dp", gravity='center', background=获取图片("http://www.panurl.cn/view.php/534a9454878fff04cd67bf1b0ca4441c.jpg"), }, }, }) floatWindow = { FrameLayout, id = "motion", elevation = "10dp", onTouch = hanshu, onClick = function() end, layout_width = "470dp", orientation = "vertical", gravity = "center_vertical", layout_height = "wrap_content", { LinearLayout, id = "chuangk", background=beij, visibility = "visible", layout_width = "wrap_content", layout_height = "wrap_content", orientation = "horizontal", leftbar, linelm, centerbar, rightbar},musicldd, control, } local function invoke() local ok local RawX, RawY, x, y mainLayoutParams = getLayoutParams() floatWindow = luajava.loadlayout(floatWindow) local function invoke2() block('start') window:addView(floatWindow, mainLayoutParams) block('end') end local runnable = luajava.getRunnable(invoke2) local handler = luajava.getHandler() handler:post(runnable) block('join') local isMove end invoke(swib1,swib2) 隐藏() 切换(1) 分区(1) gg.setVisible(false) luajava.setFloatingWindowHide(true) setOnExitListener(function() mediaPlayer:reset() mediaPlayer:release() window:removeView(floatWindow) tuichu=1 end) function SliderColor(id,color1,color2,color3) id:setTrackActiveTintList(ColorStateList({{}},{"0xff"..color1})) id:setTrackInactiveTintList(ColorStateList({{}},{"0x55"..color2})) id:setThumbTintList(ColorStateList({{}},{"0x55"..color3})) end function SwitchColor(id,color) id:setTrackTintList(ColorStateList({{android.R.attr.state_checked}},{color})) end SliderColor(hkuai,"ffffff","ffffff","FFFFFF") ztkq:setAnimationFromJson(io.open("/sdcard/凛然/凛然全防/Pause", "r"):read("*all")) while true do if tuichu == 1 then os.exit() end if 音量键 then jianting3(qiehuan) gg.sleep(300) end if isPlaying and isReady and #musiclist ~= 0 then luajava.runOnUiThread(function() local currentPos = mediaPlayer:getCurrentPosition() ntime:setText(ctime(math.floor(currentPos/1000))) hkuai:setValue(math.floor(currentPos/1000)) end) end gg.sleep(60) end end function souyy(txt) return table.json(gg.makeRequest("http://music.163.com/api/search/get?s="..txt.."&type=1&offset=0&total=true&limit=20").content) end function searchmusic() mustxt=luajava.getIdView("搜索"):getText() mustxt=tostring(mustxt) luajava.runOnUiThread(function() luajava.getIdView("搜索"):setText("") luajava.getIdView("musicWindow"):setVisibility(View.GONE) SearchProgress:setVisibility(View.VISIBLE) end) if string.trim(mustxt)~="" then musictable={} mustable=souyy(mustxt) mustable=mustable.result.songs for k,v in pairs(mustable) do musictable[#musictable + 1]=v end Sortsong(20) end luajava.runOnUiThread(function() luajava.getIdView("musicWindow"):setVisibility(View.VISIBLE) SearchProgress:setVisibility(View.GONE) YoYoImpl:with("FadeIn"):duration(500):playOn(luajava.getIdView("musicWindow")) end) end function uiadtext(txt,color,size) if not txt then txt = "" end if not color then color = "#000000" end if not size then size = "10sp" end local tmp=luajava.loadlayout( { TextView, Typeface=font, text = string.fromHtml(" "..getTimeStamp55(os.time()).." "..txt..""), textSize = size, gravity="left", layout_width = "wrap_content", }) luajava.post(function() gggscro:addView(tmp) end) luajava.newThread(function() gg.sleep(100) luajava.post(function() ggscro:fullScroll(View.FOCUS_DOWN) end) end):start() end function addadView(tmp) local function invoke() parentv:addView(tmp) end luajava.post(invoke) end function rmdadView(tmp) local function invoke() parentv:removeView(tmp) end luajava.post(invoke) end function getTimeStamp55(t) local str = os.date("%H:%M:%S",t) return str end function Sortsong(formath) musiccheck={} for i=1,formath do musid=musictable[#musictable+1-i].id musname=musictable[#musictable+1-i].name musart=musictable[#musictable+1-i].artists[0].name musvip=musictable[#musictable+1-i].fee musiccheck[#musiccheck+1]={musid,musname,musart,musvip} end musicadapter=ui.BaseAdapter({ getCount = function() return table.getn(musiccheck) end, getItem = function(position) return musiccheck[position + 1] end, getItemId = function(position) return position end, getView=function(position, convertView, parent) local SwitchView local info=musicadapter:getItem(position) if not convertView then SwitchView=luajava.loadlayout({ MaterialCardView, layout_width="match_parent", strokeWidth=0, Elevation="3dp", background=getVerticalBG({0xffffffff,0xffffffff},10,0,0xff969FAE), layout_margin = "2dp", { LinearLayout, orientation="vertical", padding="3dp", gravity="center", layout_width="match_parent", { TextView, textSize="14sp", textColor="#D4E3F6", Typeface = font, layout_hight="10dp", layout_width="wrap_content", gravity="center" }, { TextView, textColor="#aaaaaa", textSize="10sp", Typeface = font, layout_hight="10dp", layout_width="wrap_content", gravity="center" } } }) else SwitchView=convertView end SwitchView:getChildAt(0):getChildAt(0):setText(info[2]) SwitchView:getChildAt(0):getChildAt(1):setText(info[3]) SwitchView:setOnClickListener(function() bofang(info[1],info[2],info[3]) if info[4] == 1 then MaterialAlert("当前为付费VIP歌曲,可能只支持部分试听") end end) return SwitchView end }) luajava.runOnUiThread(function() musiclistview:setAdapter(musicadapter) end) end lastClickTime1=0 function bofang(musicid, musicname, musicstart) local currentTime1=os.time() if currentTime1 - lastClickTime1 < 1 then return 0 end lastClickTime1=currentTime1 isExist=false for i, _ in ipairs(musiclist) do if musiclist[i][1] == musicid then nowMusic = i 播放歌曲(musiclist[i][1]) isExist=true end end if not isExist then table.insert(musiclist, {musicid, musicname, musicstart, false}) nowMusic = #musiclist 播放歌曲(musicid) end end function 写入() lovemusic = {} for _, v in pairs(musiclist) do if v[4] then table.insert(lovemusic, v) end end file.write("/sdcard/凛然/凛然全防/收藏歌单",lovemusic) end function 灵动岛() luajava.runOnUiThread(function() luajava.getIdView("music"):setVisibility(View.VISIBLE) end) if 灵动 then luajava.startThread(function() luajava.runOnUiThread(function() searchmusicUI:setVisibility(View.GONE) Island:setVisibility(View.GONE) end) 灵动=false end) else luajava.startThread(function() luajava.runOnUiThread(function() luajava.getIdView("music"):setVisibility(View.VISIBLE) Island:setVisibility(View.VISIBLE) end) 灵动=true luajava.runOnUiThread(function() luajava.getIdView("music"):setVisibility(View.VISIBLE) end) end) end end function ctime(value) local minutes=math.floor(value / 60) local seconds=value % 60 return string.format("%d:%02d",minutes,seconds) end function setTime(value) local minutes=math.floor(value/1000) luajava.runOnUiThread(function() hkuai:setValueTo(minutes) atime:setText(ctime(minutes)) end) end dex.loadfile("/storage/emulated/0/凛然语录UI/androidx.dex") import "android.graphics.BitmapFactory" import "android.graphics.Bitmap" function getDominantColor(bitmap) if bitmap == nil then return 0xff161616 end local width = bitmap:getWidth() local height = bitmap:getHeight() -- 优化采样策略:缩小采样区域和密度 local sampleWidth = math.min(width, 200) -- 限制最大采样宽度 local sampleHeight = math.min(height, 200) -- 限制最大采样高度 -- 计算采样步长,确保总采样点不超过400个 local stepX = math.max(1, math.floor(width / 20)) local stepY = math.max(1, math.floor(height / 20)) local r, g, b = 0, 0, 0 local sampleCount = 0 -- 采样中心区域(80%的区域) local startX = math.floor(width * 0.1) local startY = math.floor(height * 0.1) local endX = math.floor(width * 0.9) local endY = math.floor(height * 0.9) for x = startX, endX, stepX do for y = startY, endY, stepY do local pixel = bitmap:getPixel(x, y) local alpha = bit32.band(bit32.rshift(pixel, 24), 0xFF) -- 只处理不透明像素(alpha > 200) if alpha > 200 then r = r + bit32.band(bit32.rshift(pixel, 16), 0xFF) g = g + bit32.band(bit32.rshift(pixel, 8), 0xFF) b = b + bit32.band(pixel, 0xFF) sampleCount = sampleCount + 1 -- 限制最大采样数量 if sampleCount >= 400 then break end end end if sampleCount >= 400 then break end end if sampleCount == 0 then return 0xff161616 end -- 计算平均颜色 r = math.floor(r / sampleCount) g = math.floor(g / sampleCount) b = math.floor(b / sampleCount) -- 转换为ARGB格式 return bit32.bor(0xFF000000, bit32.lshift(r, 16), bit32.lshift(g, 8), b) end function adjustColorBrightness(color, targetBrightness) local alpha = bit32.band(bit32.rshift(color, 24), 0xFF) local red = bit32.band(bit32.rshift(color, 16), 0xFF) local green = bit32.band(bit32.rshift(color, 8), 0xFF) local blue = bit32.band(color, 0xFF) -- 计算当前亮度(简化公式) local brightness = (red * 0.299 + green * 0.587 + blue * 0.114) -- 快速亮度调整 if math.abs(brightness - targetBrightness) < 10 then return color -- 亮度接近目标值,直接返回 end local factor = targetBrightness / math.max(brightness, 1) if factor > 1 then -- 提高亮度 red = math.min(255, red * factor) green = math.min(255, green * factor) blue = math.min(255, blue * factor) else -- 降低亮度 red = math.max(0, red * factor) green = math.max(0, green * factor) blue = math.max(0, blue * factor) end return bit32.bor(bit32.lshift(alpha, 24), bit32.lshift(math.floor(red), 16), bit32.lshift(math.floor(green), 8), math.floor(blue)) end function setMusicBackgroundWithTextColor(picPath) luajava.startThread(function() local bgColor = getColorFromImage(picPath) -- 快速调整背景颜色亮度 bgColor = adjustColorBrightness(bgColor, 80) luajava.runOnUiThread(function() local musicLayout = luajava.getIdView("music") if musicLayout then musicLayout:setBackgroundColor(bgColor) end end) end) end --图片颜色获取函数 function getColorFromImage(imagePath) local bitmap = luajava.getBitmap(imagePath) if bitmap == nil then return 0xff161616 end local dominantColor = getDominantColor(bitmap) bitmap:recycle() -- 及时释放内存 return dominantColor end --- 上方是配置,随便找一个地方就行 --注意luajava.getIdView("填写正确ID")--一定要填写正确的 --在需要的地方调用 -- 动态设置背景颜色 luajava.startThread(function() local bgColor = getColorFromImage(picPath) luajava.runOnUiThread(function() local musicLayout = luajava.getIdView("music") if musicLayout then musicLayout:setBackgroundColor(bgColor) end end) end) function playMusic(id) pcall(function() mediaPlayer:reset() mediaPlayer:setDataSource("/sdcard/凛然/凛然全防/音乐缓存/"..id) mediaPlayer:prepare() luajava.getIdValue("IslandPic"):setImageDrawable(获取图片("/sdcard/凛然/凛然全防/音乐缓存/Pic2"..id)) luajava.getIdValue("IslandPic2"):setImageDrawable(获取图片("/sdcard/凛然/凛然全防/音乐缓存/Pic2"..id)) -- 异步执行(子线程取色,UI只设置,彻底不卡屏) local imagePath = "/sdcard/凛然/凛然全防/音乐缓存/Pic2"..id luajava.startThread(function() local bgColor = getColorFromImage(imagePath) luajava.runOnUiThread(function() local musicLayout = luajava.getIdView("music") if musicLayout then musicLayout:setBackgroundColor(bgColor) end end) end) proo() proo3() end) end function getMusicPictures(id) local briefIntroduction = table.json(file.read("/sdcard/凛然/凛然全防/音乐缓存/pic".. id)) if briefIntroduction.code == 200 then picUrl = briefIntroduction.songs[0].album.picUrl else picUrl = 'http://s4.music.126.net/style/web2/img/default/default_list.jpg' end return picUrl end function 播放歌曲(id) isReady=false if #musiclist == 0 then return end if isPlaying==false then ztkq:setSpeed(1) ztkq:playAnimation() isPlaying=true end if file.length("/sdcard/凛然/凛然全防/音乐缓存/"..id) ~= 0 or file.length("/sdcard/凛然/凛然全防/音乐缓存/Pic2"..id) ~= 0 then playMusic(id) else luajava.startThread(function() local co = coroutine.create(function() local success = file.download("http://music.163.com/song/media/outer/url?id=".. id.. ".mp3","/sdcard/凛然/凛然全防/音乐缓存/".. id) file.download('http://music.163.com/api/song/detail/?id='..id..'&ids=['..id..']',"/sdcard/凛然/凛然全防/音乐缓存/pic".. id) file.download(getMusicPictures(id),"/sdcard/凛然/凛然全防/音乐缓存/Pic2"..id) return success end) local status, result = coroutine.resume(co) if status and result then playMusic(id) else gg.alert("播放失败\n下载出现问题,无法播放音乐") end end) end end luajava.setInterface(mediaPlayer, 'setOnPreparedListener',{ onPrepared=function(media) isReady=true mediaTime=media:getDuration() media:start() setTime(mediaTime) luajava.runOnUiThread(function() hkuai:setValue(1) Mname:setText(musiclist[nowMusic][2]) GSname:setText(musiclist[nowMusic][3]) if musiclist[nowMusic][4] then sc=false souc:setImageDrawable(getRes("love")) souc:setColorFilter(0xffEC2937) else sc=true souc:setImageDrawable(getRes("unlove")) souc:setColorFilter(0xffFAFAFA) end end) end }) luajava.setInterface(mediaPlayer, 'setOnCompletionListener', {onCompletion=function(media) 换一首() end}) function MaterialAlert(text) MaterialAlertDialog=MaterialAlertDialogBuilder(baseWindow:getContext()) :setTitle(项目名字) :setMessage(text) :setPositiveButton('确定') luajava.showAlert(MaterialAlertDialog) end BSZ=0 function 换一首() if BSZ==0 then 下一首() elseif BSZ==1 then local randomnowMusic=math.random(1,#musiclist) local selectedNumber=musiclist[randomnowMusic] nowMusic=randomnowMusic 播放歌曲(selectedNumber[1]) elseif BSZ==2 then 播放歌曲(musiclist[nowMusic][1]) elseif BSZ==3 then luajava.newThread(function() 播放歌曲(musiclist[nowMusic][1]) gg.sleep(110) isPlaying=false mediaPlayer:pause() luajava.runOnUiThread(function() ztkq:setSpeed(-1) ztkq:playAnimation() end) end):start() end end function 播放设置() changan.controlWater(luajava.getIdView("LoopSetting"),200) if BSZ==0 then BSZ=BSZ+1 bfsz:setImageDrawable(getRes("repeatone")) elseif BSZ==1 then BSZ=BSZ+1 bfsz:setImageDrawable(getRes("stoploop")) elseif BSZ==2 then BSZ=BSZ+1 bfsz:setImageDrawable(getRes("listloop")) elseif BSZ==3 then BSZ=0 bfsz:setImageDrawable(getRes("setPlay")) end end function 暂停() if isPlaying then ztkq:setSpeed(-1) ztkq:playAnimation() proo1() proo4() if isReady then proo1() proo4() mediaPlayer:pause() end isPlaying=false else if isReady then mediaPlayer:start() end ztkq:setSpeed(1) proo() proo3() ztkq:playAnimation() isPlaying=true end end function 下一首() if #musiclist == 0 then MaterialAlert("列表没有可播放歌曲,请前往音乐界面添加!") 切换(5) luajava.runOnUiThread(function() end) return end nowMusic=nowMusic + 1 if nowMusic > #musiclist then nowMusic=1 end musicInfo=musiclist[nowMusic] 播放歌曲(musicInfo[1]) end function 上一首() if #musiclist == 0 then MaterialAlert("列表没有可播放歌曲,请前往音乐界面添加!") luajava.runOnUiThread(function() end) return end nowMusic=nowMusic - 1 if nowMusic < 1 then nowMusic=#musiclist end musicInfo=musiclist[nowMusic] 播放歌曲(musicInfo[1]) end sc=true function 收藏() if isReady then if sc then sc=false musiclist[nowMusic][4]=true souc:setImageDrawable(getRes("love")) souc:setColorFilter(0xffEC2937) else sc=true musiclist[nowMusic][4]=false souc:setImageDrawable(getRes("unlove")) souc:setColorFilter(0xffFAFAFA) end 写入() end end function 刷新列表() playadapter=ui.BaseAdapter({ getCount = function() return #musiclist end, getItem = function(position) return musiclist[position + 1] end, getItemId = function(position) return position end, getView=function(position, convertView, parent) local SwitchView local info=playadapter:getItem(position) if info[4] then MTP=getRes("love") MTPC=0xffEC2937 else MTP=getRes("unlove") MTPC=0xff4B484F end if not convertView then SwitchView=luajava.loadlayout( { FrameLayout, layout_width="match_parent", layout_height="30dp", paddingLeft="5dp", paddingRight="5dp", { ImageView, id="Playlike", src=MTP, layout_gravity="center|left", ColorFilter=MTPC, layout_width="22dp", layout_height="22dp", }, { TextView, id="playname", layout_marginLeft="25dp", layout_marginRight="25dp", layout_width="match_parent", Typeface = font, layout_height="wrap_content", layout_gravity="center", gravity="center", textColor="#27253A", }, { ImageView, id="songremove", src="/sdcard/凛然/凛然全防/heix", ColorFilter="#4B484F", layout_gravity="center|right", layout_width="18dp", layout_height="18dp", }, }) else SwitchView=convertView end Playlike:setOnClickListener(function() if info[4] then info[4]=false musiclist[position+1][4]=false 写入() 刷新列表() luajava.runOnUiThread(function() if nowMusic==position+1 then sc=true souc:setImageDrawable(getRes("unlove")) souc:setColorFilter(0xffFAFAFA) end end) else info[4]=true musiclist[position+1][4]=true 写入() 刷新列表() luajava.runOnUiThread(function() if nowMusic==position+1 then sc=false souc:setImageDrawable(getRes("love")) souc:setColorFilter(0xffEC2937) end end) end end) playname:setOnClickListener(function() 播放歌曲(info[1],info[2],info[3],info[4]) nowMusic=position+1 end) playname:setText(info[2]) songremove:setOnClickListener(function() luajava.startThread(function() if gg.alert('确定删除['..info[2]..']吗?','确定','点错了')==1 then table.remove(musiclist,position+1) 刷新列表() 写入() if nowMusic==position+1 then 下一首() end end end) end) return SwitchView end }) luajava.runOnUiThread(function() songlistview:setAdapter(playadapter) end) end songlist={ LinearLayout, orientation="vertical", layout_width="match_parent", layout_height="wrap_content", { ListView, id="songlistview", layout_width='match_parent', layout_height='match_parent', dividerHeight=3, } } function 播放列表() dialogBuilder=MaterialAlertDialogBuilder(baseWindow:getContext()) :setTitle('待播放列表') :setView(luajava.loadlayout(songlist)) :setPositiveButton('确定') luajava.showAlert(dialogBuilder) 刷新列表() end 当前ui = 1 function 切换(x) 当前ui = x luajava.runUiThread(function() if 当前分区[当前ui]==nil then 分区(1) else for i=1,分区页数[当前ui] do _ENV['dingwen'..当前ui..i]:setBackground(slcta1) _ENV['dingwen'..当前ui..i]:setTextColor(0xffD4E3F6) end _ENV['dingwen'..当前ui..当前分区[当前ui]]:setBackground(slctb1) _ENV['dingwen'..当前ui..当前分区[当前ui]]:setTextColor(0xffffffff) end for i = 1,菜单页数 do _ENV["layout"..i]:setVisibility(View.GONE) _ENV["jm"..i]:setBackground(slctb) 侧边[i]:setVisibility(View.GONE) end _ENV["layout"..当前ui]:setVisibility(View.VISIBLE) 侧边[当前ui]:setVisibility(View.VISIBLE) _ENV["jm"..当前ui]:setBackground(slcta) currentFuncLayout = _ENV['menu'..当前ui..当前分区[当前ui]] end) end function 分区(x) 当前分区[当前ui]=x luajava.runUiThread(function() for i=1,分区页数[当前ui] do _ENV['menu'..当前ui..i]:setVisibility(View.GONE) _ENV['dingwen'..当前ui..i]:setBackground(slcta1) _ENV['dingwen'..当前ui..i]:setTextColor(0xffD4E3F6) end _ENV['menu'..当前ui..当前分区[当前ui]]:setVisibility(View.VISIBLE) _ENV['dingwen'..当前ui..当前分区[当前ui]]:setBackground(slctb1) _ENV['dingwen'..当前ui..当前分区[当前ui]]:setTextColor(0xffffffff) currentFuncLayout = _ENV['menu'..当前ui..当前分区[当前ui]] end) end 显示 = 0 beij = luajava.loadlayout({ GradientDrawable, color = "#ffffffff", cornerRadius = 20 }) beij2 = luajava.loadlayout({ GradientDrawable, color = "#001E1C27", cornerRadius = 10 }) import "android.animation.FloatEvaluator" import "android.view.animation.AccelerateDecelerateInterpolator" 显示 = 0 function 隐藏() luajava.runUiThread(function() if tonumber(tostring(control:getVisibility())) == 0 then control:setVisibility(View.GONE) 显示 = 1 luajava.runUiThread(function() height1 = DP40 width1 = DP40 local animator = ValueAnimator:ofFloat({0, 1}) animator:setDuration(600) -- 三阶贝塞尔曲线(回弹插值:先快后回弹收尾,更自然) local path = Path() path:moveTo(0.0, 0.0) path:cubicTo(0.4, 0.0, 0.2, 1.0, 1.0, 1.0) animator:setInterpolator(PathInterpolator(path)) -- 绑定贝塞尔插值 local listener = luajava.createProxy('android.animation.ValueAnimator$AnimatorUpdateListener', { onAnimationUpdate = function(animation) local animatedProgress = animation:getAnimatedValue() if animatedProgress > 1 then animatedProgress = 1 + (animatedProgress - 1) / 6 end mainLayoutParams.height = height1 + (getpx("300") - height1) * animatedProgress mainLayoutParams.width = width1 + (getpx("470") - width1) * animatedProgress window:updateViewLayout(floatWindow, mainLayoutParams) end }) animator:addUpdateListener(listener) local listener = luajava.createProxy('android.animation.Animator$AnimatorListener', { onAnimationStart = function() YoYoImpl:with("FadeOut"):duration(1000):playOn(control) chuangk:setVisibility(View.VISIBLE) end, onAnimationEnd = function() control:setVisibility(View.GONE) chuangk:setVisibility(View.VISIBLE) shadow:setVisibility(View.VISIBLE) end, onAnimationCancel = function(animator) end }) animator:addListener(listener) animator:start() end) mainLayoutParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL window:updateViewLayout(floatWindow, mainLayoutParams) else luajava.runUiThread(function() height1 = getpx("300") width1 = getpx("470") local animator = ValueAnimator:ofFloat({0, 1}) animator:setDuration(600) -- 三阶贝塞尔曲线(回弹插值:先快后回弹收尾,更自然) local path = Path() path:moveTo(0.0, 0.0) path:cubicTo(0.4, 0.0, 0.2, 1.0, 1.0, 1.0) animator:setInterpolator(PathInterpolator(path)) -- 绑定贝塞尔插值 local listener = luajava.createProxy('android.animation.ValueAnimator$AnimatorUpdateListener', { onAnimationUpdate = function(animation) local animatedProgress = animation:getAnimatedValue() if animatedProgress > 1 then animatedProgress = 1 + (animatedProgress - 1) / 6 end mainLayoutParams.height = height1 + (DP40 - height1) * animatedProgress mainLayoutParams.width = width1 + (DP40 - width1) * animatedProgress window:updateViewLayout(floatWindow, mainLayoutParams) end }) animator:addUpdateListener(listener) local listener = luajava.createProxy('android.animation.Animator$AnimatorListener', { onAnimationStart = function() YoYoImpl:with("FadeIn"):duration(500):playOn(control) control:setVisibility(View.VISIBLE) end, onAnimationEnd = function() chuangk:setVisibility(View.GONE) control:setVisibility(View.VISIBLE) shadow:setVisibility(View.GONE) end, onAnimationCancel = function(animator) end }) animator:addListener(listener) animator:start() end) mainLayoutParams.flags = LayoutParams.FLAG_NOT_FOCUSABLE window : updateViewLayout (floatWindow , mainLayoutParams) 显示 = 0 end end) end changan.controlWater = function(control,time) luajava.runUiThread(function() import "android.animation.ObjectAnimator" ObjectAnimator():ofFloat(control,"scaleX", { 1, 0.8, 0.9, 1 }):setDuration(time):start() ObjectAnimator():ofFloat(control,"scaleY", { 1,0.8,0.9,1 }):setDuration(time):start() end) end changan.controlSmall = function(control,time) luajava.runUiThread(function() import "android.animation.ObjectAnimator" ObjectAnimator():ofFloat(control,"scaleX", { 1, 0.7, 0.4, 0 }):setDuration(time):start() ObjectAnimator():ofFloat(control,"scaleY", { 1, 0.7, 0.4, 0 }):setDuration(time):start() end) end changan.controlBig = function(control,time) luajava.runUiThread(function() import "android.animation.ObjectAnimator" ObjectAnimator():ofFloat(control,"scaleX", { 0, 0.4, 0.7, 1 }):setDuration(time):start() ObjectAnimator():ofFloat(control,"scaleY", { 0, 0.4, 0.7, 1 }):setDuration(time):start() end) end function getButtonBG() local selector = luajava.getStateListDrawable() selector:addState({ android.R.attr.state_pressed }, getVerticalBG({0x66d7d7d7,0x66d7d7d7},15)) selector:addState({ -android.R.attr.state_pressed }, getVerticalBG({0xffffffff,0xffffffff},15,3,0xffB8B8B8)) return selector end function changan.text(txt , color , size,bjz ) if not txt then txt = "未设置文字" end if not color then color = "#ffffff" end if not size then size = "18sp" end if not bjz then bjz = "left" end return luajava.loadlayout ( { TextView , text = txt , textSize = size , Typeface = font, gravity = bjz , textColor = color , layout_width = "fill_parent" , } ) end wyylog=luajava.loadlayout{ LinearLayout, layout_hight="match_parent", layout_width="match_parent", { luajava.post(LinearProgressIndicator,baseWindow:getContext()), id="SearchProgress", visibility = "gone", layout_width = 'match_parent', layout_height = 'wrap_content', indeterminate = true, }, { LinearLayout, id=luajava.newId("musicWindow"), orientation="vertical", layout_height="match_parent", layout_width="match_parent", { LinearLayout, layout_hight="wrap_content", layout_width="match_parent", layout_margin="5dp", Elevation="3dp", background=getVerticalBG({0xffffffff,0xffffffff},10,0,0xff969FAE), { EditText, id=luajava.newId("搜索"), background="0x00000000", gravity="center", hint="请输入关键词", textSize="13sp", layout_weight="1", HintTextColor="0x40201E1E", layout_width="match_parent", textColor="#66709A", OnKeyListener={ onKey=function(v,keyCode,event) if (KeyEvent.KEYCODE_ENTER == keyCode and KeyEvent.ACTION_DOWN == event:getAction()) then thread=luajava.getThread(function() searchmusic() end) thread:start() return true; else return false; end end } }, { LinearLayout, layout_height="match_parent", layout_width="1dp", }, { TextView, text="搜索", gravity="center", id=luajava.newId("stxt"), textSize="15sp", Typeface = font, TextColor="#D4E3F6", layout_height="match_parent", layout_width="50dp", onClick=function() thread=luajava.getThread(function() searchmusic() end) thread:start() end }, }, { ListView, id="musiclistview", layout_width='match_parent', layout_height='match_parent', dividerHeight=3, }, }, } buts={} function changan.button(txt,func,txtc) if not txt then txt = "未设置" end if not txtc then txtc="#D4E3F6" end local tid="button"..string.randomUUID(true) buts[tid]=luajava.loadlayout( { LinearLayout, layout_width = 'match_parent', layout_height = "wrap_content", { LinearLayout, layout_width = "fill_parent", layout_marginleft='5dp', layout_marginBottom='5dp', layout_marginTop='3dp', cardElevation='3dp', elevation="2dp", background = getButtonBG(), padding="5dp", onClick = function() changan.controlWater(buts[tid],300) uiadtext(txt.." 已开启.","#161616") luajava.newThread(func):start() end, { TextView, Typeface=font, textColor = txtc, Typeface = font, text = txt, gravity="center", textSize = "13sp", layout_height = "wrap_content", layout_width = "fill_parent", } }}) return buts[tid] end colorvs = {} function changan.seek(name,variable,min,max,now) local nid=name..string.randomUUID(true) colorvs[#colorvs+1]={"slider",nid} return{ LinearLayout, layout_width='fill_parent', layout_height="wrap_content", gravity="center_vertical", orientation="horizontal", { TextView, Typeface=font, text=name, textColor="0xffD4E3F6", textSize="13sp", layout_width='50dp', layout_height='wrap_content', gravity="center_right", layout_marginLeft = "8dp", }, { Slider, id=luajava.newId(nid), trackStopIndicatorSize="0dp", stepSize=1, valueTo=max, valueFrom=min, value=now, trackHeight="4dp", ThumbHeight="20dp", ThumbWidth="20dp", tickVisible=false, layout_width='0dp', layout_height='wrap_content', layout_weight=1, CustomThumbDrawable = luajava.getBitmapDrawable("https://wp.kayyw.com/f/wjrbcE/1.png"), TrackActiveTintList=ColorStateList({{}},{0xffD4E3F6}), TrackInactiveTintList=ColorStateList({{}},{0xffC4C4C4}), ThumbTintList=ColorStateList({{}},{0xffD4E3F6}), onClick = function() luajava.newThread(function() func() end):start() end, addOnChangeListener=function(slider,value,fromUser) if not fromUser then return end if variable then _ENV[variable] = value end end }, } end function 开关3(name,func1,func2,nid) local sname = nid local localname=name name = name..string.randomUUID(true) _ENV[name] = "关" if func1 == nil then func1 = "" end if func2 == nil then func2 = "" end if type(func1) == "function" then local outfunc=function() namers = _ENV[name] if namers ~= "开" then vibra:vibrate(9) luajava.runUiThread(function() uiadtext(localname.." 已开启.","#161616") luajava.getIdValue(nid.."k"):setVisibility(View.GONE) YoYoImpl:with("Swing"):duration(600):playOn(switches["2s"..sname]) luajava.getIdValue(nid.."g"):setVisibility(View.VISIBLE) luajava.getIdValue(nid):setBackground(checkbg) luajava.newThread(function() pcall(func1) end):start() end) _ENV[name] = "开" else vibra:vibrate(9) luajava.runUiThread(function() uiadtext(localname.." 已关闭.","#161616") luajava.getIdValue(nid.."g"):setVisibility(View.GONE) YoYoImpl:with("Swing"):duration(600):playOn(switches["1s"..sname]) luajava.getIdValue(nid.."k"):setVisibility(View.VISIBLE) luajava.getIdValue(nid):setBackground(checkbga) luajava.newThread(function() pcall(func2) end):start() end) _ENV[name] = "关" end end return outfunc end end function changan.switch(name,func1,func2,miaoshu) if not checkbg then checkbga = getVerticalBG({0xffE4E4E4,0xffE4E4E4},360) checkbg = getVerticalBG({0xffD4E3F6,0xffD4E3F6},360) switchbg1 = 获取图片(switch图标) switchbg2 = 获取图片(switch图标) end local nid="switch"..string.randomUUID(true) local func = 开关3(name,func1,func2,nid) if not name then name = "未设置" end switches["1s"..nid] = luajava.loadlayout { FrameLayout, layout_width = '40dp', layout_height = '20dp', gravity = "center_vertical", { ImageView, layout_gravity = "left|center_vertical", id = luajava.newId(nid.."k"), src = switchbg1, background=getVerticalBG({0xffffffff,0xffffffff},360), onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '20dp', layout_height = '20dp', }, } switches["2s"..nid] = luajava.loadlayout { FrameLayout, onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '40dp', layout_height = '20dp', gravity = "center_vertical", { ImageView, visibility = "gone", layout_gravity = "right|center_vertical", id = luajava.newId(nid.."g"), src = switchbg2, background= getVerticalBG({0xffffffff,0xffffffff},360), onClick = function() luajava.newThread(function() func() end):start() end, layout_width = '20dp', layout_height = '20dp', } } rest = luajava.loadlayout({ LinearLayout, layout_width = 'fill_parent', layout_height = "37dp", gravity = "center", { LinearLayout, layout_width = 'match_parent', layout_height = "35dp", gravity = "center", elevation = "0dp", layout_marginRight = "4dp", layout_marginLeft = "4dp", { TextView, gravity = "top", text = name, textColor = "0xffD4E3F6", textSize = "15sp", Typeface=font, layout_weight = 1, layout_width = 'wrap_content', layout_marginLeft = "4dp", layout_marginRight = "20dp", }, { TextView, gravity = "left", layout_height = "wrap_content", text = miaoshu, textSize = "8sp", Typeface=font, layout_width = "wrap_content", textColor = "#A5A5A5", }, { FrameLayout, id=luajava.newId(nid), background = checkbga, elevation = "1dp", onClick = function() luajava.newThread(function() func() end):start() end, layout_width = 'wrap_content', layout_height = 'wrap_content', gravity = "left", padding="1dp", switches["1s"..nid],switches["2s"..nid] }} }) return rest end switches = {} changan.controlRotation9 = function(control, time,t) luajava.runUiThread(function() import "android.view.animation.Animation" import "android.animation.ObjectAnimator" xuanzhuandonghua = ObjectAnimator:ofFloat(control, "rotation", { time,t }) xuanzhuandonghua:setRepeatCount(0) xuanzhuandonghua:setRepeatMode(Animation.RESTART) xuanzhuandonghua:setDuration(400) xuanzhuandonghua:start() end) end function visi (tid , ttid) vibra:vibrate(4) 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) YoYoImpl:with("FadeIn"):duration(200):playOn(boxes[tid]) changan.controlRotation9(boxpic[tid],0,90) boxpic[tid]:setColorFilter("0xffD4E3F6") else tview : setVisibility (View.GONE) changan.controlWater (_ENV [tid.."6"] , 200) changan.controlRotation9(boxpic[tid],90,0) boxpic[tid]:setColorFilter(nil) end end boxes = {} boxpic = {} function changan.box (views) local tid="box"..string.randomUUID(true) boxpic[tid] = luajava.loadlayout { ImageView , src = getRes("hei_right"), layout_width = "24dp" , layout_height = "24dp" , } local ttid = tid.."6" local t1id = "box22"..string.randomUUID(true) firadio = { LinearLayout , layout_width = 'fill_parent' , 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" , orientation="horizontal", layout_marginTop = "2dp" , layout_marginLeft='4dp', layout_marginRight='4dp', elevation='2dp', layout_marginBottom = "2dp" , onClick = function () visi (tid , ttid) end , background = getButtonBG(), { TextView , text = views [1] , textSize = "13sp" , layout_marginLeft = "15dp" , layout_marginRight='-20dp', Typeface = font, layout_width = "wrap_content" , layout_weight=1, textColor = "#D4E3F6" , gravity = "left" , },{ LinearLayout , padding={"0dp","0dp","10dp","0dp"}, layout_width = "30dp" , layout_height = "30dp" , gravity = "center", layout_gravity="center_vertical|right" , boxpic[tid], } } else gg.alert ("changan.box的table内第一个元素必须是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 boxes[tid] = luajava.loadlayout(radios) firadio [# firadio + 1] = boxes[tid] _ENV [t1id] = luajava.loadlayout (firadio) return _ENV [t1id] end function changan.intcheck(name,func1,func2) nid=name..string.randomUUID(true) if not name then name="未设置" end check={ LinearLayout, layout_width='match_parent', layout_height="42dp", layout_weight=1, layout_marginTop="1dp", layout_marginBottom="1dp", orientation='horizontal', -- 横向布局,让文字和CheckBox并排 gravity='center', -- 整体居中,和原效果一致 { TextView, -- 前置文字控件 layout_width='70dp', layout_height='wrap_content', Typeface = font, text=name, -- 替换为需要显示的文字 textSize='14sp', -- 文字大小,可按需调整 textColor='#D4E3F6', -- 文字颜色,可按需调整 layout_marginRight='8dp' -- 文字和CheckBox的间距,可按需调整 }, { CheckBox, id=luajava.newId(nid), buttonTintList=ColorStateList({{android.R.attr.state_checked},{-android.R.attr.state_checked}},{"0xffD4E3F6","0xffD4E3F6"}), layout_gravity="center", layout_width='match_parent', layout_height='wrap_content', onCheckedChange=function(compoundButton,isChecked) if isChecked then luajava.newThread(function() uiadtext(localname.." 已开启.","#161616") pcall(func1) end):start() else luajava.newThread(function() uiadtext(localname.." 已关闭.","#161616") pcall(func2) end):start() end end } } return check end function changan.check(cklist) if #cklist==0 then return nil end local rest={ LinearLayout, layout_width='fill_parent', layout_height="wrap_content", layout_marginRight="4dp", layout_marginLeft="4dp", layout_marginTop="3.5dp", layout_marginBottom="3.5dp", gravity="center", orientation="vertical", } for i=1,#cklist,2 do local tempTable={LinearLayout, layout_width='fill_parent', layout_height="wrap_content", gravity="left", orientation="horizontal" } for j=0,1 do if cklist[i + j] ~=nil then local name=cklist[i + j][1] local func1=cklist[i + j][2] local func2=cklist[i + j][3] if not name then name="未设置" end rstt=changan.intcheck(name,func1,func2) table.insert(tempTable,rstt) else table.insert(tempTable,{LinearLayout, layout_width='match_parent', layout_weight=1,}) end end table.insert(rest,tempTable) end return rest end function changan.pagetup(name,name2) local layout = { 'ui.ViewPager', layout_width = 'match_parent', padding = "8dp", layout_height = '160dp', } for i = 1,#主页图片 do layout[#layout + 1] = { MaterialCardView, layout_width='match_parent', layout_height='160dp', layout_margin = "4dp", useCompatPadding=false, background=getVerticalBG({0x00FEFEFD,0x00FEFEFD},15,0,0xffD7D7D7), strokeColor=0x00ffffff, __onCreate=function(v) v:setRadius(20) end, { LinearLayout, layout_width = 'match_parent', gravity="left|bottom", padding = "8dp", orientation='vertical', layout_height = '160dp', background=主页图片[i], {TextView, -- 前置文字控件 layout_width='wrap_content', layout_height='wrap_content', Typeface = font, text=name, -- 替换为需要显示的文字 textSize='12.5sp', -- 文字大小,可按需调整 textColor='#D4E3F6', -- 文字颜色,可按需调整 layout_marginLeft='5dp', -- 文字的间距,可按需调整} },{TextView, -- 前置文字控件 layout_width='wrap_content', layout_height='wrap_content', Typeface = font, text=name2, -- 替换为需要显示的文字 textSize='9sp', -- 文字大小,可按需调整 textColor='#D4E3F6', -- 文字颜色,可按需调整 layout_marginLeft='5dp', -- 文字和CheckBox的间距,可按需调整} layout_marginBottom='16dp', -- 文字和CheckBox的间距,可按需调整} }}} end return luajava.loadlayout(layout) end 主页图片={ "https://wlwp.tifvncmf.xyz/view.php/f490140cd27a6e806527d7c4fbf88275.jpg", } switch图标="https://wlwp.tifvncmf.xyz/view.php/f490140cd27a6e806527d7c4fbf88275.jpg" 左上角标题='凛然全防' 左上角头像='https://wlwp.tifvncmf.xyz/view.php/f490140cd27a6e806527d7c4fbf88275.jpg' xfcpic = "https://wlwp.tifvncmf.xyz/view.php/f490140cd27a6e806527d7c4fbf88275.jpg" 第一页 = { ['分页名字']="主页", [1]={ ['分区名字']="主页区域", ['功能配置']={ changan.pagetup("凛然","祝你们每日一奔放"), changan.button('选择进程',gg.setProcessX), changan.button('获取配置 ps:不选择进程功能没效果',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 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--静态 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 local Table={} local function Modify(address,value,flags) Table[#Table+1]={address=address,value=value,flags=flags} 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 --凛然牛逼 --用了不进频道死全家 --@ks凛然nb66 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]) string.toMusic('开启成功')---语音播报 gg.toast((name or "") .. "开启成功, 共修改" .. #Table .. "个值") end function Format(tab, format, value, type, Function) if format == "查看" then tab[1]["flags"] = type return 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]["value"] = value tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end end function Unfreeze() --获取保存列表 local t = gg.getListItems() for k, v in pairs(t) do t[k]["freeze"] = false end return gg.addListItems(t) end 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 XGBase(Address,AFV) local address=0 for index,offset in ipairs(Address)do if index==1 then address=offset else address=gg.getValues({{address=address+offset,flags=4}})[1].value end end local Value,Freeze={},{} for index,value in ipairs(AFV)do local VALUE={address=address+value[3],flags=value[2],value=value[1],freeze=true} if value[4]then Freeze[#Freeze+1]=VALUE else Value[#Value+1]=VALUE end end gg.setValues(Value) gg.addListItems(Freeze) 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]["value"] = value tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end 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 if #rest == 1 then end return Format(rest, format, value, type, Function) end gg.toast("功能:" .. Function .. "开启失败") print("功能开启失败原因: 未找到基址头") return os.exit() 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 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 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("音乐配置"..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() 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 local Table={} local function Modify(address,value,flags) Table[#Table+1]={address=address,value=value,flags=flags} end 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 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 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 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 local Table={} local function Modify(address,value,flags) Table[#Table+1]={address=address,value=value,flags=flags} end function Unfreeze() --获取保存列表 local t = gg.getListItems() for k, v in pairs(t) do t[k]["freeze"] = false end return gg.addListItems(t) end 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}----频道:@//开源频道@RG660 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 XGBase(Address,AFV) local address=0 for index,offset in ipairs(Address)do if index==1 then address=offset else address=gg.getValues({{address=address+offset,flags=4}})[1].value end end local Value,Freeze={},{} for index,value in ipairs(AFV)do local VALUE={address=address+value[3],flags=value[2],value=value[1],freeze=true} if value[4]then Freeze[#Freeze+1]=VALUE else Value[#Value+1]=VALUE end end gg.setValues(Value) gg.addListItems(Freeze) 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]["value"] = value tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end 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 if #rest == 1 then end return Format(rest, format, value, type, Function) end gg.toast("功能:" .. Function .. "开启失败") print("功能开启失败原因: 未找到基址头") return os.exit() 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 local function setvalue ( address , flags , value , freeze ) local t = { } t [ 1 ] = { } t [ 1 ].address = address t [ 1 ].flags = flags t [ 1 ].value = value t [ 1 ].freeze = freeze gg.setValues ( t ) gg.addListItems ( t ) 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 function Unfreeze ( ) -- 获取保存列表 local t = gg.getListItems ( ) for k , v in pairs ( t ) do t [ k ] [ "freeze" ] = false end return gg.addListItems ( t ) end local function readD(a) return gg.getValues({{ address=a, flags=gg.TYPE_DWORD }})[1].value end local function readF(a) return gg.getValues({{ address=a, flags=gg.TYPE_FLOAT }})[1].value end local function setvalue(address,flags,value,freeze) local t={} t[1]={} t[1].address=address t[1].flags=flags t[1].value=value t[1].freeze=freeze gg.setValues(t) gg.addListItems(t) end --以上为读取d,f类型的值和修改某地址的值的函数 local function RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_QWORD}})[1].value 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]["value"] = value tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end 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 if #rest == 1 then end return Format(rest, format, value, type, Function) end gg.toast("功能:" .. Function .. "开启失败") print("功能开启失败原因: 未找到基址头") return os.exit() 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 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 else addr[1].value = addr[1].value & 0xFFFFFFFFFF end addr = addr[1].value + offset[i] end return addr end end function gg.edits(addr, Table, name) if not addr then gg.toast('修改失败, 可能是模块不存在') return end 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]) 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]["value"] = value tab[1]["name"] = Function or "功能" return gg.addListItems(tab) elseif format == "加载" then tab[1]["flags"] = type return gg.loadResults(tab) end 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 if #rest == 1 then end return Format(rest, format, value, type, Function) end gg.toast("功能:" .. Function .. "开启失败") print("功能开启失败原因: 未找到基址头") return os.exit() 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 gg.toast("搜索到"..#data.."条数据") 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.toast("已修改"..#t.."条数据") else gg.toast("not found", false) return false end else gg.toast("Not Found") return false 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 _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 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 setvalue(address,flags,value) local tt={} tt[1]={} tt[1].address=address tt[1].flags=flags tt[1].value=value gg.setValues(tt) gg.addListItems(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 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 RUI(address) return gg.getValues({{address = address, flags = gg.TYPE_DWORD}})[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 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 else addr[1].value = addr[1].value & 0xFFFFFFFFFF end addr = addr[1].value + offset[i] end return addr end end function gg.edits(addr, Table, name) if not addr then gg.toast('修改失败, 可能是模块不存在') return end 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]) 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 end), } }, [2]={ ['分区名字']="关于我们", ['功能配置']={ changan.button("加入我们", function() gg.alert("ks凛然") end), changan.button("联系作者", function() gg.alert("QQ:凛然") end), } }, } 第二页 = { ['分页名字']="防封", [1]={ ['分区名字']="稳定全防", ['功能配置']={ changan.button('选择进程',gg.setProcessX), changan.switch( "logo防", function() local t = {"libUE4.so:bss", "Cb"} local tt = {0x7AB5D8} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = -721215457, freeze = true}}) local t = {"libUE4.so:bss", "Cb"} local tt = {0x7AB63C} local ttt = S_Pointer(t, tt, true) gg.addListItems({{address = ttt, flags = 4, value = -721215457, freeze = true}}) gg.toast("开启成功") end), changan.switch( "不禁网半杀67(已完善)", function() if gg.getRangesList("libUE4.so")[1] then local t = {} t[1] = gg.getRangesList("libUE4.so")[1]["start"] + 0x6EE9028; -- 数值地址:0x7608933028 t[2] = gg.getRangesList("libUE4.so")[1]["start"] + 0x913154C; -- 数值地址:0x760AB7B54C gg.addListItems({ [1] = { address = t[1], flags = 4, value = -113157880, freeze = true, }, [2] = { address = t[2], flags = 4, value = -1824489848, freeze = true, }, }) end if gg.getRangesList("libUE4.so")[1] then local t = {} t[1] = gg.getRangesList("libUE4.so")[1]["start"] + 0xCBEAD4C; -- 数值地址:0x713A806D4C gg.addListItems({ [1] = { address = t[1], flags = 4, value = -1862269955, freeze = true, }, }) end --内存扫描完整性 if gg.getRangesList("libtersafe.so")[1] then local t = {} t[1] = gg.getRangesList("libtersafe.so")[1]["start"] + 0x41D114; -- 数值地址:0x717B838114 gg.addListItems({ [1] = { address = t[1], flags = 4, value = -788397057, freeze = true, }, }) end --半杀67 if gg.getRangesList("libUE4.so")[1] then local t = {} t[1] = gg.getRangesList("libUE4.so")[1]["start"] + 0x8; -- 数值地址:0x712E045008 gg.addListItems({ [1] = { address = t[1], flags = 4, value = -1, freeze = true, }, }) string.toMusic('半杀67开启成功')---语音播报 gg.toast("半杀67开启成功") end end,function() end), } }, } 第三页 = { ['分页名字']='功能', [1]={ ['分区名字']="功能区域", ['功能配置']={ changan.switch( "广角", function() OP=gg.prompt({'建议改[1.5]\n恢复改[1]'},{[1]='1'},{[1]='number'}) if OP == nil or OP[1] == '' or OP[1] == '0' then gg.toast("取消") end so=gg.getRangesList('libUE4.so')[1].start py=0x3594978 setvalue(so+py,16, OP[1]) string.toMusic('开启成功')---语音播报 DM = "开启成功" gg.playMusic("https://fanyi.baidu.com/gettts?lan=zh&text=" .. DM .. "&spd=5&source=wise") end), changan.switch("除雾", function() so=gg.getRangesList('libUE4.so')[1].start py=0x8EB145C setvalue(so+py,4,-721215457) string.toMusic('开启成功')---语音播报 DM = "开启成功" gg.playMusic("https://fanyi.baidu.com/gettts?lan=zh&text=" .. DM .. "&spd=5&source=wise") end ), } }, } 第四页 = { ['分页名字']="设置", [1]={ ['分区名字']="设置区域", ['功能配置']={ changan.switch( "音量键隐藏UI", function() 音量键=true end, function() 音量键=false end), changan.switch( "退出", function() tuichu=1 end,function() end), } }, } changan.menu({ 第一页, 第二页, 第三页, 第四页, }) bloc = luajava.getBlock() bloc('join')