mirai/docs/guide_subscribe_events.md
2020-02-21 17:38:24 +08:00

4.0 KiB
Raw Blame History

Mirai Guide - Subscribe Events

由于Mirai项目在快速推进中因此内容时有变动本文档的最后更新日期为2020-02-21,对应版本0.17.0

本页面采用Kotlin作为开发语言若你希望使用 Java 开发, 请参阅: mirai-japt

本页面是Mirai Guide - Getting Started的后续Guide

消息事件-Message Event

首先我们来回顾上一个Guide的源码

suspend fun main() {
    val qqId = 10000L//Bot的QQ号需为Long类型在结尾处添加大写L
    val password = "your_password"//Bot的密码
    val miraiBot = Bot(qqId, password).alsoLogin()//新建Bot并登录
    miraiBot.subscribeMessages {
        "你好" reply "你好!"
        case("at me") {
            reply(sender.at() + " 给爷爬 ")
        }

        (contains("舔") or contains("刘老板")) {
            "刘老板太强了".reply()
        }
    }
    miraiBot.join() // 等待 Bot 离线, 避免主线程退出
}

在本例中,miraiBot是一个Bot对象让其登录然后对Message Event进行了监听。

对于Message EventMirai提供了较其他Event更强大的MessageSubscribersBuilder,本例也采用了MessageSubscribersBuilder。其他具体使用方法可以参考Wiki:Message Event部分。

事件-Event

上一节中提到的Message Event仅仅是众多Event的这一种,其他Event有群员加入群,离开群,私聊等等...

具体doc暂不提供现可翻阅源码BotEvents.kt,查看注释。当前事件仍在扩充中,可能有一定不足。

下面我们开始示例对一些事件进行监听。

尝试监听事件-Try Subscribing Events

监听加群事件

在代码中的miraiBot.join()前添加

miraiBot.subscribeAlways<MemberJoinEvent> {
        it.group.sendMessage("欢迎 ${it.member.nameCardOrNick} 加入本群!")
}

本段语句监听了加入群的事件。

监听禁言事件

在代码中添加

miraiBot.subscribeAlways<MemberMuteEvent> (){
        it.group.sendMessage("恭喜老哥 ${it.member.nameCardOrNick} 喜提禁言套餐一份")
}

在被禁言后Bot将发送恭喜语句。

添加后的可执行代码

至此,当前的代码为

package net.mamoe.mirai.simpleloader

import kotlinx.coroutines.*
import net.mamoe.mirai.Bot
import net.mamoe.mirai.alsoLogin
import net.mamoe.mirai.event.subscribeMessages
import net.mamoe.mirai.contact.nameCardOrNick
import net.mamoe.mirai.contact.sendMessage
import net.mamoe.mirai.event.events.MemberJoinEvent
import net.mamoe.mirai.event.events.MemberMuteEvent
import net.mamoe.mirai.event.subscribeAlways

suspend fun main() {
    val qqId = 10000L//Bot的QQ号需为Long类型在结尾处添加大写L
    val password = "your_password"//Bot的密码
    val miraiBot = Bot(qqId, password).alsoLogin()//新建Bot并登录
    miraiBot.subscribeMessages {
        "你好" reply "你好!"
        case("at me") {
            reply(sender.at() + " 给爷爬 ")
        }

        (contains("舔") or contains("刘老板")) {
            "刘老板太强了".reply()
        }
    }
    miraiBot.subscribeAlways<MemberJoinEvent> {
        it.group.sendMessage("欢迎 ${it.member.nameCardOrNick} 加入本群!")
    }
    miraiBot.subscribeAlways<MemberMuteEvent> (){
        it.group.sendMessage("恭喜老哥 ${it.member.nameCardOrNick} 喜提禁言套餐一份")
    }
    miraiBot.join() // 等待 Bot 离线, 避免主线程退出
}