HearthBuddy Plugin编写遇到的问题
错误1 赋值问题
貌似编译器版本有点低,无法识别C#的高级语法糖
属性的初始值,必须是public bool IsEnabled { get{return true;} }
不能写成public bool IsEnabled { get; }=true;
Control
Compiler Error: \Plugins\AutoConcede\AutoConcede.cs(75,38) :
error CS0840: 'AutoConcede.AutoConcede.Control.get' must declare a body because it is not marked abstract or extern. Automatically implemented properties must define both get and set accessors.
Compiler Error: c:\Users\clu\Desktop\Hearthbuddy 0.3.1446.417\Plugins\AutoConcede\AutoConcede.cs(76,40) : error CS0840: 'AutoConcede.AutoConcede.Settings.get' must declare a body because it is not marked abstract or extern. Automatically implemented properties must define both get and set accessors.
2019-07-16 14:22:58,834 [14] DEBUG Logger (null) - [AutoConcede] Initialize
自动投降不工作,提示是
2019-07-16 15:10:03,568 [5] INFO Logger (null) - [Concede] GameState == null.
2019
public static bool Concede(bool logReason)
{
bool result;
try
{
if (GameState.Get() == null)
{
if (logReason)
{
TritonHs.ilog_0.InfoFormat("[Concede] GameState == null.", Array.Empty<object>());
}
result = false;
}
else if (!GameUtils.CanConcedeCurrentMission())
{
TritonHs.ilog_0.InfoFormat("[Concede] !GameUtils.CanConcedeCurrentMission().", Array.Empty<object>());
result = false;
}
else
{
GameState.Get().Concede();
using (TritonHs.Memory.ReleaseFrame(true))
{
Thread.Sleep();
}
result = true;
}
}
catch (Exception ex)
{
if (logReason)
{
TritonHs.ilog_0.InfoFormat("[Concede] An exception occurred. {0}", ex.ToString());
}
result = false;
}
return result;
}
关于在选牌阶段,以及回合开始投降
https://tieba.baidu.com/p/5929349383?red_tag=2707770290
Hearthbuddy\Routines\DefaultRoutine\DefaultRoutine.cs
public async Task MulliganLogic(MulliganData mulliganData)
public async Task OurTurnLogic()
DefaultRoutine继承了Triton.Bot.IRoutine接口
public interface IRoutine : IRunnable, IAuthored, IBase, IConfigurable
{
// Token: 0x06001185 RID: 4485
void SetConfiguration(string name, params object[] param); // Token: 0x06001186 RID: 4486
object GetConfiguration(string name); // Token: 0x06001187 RID: 4487
Task<bool> Logic(string type, object context);
}
主要逻辑的入口,都是在Logic函数里面
/// <summary>
/// The routine's coroutine logic to execute.
/// </summary>
/// <param name="type">The requested type of logic to execute.</param>
/// <param name="context">Data sent to the routine from the bot for the current logic.</param>
/// <returns>true if logic was executed to handle this type and false otherwise.</returns>
public async Task<bool> Logic(string type, object context)
{ // The bot is requesting mulligan logic.
if (type == "mulligan")
{
await MulliganLogic(context as MulliganData);
return true;
} // The bot is requesting emote logic.
if (type == "emote")
{
await EmoteLogic(context as EmoteData);
return true;
} // The bot is requesting our turn logic.
if (type == "our_turn")
{
await OurTurnLogic();
return true;
} // The bot is requesting opponent turn logic.
if (type == "opponent_turn")
{
await OpponentTurnLogic();
return true;
} // The bot is requesting our turn logic.
if (type == "our_turn_combat")
{
await OurTurnCombatLogic();
return true;
} // The bot is requesting opponent turn logic.
if (type == "opponent_turn_combat")
{
await OpponentTurnCombatLogic();
return true;
} // The bot is requesting arena draft logic.
if (type == "arena_draft")
{
await ArenaDraftLogic(context as ArenaDraftData);
return true;
} // The bot is requesting quest handling logic.
if (type == "handle_quests")
{
await HandleQuestsLogic(context as QuestData);
return true;
} // Whatever the current logic type is, this routine doesn't implement it.
return false;
}
无法识别Object,必须改成小写的object
如何确定插件是否加载成功
查看plugins的tab那边是否显示了相应的插件,如果没有显示,就说明插件编译失败。可以去日志文件看细节
需要依据GameEventManager 中的事件,来决定如何写代码
public class GameEventManager : IRunnable, IResetable
2019-07-17 11:51:33,227 [19] DEBUG Logger (null) - [AutoConcede] ConcedeThread for loop, index = 1
2019-07-17 11:51:33,228 [14] INFO Logger (null) - [GameEventManagerOnMulliganConfirm]
2019-07-17 11:51:49,782 [14] ERROR Logger (null) - [Tick] Exception during execution:
GreyMagic.InjectionDesyncException: Process must have frozen or gotten out of sync: Injection Finished Event was never fired
at GreyMagic.Executor.WaitForInjection(Int32 timeout)
at GreyMagic.Executor.SharedExecuteLogicEnd(Int32 timeout)
at GreyMagic.Executor.Execute(Int32 timeout)
at GreyMagic.Executor.GrabFrame()
at GreyMagic.ExternalProcessMemory.AcquireFrame(Boolean isHardLock)
at Triton.Bot.BotManager.smethod_1(IBot ibot_1)
2019-07-17 11:51:49,785 [14] DEBUG Logger (null) - [BotThreadFunction] An InjectionDesyncException was detected.
HearthBuddy Plugin编写遇到的问题的更多相关文章
- Bootstrap plugin编写
滚动demo: <!doctype html> <html lang="en"> <head> <meta charset="U ...
- lua 5.3最简单plugin编写
#include <windows.h> #include "lauxlib.h" /* Pop-up a Windows message box with your ...
- AS 自定义 Gradle plugin 插件 案例 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- 使用 CodeIgniter 框架快速开发 PHP 应用(三)
原文:使用 CodeIgniter 框架快速开发 PHP 应用(三) 分析网站结构既然我们已经安装 CI ,我们开始了解它如何工作.读者已经知道 CI 实现了MVC式样. 通过对目录和文件的内容进行分 ...
- 使用dropwizard(4)-加入测试-jacoco代码覆盖率
前言 dropwizard提供了一个简单的测试框架.这里简单集成并加入jacoco测试. Demo source https://github.com/Ryan-Miao/l4dropwizard 本 ...
- 30分钟带你了解Docker
最近一直在忙项目,不知不觉2个多月没有更新博客了.正好自学了几天docker就干脆总结一下,也顺带增加一篇<30分钟入门系列>.网上能够查到的对于docker的定义我就不再重复了,说说我自 ...
- MQTT---HiveMQ源代码具体解释(四)插件载入
源博客地址:http://blog.csdn.net/pipinet123 MQTT交流群:221405150 实现功能 将全部放在plugins文件夹下的全部符合plugin编写规范的plugin ...
- 掘金 Android 文章精选合集
掘金 Android 文章精选合集 掘金官方 关注 2017.07.10 16:42* 字数 175276 阅读 50053评论 13喜欢 669 用两张图告诉你,为什么你的 App 会卡顿? - A ...
- 什么是SpringBoot
随着动态语言的流行(Ruby,Groovy,Scala,Node.js),Java的开发显得格外的笨重;繁多的配置,低下的开发效率,复杂的部署流程以及第三方技术集成难度大. 在上述环境 下,Sprin ...
随机推荐
- PHP获取某段文字作为标题
<?php mb_internal_encoding('utf-8'); // 提取文字标题,多余文字用省略号替换 $arr=[ '用心用情用功,进行无愧于时代的文艺创造', '一图了解第二届一 ...
- string字符串长度和字节长度问题
string str = "abcdef 安安安"; int i = str.Length; byte[] bt = System.Text.Encoding.Default.Ge ...
- linux wireless 基础知识 MAC80211 CFG80211
转:http://blog.csdn.net/liuxd3000/article/details/23761663 1. 基本概念 • cfg80211: 用于对无线设备进行配置管理.与Full ...
- busybox date 时间的加减
1.下载安装busybox: # wget http://busybox.net/downloads/busybox-1.29.3.tar.bz2 # tar -jxvf busybox-.tar.b ...
- java HttpClientUtil帮助类
自己写的java模拟请求帮助类,已经包含header头构造,会话session维持 package com.haozl.back.util; import java.io.File; import j ...
- 异步IO框架:asyncio 中篇
上一节我们首先介绍了,如何创建一个协程对象.主要有两种方法 通过async关键字, 通过@asyncio.coroutine 装饰函数. 然后有了协程对象,就需要一个事件循环容器来运行我们的协程.其主 ...
- index首页加载数据库数据方法
https://blog.csdn.net/qq_33198758/article/details/82987805 在做网站的时候,会遇到需要首页加载数据库数据的情况.而web.xml配置的首页: ...
- win10日历交互效果
win10日历 早就想试着实现以下win10日历的动态css效果,现在终于有时间试试啦.本篇文章只是实现简单的效果,进阶篇后续会放上来 目标效果 鼠标移入目标元素,周围相关八块元素点亮,点亮高光范围呈 ...
- HDU 6033 - Add More Zero | 2017 Multi-University Training Contest 1
/* HDU 6033 - Add More Zero [ 简单公式 ] | 2017 Multi-University Training Contest 1 题意: 问 2^n-1 有几位 分析: ...
- C#静态变量 总结
在C#程序中,没有全局变量的概念,这意味着所有的成员变量只有该类的实例才能操作这些数据,这起到了“信息隐藏”的作用.但有些时候,这样做却不是个明智的选择. 假设我们要定义一个图书类,要求该类能保存图书 ...