mirai/docs/guide_quick_start.md

104 lines
2.9 KiB
Markdown
Raw Normal View History

2020-02-20 20:58:40 +08:00
# Mirai Guide - Quick Start
2020-05-11 16:05:41 +08:00
由于 mirai 项目在快速推进中,因此内容时有变动,本文档的最后更新日期为```2020/5/11```,对应版本```1.0-RC2-1```
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
本文适用于对 Kotlin 较熟悉的开发者,
2020-06-15 16:22:54 +08:00
使用 mirai 作为第三方依赖库引用到任意一个 Kotlin, Java 或其他 JVM 平台的项目
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
**若你希望一份更基础的教程**, 请参阅: [mirai-guide-getting-started](guide_getting_started.md)
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
## 构建需求
2020-02-20 20:58:40 +08:00
2020-04-04 11:13:26 +08:00
- Kotlin 1.3.71 (必须)
2020-03-01 12:08:35 +08:00
- JDK 6 或更高 (必须)
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
## 获取 Demo
可在 [mirai-demos](https://github.com/mamoe/mirai-demos) 中获取已经配置好依赖的示例项目.
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
## Quick Start
2020-02-20 20:58:40 +08:00
2020-03-01 12:08:01 +08:00
请将 `VERSION` 替换为 `mirai-core` 的最新版本号(如 `0.23.0`):
2020-02-20 20:58:40 +08:00
[![Download](https://api.bintray.com/packages/him188moe/mirai/mirai-core/images/download.svg)](https://bintray.com/him188moe/mirai/mirai-core/)
2020-03-01 12:08:01 +08:00
### 添加依赖
2020-06-16 13:55:01 +08:00
可通过以下三种方法之一添加 mirai 依赖.
#### 直接导入jar包 (不推荐)
下载已经编译好的 Jar 包, 并添加 Jar 依赖:
- [mirai-core](https://github.com/mamoe/mirai-repo/tree/master/shadow/mirai-core)
- [mirai-qqandriod](https://github.com/mamoe/mirai-repo/tree/master/shadow/mirai-core-qqandroid)
2020-06-16 13:55:01 +08:00
2020-03-01 12:08:01 +08:00
#### Maven
2020-02-20 20:58:40 +08:00
Kotlin 在 Maven 上只支持 JVM 平台.
```xml
<repositories>
<repository>
<id>jcenter</id>
<url>https://jcenter.bintray.com/</url>
</repository>
</repositories>
```
```xml
<dependencies>
<dependency>
<groupId>net.mamoe</groupId>
2020-04-30 14:42:39 +08:00
<artifactId>mirai-core-qqandroid</artifactId>
2020-02-29 13:56:23 +08:00
<version>0.23.0</version> <!-- 替换版本为最新版本 -->
2020-02-20 20:58:40 +08:00
</dependency>
</dependencies>
```
2020-06-16 13:55:01 +08:00
#### Gradle (推荐)
2020-02-20 20:58:40 +08:00
Mirai 只发布在 `jcenter`, 因此请确保添加 `jcenter()` 仓库:
```kotlin
repositories{
jcenter()
}
```
**注意:**
Mirai 核心由 API 模块(`mirai-core`)和协议模块组成。
只添加 API 模块将无法正常工作。
现在只推荐使用 QQAndroid 协议,请参照下文选择对应目标平台的依赖添加。
2020-03-01 12:08:01 +08:00
**jvm** (JVM 平台源集)
2020-02-20 20:58:40 +08:00
```kotlin
2020-04-30 14:42:39 +08:00
implementation("net.mamoe:mirai-core-qqandroid:VERSION")
2020-02-20 20:58:40 +08:00
```
2020-03-01 12:08:01 +08:00
**common** (Kotlin 多平台项目的通用源集)
2020-02-20 20:58:40 +08:00
```kotlin
implementation("net.mamoe:mirai-core-qqandroid-common:VERSION")
```
2020-03-01 12:08:01 +08:00
**android** (Android 平台源集)
2020-04-10 16:13:03 +08:00
**注意**: 在 [KT-37152](https://youtrack.jetbrains.com/issue/KT-37152) 修复前, mirai 无法支持 Android 平台目标.
2020-02-20 20:58:40 +08:00
```kotlin
implementation("net.mamoe:mirai-core-qqandroid-android:VERSION")
```
2020-03-01 12:08:01 +08:00
### 开始使用
2020-02-20 20:58:40 +08:00
```kotlin
val bot = Bot(qqId, password).alsoLogin()
2020-05-11 16:05:41 +08:00
bot.subscribeAlways<GroupMessageEvent> { event ->
if (event.message.content.contains("你好")) {
2020-06-16 13:55:01 +08:00
reply("你好!")
2020-05-11 16:05:41 +08:00
} else if (event.message.content.contains("你好")) {
2020-05-28 14:12:52 +08:00
File("C:\\image.png").sendAsImage()
2020-05-11 16:05:41 +08:00
}
2020-02-20 20:58:40 +08:00
}
2020-05-11 16:05:41 +08:00
bot.subscribeAlways<MemberPermissionChangedEvent> { event ->
if (event.kind == BECOME_OPERATOR)
reply("${event.member.id} 成为了管理员")
2020-02-20 20:58:40 +08:00
}
2020-03-26 16:42:02 +08:00
```