1 Star 0 Fork 19

理科疯子/Unity mod

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
天地归虚.cs 37.60 KB
一键复制 编辑 原始数据 按行查看 历史
Neutron3529 提交于 2023-09-13 20:17 . .
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701
#!/bin/bash -e
#
# Neutron3529's Unity Game Plugin
# Copyright (C) 2022 Neutron3529
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
############################################################################
#
# * compile instructions: put this file and `utils.cs` in `steamapps`
# * folder, open a terminal in the same folder, and execute:
# *
# * ```
# * chmod +x ${file}.cs
# * ./${file}.cs
# * ```
# *
# * then the mod will be compiled automatically.
# *
# * Here we wrote a shebang like file, which is correct
# * in my computer (Manjaro XFCE), if such script do not work
# * in your computer, you could just try the instructions below :
export GAME_NAME="${0%\.cs}" # might modify if the name mismatch.
export GAME_DIR="$GAME_NAME" # might be modified, but "$GAME_NAME" cover most of the cases.
export FILE_NAME="$0"
export ASSEMBLY="Assembly-CSharp" # might be modified
export UTILS="utils.cs" # might be modified if you do not put utils.cs in the current dir.
export PLUGIN_ID="Neutron3529.Cheat" # should be modified
export NAMESPACE_ID="Neutron3529.Cheat" # should be modified
export GAME_BASE_DIR="common/$GAME_DIR" # should modify GAME_DIR instead since GAME_DIR == GAME_NAME is almost always true.
export IFS=$'\n' # to disable the annoying space.
export DOTNET="dotnet" # the location of the DOTNET executable file.
[ -z "$DOTNET_CSC_DLL" ] && export DOTNET_CSC_DLL=`\ls /usr/share/dotnet/sdk/*/Roslyn/bincore/csc.dll` # In manjaro, the csc.dll is located in /usr/share/dotnet/sdk/*/Roslyn/bincore/csc.dll
case $1 in
V) EXTRA_DEFINE="-define:DEBUG${IFS}-define:VERBOSE${IFS}-debug" ;;
v) EXTRA_DEFINE="-define:DEBUG${IFS}-define:VERBOSE${IFS}-debug" ;;
VERBOSE) EXTRA_DEFINE="-define:DEBUG${IFS}-define:VERBOSE${IFS}-debug" ;;
verbose) EXTRA_DEFINE="-define:DEBUG${IFS}-define:VERBOSE${IFS}-debug" ;;
D) EXTRA_DEFINE="-define:DEBUG${IFS}-debug" ;;
d) EXTRA_DEFINE="-define:DEBUG${IFS}-debug" ;;
DEBUG) EXTRA_DEFINE="-define:DEBUG${IFS}-debug" ;;
debug) EXTRA_DEFINE="-define:DEBUG${IFS}-debug" ;;
*) EXTRA_DEFINE="" ;;
esac
_MODE__SELECT_=100
( yes "" | head -n $_MODE__SELECT_ | head -n-1 ; tail $FILE_NAME -n+$_MODE__SELECT_) | sed s/%%NAMESPACE_ID%%/${NAMESPACE_ID}/g | sed s/%%PLUGIN_ID%%/${PLUGIN_ID}/g | $DOTNET $DOTNET_CSC_DLL -nologo -t:library \
-r:"${GAME_BASE_DIR}/BepInEx/core/BepInEx.dll" \
-r:"${GAME_BASE_DIR}/BepInEx/core/0Harmony.dll" \
-r:"${GAME_BASE_DIR}/BepInEx/core/BepInEx.Harmony.dll" \
`[ -e "${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/netstandard.dll" ] && echo "-r:\"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/netstandard.dll\""` \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/System.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/System.Core.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/UnityEngine.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/UnityEngine.AIModule.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/UnityEngine.CoreModule.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/UnityEngine.UI.dll" \
-r:"${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/mscorlib.dll" \
$(for i in "${GAME_BASE_DIR}/${GAME_NAME}_Data/Managed/$ASSEMBLY"*.dll ; do echo -e "-r:\"$i\"\n" ; done) \
-out:"${GAME_BASE_DIR}/BepInEx/plugins/${FILE_NAME%.*}".dll \
-optimize $EXTRA_DEFINE \
- $UTILS && rm -f "${GAME_BASE_DIR}/BepInEx/config/${PLUGIN_ID}.cfg";
if [ -n "$2" ]; then
git add ${FILE_NAME}
case $2 in
R) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
r) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
RANDOM) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
random) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
U) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
u) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
UPLOAD) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
upload) git commit -am "`curl -s https://whatthecommit.com/index.txt`" ;;
*) git commit -am "$2" ;;
esac
git push
fi
exit
using System;
using System.Linq;
using System.Reflection;
using System.Reflection.Emit;
using System.Collections.Generic;
using BepInEx;
using BepInEx.Configuration;
using HarmonyLib;
using UnityEngine;
using Neutron3529;
namespace Neutron.Cheat;
[BepInPlugin("%%PLUGIN_ID%%", "Neutron3529", "0.3.0")]
public class Cheat : Neutron3529.ModEntry {
public Cheat() : base("%%PLUGIN_ID%%") {}
public override void Awake() {}
public void Start() {
// 主要逻辑放在`utils.cs`中,这里的start2只是为了以防万一
// 目前来说,这个函数的唯一用途是用来“叮”……
// 就像这样:
base.Awake();
logger("叮~修改器启动,请安心游戏");
if(config.Bind("config", "dumpSomeData", true, "在log中输出全部丹方材料的五行,武器词条,技能效果,以及其他各种神奇数据").Value){
foreach(PelletFormulaBook pb in AllDictionary.Dic_PelletFormulaBook.Values){
logger(pb.OutCome+":"+pb.Yuansus[0].ToString()+" "+pb.Yuansus[1].ToString()+" "+pb.Yuansus[2].ToString()+" "+pb.Yuansus[3].ToString()+" "+pb.Yuansus[4].ToString()+" ("+pb.ItemRequire+" - "+string.Join(" ",pb.materials)+")");
}
foreach(Materials m in AllDictionary.Dic_Material.Values){
logger(m.Name+":"+m.Jin+" "+m.Mu+" "+m.Shui+" "+m.Huo+" "+m.Tu);
}
foreach(string name in AllDictionary.Dic_BuffInfo.Keys){
BuffInfo b=AllDictionary.Dic_BuffInfo[name];
logger(name+" 名称 "+b.name+" BUFF类型 "+b.buffType+" 影响属性 "+b.attriType+" 额外信息 "+b.extraInfo);
}
foreach(string name in AllDictionary.Dic_FabaoRandom_Entrys.Keys){
FbEntryInfo b=AllDictionary.Dic_FabaoRandom_Entrys[name];
logger(name+" 名称 "+b.name+" BUFF类型 "+b.buff+" 描述 "+b.descrption);
}
foreach(string name in AllDictionary.Dic_SkillInfo.Keys){
TbsFramework.Skill.SkillInfo s=AllDictionary.Dic_SkillInfo[name];
logger(name+" 名称 "+s.skillName+" 2技能体系 "+s.skillSystem+" 子体系 "+s.childSystem+" 3攻击方式 "+s.attackType+" 4元素类型 "+s.MainYuansu+" 5选取范围 "+s.effectRange+" 6施法目标 "+s.releaseTarget+" 7施法范围 "+s.range+" 8消耗行动点数 "+s.cost+" EffectOnHit \""+string.Join("\",\"",s.EffectOnHit)+"\" 1技能描述 "+s.Description);
}
foreach(string name in AllDictionary.Dic_EffectInfo.Keys){
EffectInfo s=AllDictionary.Dic_EffectInfo[name];
logger(name+" 效果名 "+s.Effectname+" 效果类型 "+s.Effectlist+" 影响属性 "+s.AttributeType+" 元素类型 "+s.YuanSu+" 伤害增幅类型 "+s.DamageType+" 持续时间 "+s.Duration+" 数值参数 "+s.Args+" IsArgsFromHit0 "+s.IsArgsFromHit0+" MaxStucks "+s.MaxStucks);
}
foreach(string name in AllDictionary.Dic_XinFa.Keys){
XinFa s=AllDictionary.Dic_XinFa[name];
logger(name+" 名称 "+s.Name+" 稀有度 "+s.rare+" 修炼类型 "+s.type+" 子体系 \""+string.Join("\",\"",s.childTypes)+"\"");
}
foreach(string name in AllDictionary.Dic_ShuFa.Keys){
ShuFa s=AllDictionary.Dic_ShuFa[name];
logger(name+" 名称 "+s.Name+" 稀有度 "+s.rare+" 等级 "+s.shufaRare+" 修炼体系 "+s.xiuliantype+" 子体系 \""+string.Join("\",\"",s.childXiuliantypes)+"\"");
}
}
}
class Neutron3529Faster : Entry {
[Desc("动画延迟乘数",0.2)]
public static float val=0.2f;
static IEnumerable<MethodBase> TargetMethods(){
foreach(MethodInfo i in new MethodInfo[]{
typeof(SearchPanel).GetMethod("TextChange",(BindingFlags)(-1)),
// typeof(SayDialog).GetMethod("IconFlicker",(BindingFlags)(-1)),
typeof(CharaWalker).GetMethod("TypeString",(BindingFlags)(-1)),
typeof(DisplayPanel).GetMethod("DisplayOnPanel",(BindingFlags)(-1))
}){
if(i==null){logger("FATAL:NULL i");}else{
logger("修改类别"+i.ToString()+"的MoveNext方法");
if(AccessTools.EnumeratorMoveNext(i)!=null){yield return AccessTools.EnumeratorMoveNext(i);}else{logger("error:i="+i.ToString()+", have no move next");}
}
}
}
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Newobj,typeof(UnityEngine.WaitForSeconds).GetConstructor(new Type[]{typeof(float)}))
).Repeat( matcher => // Do the following for each match
matcher
.InsertAndAdvance(
new CodeInstruction(OpCodes.Ldc_R4,val),
new CodeInstruction(OpCodes.Mul)
)
.Advance(1),logger
).InstructionEnumeration();
return instructions;
}
}
[HarmonyPatch(typeof(EntryBuilder), "GetEntry")]
class EntryBuilderGetEntry : Entry {
[Desc("解除特性之间的相关性,并将特性最小得分设置为此数值")]
public static int val=0;
static void Prefix(int[] PoolRange, bool isPlayer){
if (isPlayer){
PoolRange[0]=val;
PoolRange[1]=1000;
}
}
}
[HarmonyPatch(typeof(CreateChara_AttributesPart), "AddPoint",new Type[]{typeof(object),typeof(string)})]
class CreateChara_AttributesPartAddPoint : Entry {
[Desc("roll人物时天赋点对属性的影响")]
public static int val=-1;
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Dup),
new CodeMatch(OpCodes.Ldind_I4),
new CodeMatch(OpCodes.Ldc_I4_1),
new CodeMatch(OpCodes.Add)
).Repeat( matcher => // Do the following for each match
matcher
.Advance(2) // Move cursor to after ldfld
.SetAndAdvance(
OpCodes.Ldc_I4,val
)
).InstructionEnumeration();
return instructions;
}
}
[HarmonyPatch(typeof(LianDan_LuziFunction), "currentOutPutNum",MethodType.Getter)]
class LianDan_LuziFunctioncurrentOutPutNum : Entry {
[Desc("炼丹产出乘数")]
public static float val=0;
static float Postfix(float result){
return result*val;
}
}
[HarmonyPatch(typeof(CreateChara_RandomEntryPanel), "init")]
class CreateChara_RandomEntryPanelinit : Entry {
[Desc("初始人物词条点数(进入选择面板修改时生效)")]
public static int val=45;
static void Postfix(ref int ___CurrentPoint,int ___MaxPoint){
___CurrentPoint+=val-___MaxPoint;
}
}
[Desc("炼丹只出上品")]
[HarmonyPatch(typeof(LianDan_LuziFunction), "GetAllOutpus")]
class LianDan_LuziFunctionGetAllOutpus : Entry {
static List<PelletNameAndWeight> Postfix(List<PelletNameAndWeight> result){
float counter=0f;
foreach(PelletNameAndWeight x in result){
if(x.PelletName.Contains("·下品") || x.PelletName.Contains("·中品") ){
counter+=x.Weight;
x.Weight=0f;
} else if (x.PelletName.Contains("·上品")){
x.Weight+=counter;
counter=0f;
}
}
return result;
}
}
// [Desc("种植一回合完成")]
// [HarmonyPatch(typeof(PlantGrowFunction), "GetCurrentSpeed")]
// class PlantGrowFunctionGetCurrentSpeed : Entry {
// static bool Prefix(ref float __result,float ___MaxProcess){
// __result=___MaxProcess;
// return false;
// }
// }
[HarmonyPatch(typeof(FarmArea), "GetCurrentSpeed")]
class PlantGrowFunctionGetCurrentSpeed : Entry {
[Desc("种植速率")]
public static float val=10;
static bool Prefix(ref float __result){
__result=__result*val+val-1f;
return false;
}
}
[Desc("炼器一回合完成")]
[HarmonyPatch(typeof(LianQiFunction), "GetCurrentLianQieRate")]
class LianQiFunctioncurrentLianQieRate : Entry {
static bool Prefix(ref float __result,float ___MaxProcess){
__result=___MaxProcess;
return false;
}
}
[Desc("炼丹一回合完成")]
[HarmonyPatch(typeof(LianDan_LuziFunction), "ImproveProcess")]
class LianDan_LuziFunctioncurrentFireRate : Entry {
static void Prefix(ref float ___currentProcess,float ___MaxProcess){
___currentProcess=___MaxProcess;
}
}
// [HarmonyPatch(typeof(WholeObjects), "CreateAweaponFromFormula")]
class WholeObjectsCreateAweaponFromFormula : Entry {
static IEnumerable<MethodBase> TargetMethods(){
foreach(MethodInfo m in typeof(WholeObjects).GetMethods((BindingFlags)(-1))){
if(m.Name == "CreateAweaponFromFormula") yield return m;
}
}
[Desc("额外词条,语法请参考mod源码,此处以0开头的词条会将词条效果设置为1,但不会显示数值")]
public static string val="1&吸血|3&大地图行动力提升";//"1&吸血&全属性效果&暴击率&命中率&人物好事件提升|3&大地图行动力提升&成丹值百分比提升&融合度百分比提升&火力值百分比提升|0&符箓距离增加&符箓不阻挡&丹药距离增加&丹药范围增加&稳固&免疫眩晕&免疫变形&免疫禁锢&免疫封禁|45&战斗移动距离提升&平时经验获取提升&战斗角色经验提升&心法经验提升&悟道进度百分比提升&术法精进提升&气运百分比提升&成丹值提升&融合度提升&火力值提升";
[Desc("法宝词条数量和效果变为最大")]
public static bool equip_extra_citiao=true;
public static Dictionary<float,string[]> extra_citiao=new Dictionary<float,string[]>();
public static HashSet<string> all_extra_citiao=new HashSet<string>();
public override void Init() {
base.Init();
if(val.Length>0){
foreach(string s in val.Split('|')){
string[] ci=s.Split('&');
float f=float.Parse(ci[0]);
ci[0]="";
if(extra_citiao.ContainsKey(f)){
logger("额外词条出现了重复加成,这导致了语句 "+s+" 是无效的,你应当将加成相同的词条放在一起。");
continue;
}
for(int i=0;i<ci.Length;i++){
if(ci[i]=="")continue;
if(!all_extra_citiao.Add(ci[i])){
logger("在 "+s+" 中的词条 "+ci[i]+" 与前文重复,将其无效化");
ci[i]="";
}
}
extra_citiao.Add(f,ci);
}
if(extra_citiao.Count>0 || equip_extra_citiao)this.Enable();
if(extra_citiao.Count>0)logger("额外词条-patched");
if(equip_extra_citiao)logger("法宝词条数量和效果变为最大-patched");
}
}
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Ldarg_1),
new CodeMatch(OpCodes.Ldfld,typeof(WeaponFormula).GetField("Outcome",(BindingFlags)(-1))),
new CodeMatch(i=>i.opcode==OpCodes.Callvirt && ((MethodInfo)i.operand).Name == "initialize")
).Repeat( matcher => // Do the following for each match
matcher
.InsertAndAdvance(
new CodeInstruction(OpCodes.Dup)
)
.Advance(3)
.InsertAndAdvance(
new CodeInstruction(OpCodes.Ldarg_2),
new CodeInstruction(OpCodes.Call,typeof(WholeObjectsCreateAweaponFromFormula).GetMethod("abconvert"))
)
).InstructionEnumeration();
return instructions;
}
public static void abconvert(AbstractWeapon abw,string s){
if (s=="S_0" && abw.randomEntry.Count==0){
Weapon weapon = AllDictionary.Dic_Weapon[abw.Name];
if(equip_extra_citiao){
foreach(var entry in AllDictionary.Dic_FabaoRandom_Entrys.Keys) {
//if(all_extra_citiao.Contains(entry))continue;// 这个增加值与主动增加不同,故可以保留
// abstractWeapon.randomEntry.Add(EntryBuilder.GetRandomEntry(text2, weapon, null));
string text2="";
string text="+";
float num2;
FbEntryInfo fbEntryInfo = AllDictionary.Dic_FabaoRandom_Entrys[entry];
float computerValue2 = (float)(typeof(EntryBuilder).GetMethod("GetComputerValue",(BindingFlags)(-1)).Invoke(null,new object[]{fbEntryInfo.max, weapon.Level}));
if(computerValue2<=0)computerValue2=(float)(typeof(EntryBuilder).GetMethod("GetComputerValue",(BindingFlags)(-1)).Invoke(null,new object[]{fbEntryInfo.min, weapon.Level}));
if(fbEntryInfo.isInteger) {
int num=((int)computerValue2) * (1 + weapon.Level * (int)(1 + weapon.Rare) / 26);
num2=(float)num;
text2=num.ToString();
} else {
num2 = (float)Convert.ToInt32(computerValue2 * 100f)/100f;
if (fbEntryInfo.isPercentShow)
{
text2 = num2.ToString("P0");
}
else
{
text2 = num2.ToString("0.0");
}
}
if (num2 < 0f)
{
text = "";
}
text2 = fbEntryInfo.descrption + text + text2;
if(num2!=0f){
abw.randomEntry.Add(new RandomEntry{
description = text2,
name = fbEntryInfo.name,
buffName = fbEntryInfo.buff,
value = num2,
id = Guid.NewGuid().ToString()
});
}
}
}
foreach(var kv in extra_citiao){
// logger("进入extra_citiao,k="+kv.Key+"v="+string.Join(" ",kv.Value));
foreach(var entry in kv.Value) {
if(AllDictionary.Dic_BuffInfo.ContainsKey(entry)){
BuffInfo buffInfo = AllDictionary.Dic_BuffInfo[entry];
var num2=kv.Key;
string text="";
string text2;
if (buffInfo.isPercentage || entry=="吸血" || entry=="全属性效果" || entry=="暴击率" || entry=="命中率") {
text2 = num2.ToString("P0");
} else {
text2 = num2.ToString("0.0");
}
if(num2<0f){
text=text2;
}else if (num2>0f){
text="+"+text2;
}else{
num2=1f;
}
abw.randomEntry.Add(new RandomEntry{
description = buffInfo.name + text,
name = buffInfo.name,
buffName = buffInfo.name,
value = num2,
id = Guid.NewGuid().ToString()
});
} else if (entry!=""){
logger("在Dic_FabaoRandom_Entrys信息中找不到"+entry);
}
}
}
}
}
}
[Desc("铁拳无敌(空拳可以殴打全体敌方单位,造成流血,眩晕等等异常状态)")]
class IronFist : Entry {
public override void Enable() {
// 这段程序在 WholeObjects.Awake 之后,因此可以直接修改数据。
if(AllDictionary.Dic_SkillInfo.ContainsKey("空拳")){
AllDictionary.Dic_SkillInfo["空拳"].effectRange="点";
AllDictionary.Dic_SkillInfo["空拳"].releaseTarget= TbsFramework.Skill.ReleaseTarget.所有敌方;
AllDictionary.Dic_SkillInfo["空拳"].range= 0f;
AllDictionary.Dic_SkillInfo["空拳"].cost= 1;
for(int i=0;i<1;i++){
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("伤口");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("剧毒");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("伤口不被抵抗");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("剧毒不被抵抗");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("金煞");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("寄生");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("剧毒");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("感电");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("燃烧");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("火蚀");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("溶蚀");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("虚空蚀");
}
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("驱散护盾");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("强制眩晕4s");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("脑溢血*");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("封禁5s");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("虚爆");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("风咒·倍");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("雨咒·极");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("强制致残14s");
// AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("血蛊摄心·极*");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("血神诅咒");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("血流不止·极");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("极度恐惧");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("人运灭咒·伤");
AllDictionary.Dic_SkillInfo["空拳"].EffectOnHit.Add("人运灭咒·衰");
logger("铁拳无敌-patched");
}else{
logger("铁拳无敌:找不到“空拳”这个技能");
}
}
}
[HarmonyPatch(typeof(WholeObjects), "CreateDropItem")]
class WholeObjectsCreateDropItem : Entry {
[Desc("将可堆叠物品掉落数量变为物品掉落数量最大值乘以此数值")]
public static sbyte val=1;
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Ldfld,typeof(DropItem).GetField("minCount"))
).Repeat( matcher => // Do the following for each match
matcher
.SetAndAdvance(
OpCodes.Ldfld,typeof(DropItem).GetField("maxCount")
)
.Advance(1)
).InstructionEnumeration();
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Ldfld,typeof(DropItem).GetField("maxCount"))
).Repeat( matcher => // Do the following for each match
matcher
.Advance(1)
.InsertAndAdvance(
new CodeInstruction(OpCodes.Ldc_I4_S,(int)val),
new CodeInstruction(OpCodes.Mul)
)
.Advance(1)
).InstructionEnumeration();
return instructions;
}
}
[HarmonyPatch(typeof(PlantGrowFunction), "GetOutPut")]
class PlantGrowFunctionGetOutPut : Entry {
[Desc("将植物产量变为物品掉落数量最大值乘以此数值(有BUG,暂时禁用)")]
public static sbyte val=-1;
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Ldfld,typeof(PlantClass).GetField("output_min"))
).Repeat( matcher => // Do the following for each match
matcher
.SetAndAdvance(
OpCodes.Ldfld,typeof(PlantClass).GetField("output_max")
)
.Advance(1)
).InstructionEnumeration();
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Ldfld,typeof(PlantClass).GetField("output_max"))
).Repeat( matcher => // Do the following for each match
matcher
.Advance(1)
.InsertAndAdvance(
new CodeInstruction(OpCodes.Ldc_I4_S,(int)val),
new CodeInstruction(OpCodes.Mul)
)
.Advance(1)
).InstructionEnumeration();
return instructions;
}
}
[Desc("随机数设置为0(用于开启灭门/劫掠获取全部资源)")]
class RandomEnhancement : Entry {
public static List<MethodInfo> randomEnhancement=new List<MethodInfo>();
[Desc("灭门获得全部资源,有BUG,暂时禁用")]
bool miemen_getall=false;
[Desc("劫掠门派获得全部资源,有BUG,暂时禁用")]
bool robmen_getall=false;
[Desc("屠城获得全部资源,有BUG,暂时禁用")]
bool miecity_getall=false;
[Desc("劫掠城市获得全部资源,有BUG,暂时禁用")]
bool robcity_getall=false;
public override void Init() {
base.Init();
if(miemen_getall){
randomEnhancement.Add(typeof(Sect).GetMethod("BeDestroy",(BindingFlags)(-1)));
logger("随机数设置为0-灭门获得全部资源-added");
}
if(robmen_getall){
randomEnhancement.Add(typeof(Sect).GetMethod("BeRob",(BindingFlags)(-1)));
logger("随机数设置为0-劫掠门派获得全部资源-added");
}
if(miecity_getall){
randomEnhancement.Add(typeof(City).GetMethod("Destroy",(BindingFlags)(-1)));
logger("随机数设置为0-屠城获得全部资源-added");
}
if(robcity_getall){
randomEnhancement.Add(typeof(City).GetMethod("BeRob",(BindingFlags)(-1)));
logger("随机数设置为0-劫掠城市获得全部资源-added");
}
if(randomEnhancement.Count>0)this.Enable();
}
static IEnumerable<MethodBase> TargetMethods(){
foreach(MethodInfo m in randomEnhancement){
yield return m;
}
}
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Call,typeof(UnityEngine.Random).GetMethod("Range",new Type[]{typeof(int),typeof(int)}/*, and maybe some BindingFlags here*/))
).Repeat( matcher =>
matcher
.Advance(1)
.InsertAndAdvance(
new CodeInstruction(OpCodes.Pop),
new CodeInstruction(OpCodes.Ldc_I4_0)
)
.Advance(1),logger
).InstructionEnumeration();
return instructions;
}
}
[HarmonyPatch(typeof(BuildingManager), "AttackSect")]
class BuildingManagerAttackSect : Entry {
[Desc("灭门时 声望,门派善恶,玩家善恶 的改变量")]
public static string val="1000,100,100";
public static int a0=1000;
public static int a1=100;
public static int a2=100;
public override void Enable(){
var t=val.Split(',');
a0=int.Parse(t[0]);
a1=int.Parse(t[1]);
a2=int.Parse(t[2]);
base.Enable();
}
static void Postfix(){
Sect sect = WholeObjects.Instance.Dic_Sect["S_0"];
sect.shengWang += a0;
sect.shanE += a1;
WholeObjects.Instance.GetPlayer().shane += a2;
}
}
[Desc("好事件的字面值概率")]
[HarmonyPatch(typeof(DefaultInformation), "GetBaseGoodEvent")]
class ZhuangShiPanelGetBaseGoodEvent : Entry {
static bool Prefix(ref float __result){
__result=10f;
return false;
}
}
[HarmonyPatch(typeof(ZhuiSuiZhePanel), "ForceGetDizi")]
class ZhuiSuiZhePanelForceGetDizi : Entry {
[Desc("点击刷新弟子按钮时声望的增加值")]
public static int val=200;
static void Prefix(){
WholeObjects.Instance.GetPlayerSect().shengWang+=val;
}
}
[Desc("追随者只刷新气运之子")]
[HarmonyPatch(typeof(ZhuiSuiZhePanel), "ZhuiSuiZhe_Create")]
class ZhuiSuiZhePanelZhuiSuiZhe_Create : Entry {
static IEnumerable<CodeInstruction> Transpiler(MethodBase __originalMethod, IEnumerable<CodeInstruction> instructions) {
logger("%%PLUGIN_ID%%-正在注入类别"+__originalMethod.DeclaringType.Name+"的"+__originalMethod.Name+"方法");
instructions = new CodeMatcher(instructions)
.MatchForward(false, // false = move at the start of the match, true = move at the end of the match
new CodeMatch(OpCodes.Call,typeof(GeneralUtils).GetMethod("RandomBornRare",new Type[]{typeof(int),typeof(int)}))
).Repeat( matcher =>
matcher
.Advance(1)
.InsertAndAdvance(
new CodeInstruction(OpCodes.Pop),
new CodeInstruction(OpCodes.Ldc_I4_S,(int)Inborn.气运)
)
.Advance(1),logger
).InstructionEnumeration();
return instructions;
}
}
[HarmonyPatch(typeof(WholeObjects), "GetDropTermItems")]
class WholeObjectsGetDropTermItems : Entry {
[Desc("初始物品增加,1=全心法 2=全术法 4=全法宝配方 8=全丹药配方 16=全阵图配方 32=全植物999")]
public static sbyte val=63;
static List<ItemStored> Postfix(List<ItemStored> list, WholeObjects __instance, string dropTermID){
if(dropTermID!="玩家门派初始物品"){return list;}
if((val&1)==1){
list=list.Where(x=>x.type!=ItemType.心法书).ToList();
foreach(var shu in AllDictionary.Dic_XinFa.Values){
list.Add(__instance.CreateAXinfaBook(shu.Name, "", -1, false));
}
}
if((val&2)==2){
list=list.Where(x=>x.type!=ItemType.术法书).ToList();
foreach(var shu in AllDictionary.Dic_ShuFa.Values){
list.Add(__instance.CreateAShuFaBooK(shu.Name, "", false));
}
}
if((val&4)==4){
list=list.Where(x=>x.type!=ItemType.法宝配方).ToList();
foreach(var shu in AllDictionary.Dic_WeaponFormula.Values){
list.Add((ItemStored)typeof(WholeObjects).GetMethod("CreateNormalItem",(BindingFlags)(-1)).Invoke(__instance,new object[]{shu.Name, "", 1, false}));
}
}
if((val&8)==8){
list=list.Where(x=>x.type!=ItemType.丹药配方).ToList();
foreach(var shu in AllDictionary.Dic_PelletFormulaBook.Values){
list.Add((ItemStored)typeof(WholeObjects).GetMethod("CreateNormalItem",(BindingFlags)(-1)).Invoke(__instance,new object[]{shu.Name, "", 1, false}));
}
}
if((val&32)==32){
list=list.Where(x=>!AllDictionary.Dic_Plant.ContainsKey(x.name)).ToList();
foreach(var shu in AllDictionary.Dic_Plant.Values){
if (AllDictionary.Dic_Item.ContainsKey(shu.PlantName)){
list.Add((ItemStored)typeof(WholeObjects).GetMethod("CreateNormalItem",(BindingFlags)(-1)).Invoke(__instance,new object[]{shu.PlantName, "", 999, false}));
if(AllDictionary.Dic_Material.ContainsKey(shu.PlantName)){
var m=AllDictionary.Dic_Material[shu.PlantName];
logger("植物"+m.Name+":"+m.Jin+" "+m.Mu+" "+m.Shui+" "+m.Huo+" "+m.Tu);
} else {
logger("植物"+shu.PlantName+"不存在对应材料?");
}
} else {
logger("植物名称:"+shu.PlantName+" 不在AllDictionary.Dic_Plant中");
}
}
}
if((val&16)==16){
foreach(var shu in AllDictionary.Dic_StovePosBook.Values){
if((shu.Name[0]!="阴图"[0] || shu.Name[1]!="阴图"[1]) && (shu.Name[0]!="阳图"[0] || shu.Name[1]!="阳图"[1]) && (shu.Name[0]!="清图"[0] || shu.Name[1]!="清图"[1])){
list.Add((ItemStored)typeof(WholeObjects).GetMethod("CreateNormalItem",(BindingFlags)(-1)).Invoke(__instance,new object[]{shu.Name, "", 1, false}));
}
}
}
return list;
}
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C#
1
https://gitee.com/likefengzi/Unity_Mod.git
[email protected]:likefengzi/Unity_Mod.git
likefengzi
Unity_Mod
Unity mod
master

搜索帮助