hubotと戯れてみる #5 slackとhubotでオセロゲーム。華麗なるエンディング?

hubotと戯れてみる #5 slackとhubotでオセロゲーム。華麗なるエンディング?

ソフトバンク・au・ドコモの方は、公式のオンラインショップを利用すれば頭金不要で通常のショップよりお得に購入できます。

slack上でhubotを利用してオセロゲームを作っています。今回はゲーム終了判定とエンディングを実装します。前回は石をひっくり返す処理を実装しました。

slackとhubotでオセロゲーム編

#1 slackと連携するhubotを3分でインストールする。(動画付き)
#2 slackとhubotを利用してオセロゲームを作ってみる。
#3 slackとhubotでオセロゲーム。とりあえず石を置いてみる。
#4 slackとhubotでオセロゲーム。石をひっくり返す。
#5 slackとhubotでオセロゲーム。華麗なるエンディング? ← ← 今ここ

さて、slackとhubotでオセロゲーム編も今回で最後となります。気合を入れて実装していきます。

処理の流れ

処理の流れはこんな感じ、前回の流れに追加します。

  1. ボードの状態とターンの状態を取得します。 ← 前回作りました。
  2. メッセージから指示された石を置く座標を抜き取ります。 ← 前回作りました。
  3. 石が置ける場所か判定する。 ← 前回作りました。
  4. ひっくり返す石を判定する。 ← 前回作りました。
  5. 盤上に石を置きます。 ← 前回作ったものを修正
  6. ターンをチェンジします。 ← 前回作りました。
  7. 盤上の情報とターン情報を保存します。 ← 前回作りました。
  8. ゲーム終了判定を行う。終了ならエンディング ← 新たに追加
  9. メッセージを返します。 ← 前回作りました。

では、実装します。

8.ゲーム終了判定を行う。終了ならエンディング [追加]

checkGameEnd関数は簡単です。bordArrayを検索して□がないか調べるだけです。

outputEnding関数は、エンディングメッセージを流す関数です。

石の数を数えたり、どちらが勝者か返したりするのも良いかもしれません。ソースには加えていませんが、私の環境ではランダムで画像を返すように実装しています。

以上で、slackとhubotでオセロゲームの連載は終了です。次は、どのゲームを移植しようかなっと!!

本日作成したファイルは、こちらに置いてあります。

最後に

えっと。。。。。。。実はこの記事を書いている段階で、機能を1つ実装し忘れた事に気が付きました。それは、パスをする機能です。いずれどこなのタイミングで号外として実装しようかなと思います。

ソフトバンク・au・ドコモの方は、公式のオンラインショップを利用すれば頭金不要で通常のショップよりお得に購入できます。

【週刊bitWave】(メルマガ)始めました!

登録はこちらからメールアドレスを入力してお申込みください。

ご登録いただいたメールアドレスは 【週刊bitWave】の更新情報の配信にのみ使用します。

個人情報の取扱いに関しては、「プライバシーポリシー」をご確認ください。解除はいつでもこちらから行うことが可能です。

あなたにおすすめ

仮想環境で『Ansible』を使ってサーバ構築... 最近、サーバ構築を実施する必要がありました。 まずは仮想環境を作り、サーバ構築を……と思ったのですが、私はインフラ周りの経験が浅く、色々困ったことが頻出してしまいました。 今回の記事では、私と同じような “サーバ構築ビギナー” ...
「Puppeteer」+「LINE Notify」でサイトの更新時のみ通知を受け取ってみる... 前回の記事では閲覧数向上が期待できそうなキーワードの「Puppeteer」と「LINE Notify」のそれぞれの解説、およびサイトのサムネイルを通知してみるといった試みを実施してみました。 <bitWave関連記事『「Puppeteer...
Vue.jsで社用登録データフォームを作ってみた... 今回は社内用データ登録フォームを作ろうと思い、初めて「Vue.js」を試してみることにしました。 「Vue.js」は使い方、書き方も簡単で、初心者もすぐ活用できるjsだと思いましたので、この場を借りて共有させていただきます。 なお、...
「Puppeteer」+「LINE Notify」でサイトのサムネイルを通知してみる... 今回は記事閲覧数が期待できそうなキーワードを用いて、ブログを書いてみようかと思います。 そのキーワードとは…… 「Puppeteer」と「LINE Notify」。 「Puppeteer」って何? 「LINE Notify」って...