プログラミング

PHPポケモン「バトルシステム編〜努力値の獲得〜」33

PHP PHPポケモン ポケモン
PHPポケモン「バトルシステム編〜努力値の獲得〜」33

努力値の実装

今回はポケモンのやりこみ要素の一つ、努力値システムを導入します。既に努力値の項目は「ピカチュウで学ぶオブジェクト指向」の段階で実装し、ステータス計算にも判定済みですが、肝心な「努力値を獲得する仕組み」自体は出来ていませんでした。なので、バトルシステムも終盤となったこのタイミングで実装していきましょう。

ピカチュウから学ぶオブジェクト指向 〜入門編〜 1 ピカチュウから学ぶオブジェクト指向 〜入門編〜 1

オブジェクト指向とは  オブジェクト指向プログラミング https://ja.wikipedia.org/wiki/オブジェクト指向プログラミング オブジェクト指向プログラミングとは、互いに密接な関連性を持つデータとメソッドをひとつにまとめてオブジェクトとし、それぞれ異なる性質と役割を持たせたオブジェクトの様々な定...

 

努力値とは

そもそも努力値とはどういったものなのか見ていきましょう。 

努力値(どりょくち、英:Effort values)とは、ポケモンの強さにかかわる数値のひとつ。ステータス画面では確認できない隠しパラメータの一つである。

なお、努力値という言葉は俗称であり、ゲーム内では基礎ポイントと呼ばれている。

 

ポケモンは戦闘の後に、経験値を得ると同時に、これとは別の「隠し経験値」のようなものも獲得するようになっており、この数値もステータス上昇に影響する。これが通称「努力値」、もしくは「基礎ポイント」である。

努力値(ポケモンwiki

 

ということです。簡単に説明すると、バトルに勝利することで経験値の他にもらえる隠しポイントといったところです。これはステータスの数値に影響するため、効率良い獲得をすることで他のポケモンとは大きく差別化できる強いポケモンに育て上げることが可能になります。

 

PHPポケモンで努力値システムを導入するに当たっておさえて置きたいのは以下の3項目です。 

  1. ポケモンを倒すと、そのポケモンが持つ獲得努力値を得られる
  2. 努力値は全ステータス合計最大510
  3. 努力値は1ステータス最大252

 

それでは、上記3点に注意しながら実装していきましょう。

  

獲得努力値

 まずは獲得努力値の実装です。本来アイテムを使って努力値を得ることも可能ですが、現在はアイテムの概念が無いため戦闘による獲得のみを実装します。

 

ポケモンを倒すことで、そのポケモンが保有している「獲得努力値」を得ることができます。例えばPHPサンドバック野生ポケモンとして出てくれているフシギダネであれば、「とくこう+1」という獲得努力値を持っています。こちらも最新世代を参考にしながらポケモンへ割り当てていきます。

 

それではフシギダネに獲得努力値のプロパティ($reward_ev)をセットしましょう。

 

フシギダネ(/Classes/Pokemon/Fushigidane.php
/**
* 獲得努力値
* @var array
*/
protected $reward_ev = [
    'SpAtk' => 1,
];

 

参考ページを見て気づいた方もいるかも知れませんが、獲得努力値は1項目だけではありません。中には「こうげき」と「とくこう」など複数の項目に対して努力値を与えてくれるポケモンもいます。なので、あくまで複数を想定しておきましょう。

 

次に、獲得努力値の取得処理を作成しましょう。

 

Get格納トレイト(Traits/Pokemon/GetTrait.php
/**
* 獲得努力値を取得する
* @return array
*/
public function getEv()
{
    return $this->ev;
}
 
/**
* 獲得努力値を取得する
* @return array
*/
public function getRewardEv()
{
    return $this->reward_ev;
}

 

後ほど努力値が正常に取得できているかを確認するために、getEvというメソッドも合わせて作成しています。

 これで獲得努力値の準備は完了です。

 

努力値の付与

次に努力値の付与機能を作成しましょう。まずは努力値を割り当てるためのメソッド(setEv)を作成します。

 

Set格納トレイト(/Traits/Pokemon/SetTrait.php
/**
* 努力値をセット(取得)する
* @param array $reward_ev
* @return void
*/
public function setEv($reward_ev)
{
    // 最大努力値合計は510
    if(array_sum($this->ev) >= 510){
        return;
    }
    // 努力値を加算
    foreach($reward_ev as $key => $val){
        $this->ev[$key] += $val;
        // 各ステータスの最大は252
        if($this->ev[$key] > 252){
            $this->ev[$key] = 252;
        }
        // 最大努力値を超過させないための処理
        if(array_sum($this->ev) > 510){
            // 510超過分をセットした努力値から減算
            $this->ev[$key] -= array_sum($this->ev) - 510;
            break;
        }
    }
}

 

引数には獲得努力値(配列)を受け取っています。

まず最初に、現在の努力値合計がどれぐらいあるかをチェックします。前項で説明した通り、合計最大努力値は510と決まっています。上限を超えてしまわないよう、まずは現在ポケモンが保有している努力値の合計をarray_sumを使って算出します。

 

もし510以上だった場合はそこで処理終了です。

合計最大値をオーバーしていなければ、獲得経験値をforeachにかけて順番に処理をします。

 

次に各ステータスの上限値を制限します。

// 各ステータスの最大は252
if($this->ev[$key] > 252){
    $this->ev[$key] = 252;
}

 

1ステータスの最大値は252です。なので、加算結果が252を超過しているようであれば、252を再セットすることで対応します。

 

これで処理自体は問題ないように思えますが、努力値を複数もつポケモンがいるということを忘れてはいけません。例えば「バタフリー」を倒したケースで考えてみましょう。

 

バタフリーの獲得努力値は「とくこう+2」「とくぼう+1」です。もし合計最大値のチェック、個別最大値のチェックだけであれば、とくこう努力値を2取得した段階で合計努力値が510になっても、とくぼう努力値が252未満であればforeachの処理で+1されてしまい、合計努力値が511になるのです。ステータス上では端数となる1という努力値ですが、もし獲得努力値が2で、その結果が「252、252、6+2(超過分)」のような割り振りになれば、本来割り振れないステータスが1存在してしまうことになります。

このような例外による端数を規制するためにも、個別ステータスの算出後に再度合計値のチェックを行い、510を超過していた場合は超過分を加算したステータスから減算します。

// 最大努力値を超過させないための処理
if(array_sum($this->ev) > 510){
    // 510超過分をセットした努力値から減算
    $this->ev[$key] -= array_sum($this->ev) - 510;
    break;
}

もし最大努力値数のチェックを2度実行したくない人は、最初の合計最大値のチェックを削除してもらって構いません。個人的に努力値がオーバーしている状態でforeachの処理に入らせたくなかったため、前処理で弾くようにしています。

 

これで努力値の加算処理は実装完了です。

  

バトル結果判定の修正

 作成した努力値の取得メソッドは経験値取得のタイミングで行います。ですが、前回までのバトル終了判定だと「状態異常または状態変化による戦闘不能」が起こった際にバトル終了判定が行われないという不具合が発覚したため、合わせて修正します。

 

バトルコントローラー(/Classes/Controller/BattleController.php
/**
* ひんし状態の格納
* @var array
*/
private $fainting = [
    'friend' => false,
    'enemy' => false,
];
 
--省略
 
/**
* アクション
*
* @param string $action
* @param mixed $param
* @return void
*/
private function action($action, $param)
{
    // 敵ポケモンの技をインスタンス化
    $e_move = $this->getInstance($this->aiSelectMove());
    switch ($action) {
        /**
        * にげる
        */
        case 'run':
        $this->run++;
        if($this->checkRun()){
            $this->endBattle();
        }
        $this->setMessage('逃げられない!');
        // 敵ポケモンの攻撃
        $p_damage = $this->attack($this->enemy, $this->pokemon, $e_move);
        break;
        /**
        * たたかう
        */
        case 'fight':
        // 自ポケモンの技をインスタンス化
        $p_move = $this->getInstance($param);
        // 行動順の判定
        $order_array = $this->orderMove(
            [$this->pokemon, $this->enemy, $p_move],
            [$this->enemy, $this->pokemon, $e_move],
        );
        // 行動順にforeachでattackメソッドを実行
        foreach($order_array as list($atk, $def, $move)){
            $this->attack($atk, $def, $move);
            // ひんしチェック
            if($this->setToCheckFainting($def, $atk)){
                // ひんしポケモン有り
                break 2;
            }
        }
        // 行動順にforeachでcheckAfterSaとcheckAfterScを実行
        foreach($order_array as list($atk, $def, $move)){
            $this->checkAfterSa($atk);
            $this->checkAfterSc($atk, $def);
            // ひんしチェック
            if($this->setToCheckFainting($def, $atk)){
                // ひんしポケモン有り
                break 2;
            }
        }
        $this->setMessage('行動を選択してください');
        break;
    }
    // ひんしポケモンがでた場合の処理
    if($this->fainting['enemy'] || $this->fainting['friend']){
        $this->judgment();
    }
}
 
--省略
 
/**
* ひんし状態の格納
*
* @return boolean (true:ひんしポケモン有り, false:ひんしポケモン無し)
*/
private function setToCheckFainting($def, $atk)
{
    // 防御側のひんし状態を格納
    $this->fainting[$def->getPosition()] = $this->checkFainting($def);
    // 攻撃側のひんし状態を格納
    $this->fainting[$atk->getPosition()] = $this->checkFainting($atk);
    // 返り値判定
    if($this->fainting['enemy'] || $this->fainting['friend']){
        return true;
    }
    return false;
}
 
/**
* バトル結果判定
*
* @return void
*/
private function judgment()
{
    if($this->fainting['friend']){
        // 味方がひんし状態になった
        $this->setMessage('目の前が真っ暗になった');
    }else{
        // 相手がひんし状態になった(味方はひんし状態ではない)
        // 経験値の計算
        $exp = $this->calExp($this->pokemon, $this->enemy);
        // 経験値をポケモンにセット(返り値をpokemonに格納)
        $this->pokemon = $this->pokemon
        ->setExp($exp);
        // 努力値を獲得
        $this->pokemon
        ->setEv($this->enemy->getRewardEv());
        // ポケモンに溜まったメッセージを取得
        $this->setMessage($this->pokemon->getMessages());
    }
    // バトル終了判定用メッセージの格納
    $this->setMessage(' ', 'battle-end');
}

 

アクションメソッドを修正、ひんし状態をプロパティに格納してチェックまでを行うメソッド(setToCheckFainting)とバトル結果判定(judgment)の2つのメソッドを作成しました。

 

今までは攻撃メソッド(attack)内でひんし判定を行い、返り値としてその結果をactionメソッドに伝えていましたが、ひんし判定を新しく作成したsetToCheckFaintingで行なっています。行動後の状態異常・変化判定でのひんし判定も無くし、返り値は無しに変更しました。

※attackメソッド内のひんし判定を削除した関係上、追加効果の判定は残HPで行なっています

 

攻撃用トレイト(/Traits/Battle/AttackTrait.php
/**
* 攻撃
* (攻撃→ダメージ計算→ひんし判定)
*
* @param object $atk_pokemon
* @param object $def_pokemon
* @param object $move
* @return void
*/
protected function attack($atk_pokemon, $def_pokemon, $move)
{
    // 行動チェック(状態異常・状態変化)
    if(!$this->checkBeforeSa($atk_pokemon) || !$this->checkBeforeSc($atk_pokemon)){
        // 行動失敗
        return;
    }
    // 攻撃メッセージを格納
    $this->setMessage($atk_pokemon->getPrefixName().'は'.$move->getName().'を使った!');
    // タイプ相性チェック
    $type_comp_msg = $this->checkTypeCompatibility($move->getType(), $def_pokemon->getTypes());
    // 「こうかがない」の判定(命中率と威力がnullではなく、タイプ相性補正が0の場合)
    if(!is_null($move->getAccuracy()) && !is_null($move->getPower()) && ($this->m === 0)){
        // こうかがない
        $this->setMessage($def_pokemon->getPrefixName().'には効果が無いみたいだ');
        return;
    }
    // 命中判定
    $hit = $this->checkHit($move->getAccuracy());
    if(!$hit){
        // 攻撃失敗
        $this->setMessage('しかし攻撃は外れた!');
        return;
    }
    // 必要ステータスの取得
    $stats = $this->getStats($move->getSpecies(), $atk_pokemon, $def_pokemon);
    // ダメージ計算
    if($move->getSpecies() !== 'status'){
        /**
        * 物理,特殊技
        */
        if(!is_null($move->getPower())){
            // 急所判定(固定ダメージ技は判定不要)
            $critical = $this->checkCritical($move->getCritical());
            if($critical){
                $this->setMessage('急所に当たった!');
            }
        }
        // 乱数補正値の計算
        $this->calRandNum();
        // タイプ一致補正の計算
        $this->calMatchType($move->getType(), $atk_pokemon->getTypes());
        // ダメージ計算
        $damage = $this->calDamage(
            $atk_pokemon->getLevel(),   # 攻撃ポケモンのレベル
            $stats['a'],                # 攻撃ポケモンの攻撃値
            $stats['d'],                # 防御ポケモンの防御値
            $move->getPower(),          # 技の威力
            $this->m,                   # 補正値
        );
        // やけど補正
        if(($move->getSpecies() === 'physical') && ($atk_pokemon->getSa() === 'SaBurn')){
            // 物理且つやけど状態ならダメージを半減
            $damage *= 0.5;
        }
        // タイプ相性のメッセージを返却
        $this->setMessage($type_comp_msg);
    }else{
        /**
        * 変化技
        */
        $damage = 0;
    }
    // ダメージ計算
    $def_pokemon->calRemainingHp('sub', $damage);
    // 追加効果(相手にHPが残っていれば)
    if($def_pokemon->getRemainingHp()){
        // 追加効果
        $move->effects($atk_pokemon, $def_pokemon);
        // 追加効果のメッセージをセット
        $this->setMessage($move->getMessages());
        return;
    }
}

 

チェック格納トレイト(/Traits/Battle/CheckTrait.php
/**
* アタック後の状態異常チェック
*
* @param object Pokemon
* @return void
*/
protected function checkAfterSa($pokemon)
{
    if(empty($pokemon->getSa())){
        // 状態異常にかかっていない
        return;
    }
    switch ($pokemon->getSa()) {
        /**
        * どく
        */
        case 'SaPoison':
        // 最大HPの1/8ダメージを受ける
        $poison = new SaPoison;
        // 小数点以下切り捨て
        $damage = (int)($pokemon->getStats('HP') / 8);
        if($damage){
            // 最小ダメージ数は1
            $damage = 1;
        }
        // メッセージ
        $this->setMessage($poison->getTurnMessage($pokemon->getPrefixName()));
        break;
        /**
        * もうどく
        */
        case 'SaBadPoison':
        // 最大HPの(ターン数/16)ダメージを受ける(最大15/16)
        $bad_poison = new SaBadPoison;
        // ターンカウントを進める
        $pokemon->goSaTurn();
        // 小数点以下切り捨て
        $damage = (int)($pokemon->getStats('HP') / 16) * $pokemon->getSa('turn');
        if($damage){
            // 最小ダメージ数は1
            $damage = 1;
        }
        // メッセージ
        $this->setMessage($bad_poison->getTurnMessage($pokemon->getPrefixName()));
        break;
        /**
        * やけど
        */
        case 'SaBurn':
        // 最大HPの1/16ダメージを受ける
        $burn = new SaBurn;
        // 小数点以下切り捨て
        $damage = (int)($pokemon->getStats('HP') / 16);
        if($damage){
            // 最小ダメージ数は1
            $damage = 1;
        }
        // メッセージ
        $this->setMessage($burn->getTurnMessage($pokemon->getPrefixName()));
        break;
    }
    // ダメージ計算
    $pokemon->calRemainingHp('sub', $damage ?? 0);
}
 
/**
* アタック後の状態変化チェック
*
* @param object Pokemon
* @return void
*/
protected function checkAfterSc($sicked_pokemon, $enemy_pokemon)
{
    // ひるみ解除
    $sicked_pokemon->releaseSc('ScFlinch');
    // 状態変化を取得
    $sc = $sicked_pokemon->getSc();
    if(empty($sc)){
        // 状態異常にかかっていない
        return;
    }
    /**
    * やどりぎのタネ
    */
    if(isset($sc['ScLeechSeed'])){
        // 最大HPの1/8HPを吸収する
        $leech_seed = new ScLeechSeed;
        // 小数点以下切り捨て
        $damage = (int)($sicked_pokemon->getStats('HP') / 8);
        if($damage){
            // 最小ダメージ数は1
            $damage = 1;
        }
        // ダメージ計算
        $sicked_pokemon->calRemainingHp('sub', $damage);
        // 回復
        $enemy_pokemon->calRemainingHp('add', $damage);
        // メッセージ
        $this->setMessage($leech_seed->getTurnMessage($sicked_pokemon->getPrefixName()));
        // HPが0になっていればチェック終了
        if(!$sicked_pokemon->getRemainingHp()){
            return;
        }
    }
    /**
    * バインド
    */
    if(isset($sc['ScBind'])){
        // 最大HPの1/8ダメージを受ける
        $bind = new ScBind;
        // バインドのターンカウントを進める
        $sicked_pokemon->goScTurn('ScBind');
        if($sc['ScBind']['turn'] <= 0){
            // バインド解除
            $sicked_pokemon->releaseSc('ScBind');
            $this->setMessage($bind->getRecoveryMessage($sicked_pokemon->getPrefixName(), $sc['ScBind']['param']));
        }else{
            // 小数点以下切り捨て
            $damage = (int)($sicked_pokemon->getStats('HP') / 8);
            if($damage){
                // 最小ダメージ数は1
                $damage = 1;
            }
            // ダメージ計算
            $sicked_pokemon->calRemainingHp('sub', $damage);
            // メッセージ
            $this->setMessage($bind->getTurnMessage($sicked_pokemon->getPrefixName(), $sc['ScBind']['param']));
            // HPが0になっていればチェック終了
            if(!$sicked_pokemon->getRemainingHp()){
                return;
            }
        }
    }
}

 

今回作成した努力値の取得処理はjudgment内で相手ポケモンのgetRewardEvメソッドを引数に実行しています。

 

それでは出力結果を見てみましょう。

 

 

 

 

 

 

setResponseを使って努力値の変化を確認するためにgetEvの結果を画面下へ出力しています。フシギダネとのバトル終了後、フシギダネにセットしたとくこう(SpAtk)の努力値が+1されていることが確認できました。

 

これで努力値の割り振り処理は完成です。

 

まとめ

 いかがだったでしょうか。

今回のPHPポケモンは「努力値システムの実装方法」をご紹介しました。

多くのゲームでは隠しステータスが用いられており、その存在はゲームを更に楽しませてくれるような楽しみ要素の1つです。これがあることで、ゲームをやり込む楽しみや戦略性が生まれます

ゲームづくりに興味がある方プログラミング学習に取り組んでいる方は、ぜひ参考にしてくださいね。

 

注目の記事

お金を稼ぐためは理解しておきたい基本的な3要素【お客さんを増やす前に知っておかなければならないことって?】
マーケティング
お金を稼ぐためは理解しておきたい基本的な3要素【お客さんを増やす前に知っておかなければならないことって?】

  お客さんを増やすためにはどうすればいいんだろう?   ビジネスをやっている人で儲かっている一部を除けば、誰もが抱いている共通の悩みですね。 ですが、ただお客さんを増やすために安易な広告を打ったりするのは、実は危険なことなんです。   今回は「お金を稼ぐためには理解しておきた...

ひとのものをとったらどろぼう!編 PHPポケモン 99
プログラミング
PHP,PHPポケモン,ポケモン
ひとのものをとったらどろぼう!編 PHPポケモン 99

ひとの ものを とったら どろぼう! ポケモンの中でも有名なセリフの1つです。モンスターボールを投げることでポケモンを捕まえることができますが、既に別トレーナーが所有しているポケモンを捕まえることはできません。 初代から、トレーナー戦でモンスターボールを投げると「ひとの ものを とったら どろぼう!...

HTMLの基本設計「よくわかるSEO対策」構造化(マークアップ)編
SEO対策
HTML,SEO,マークアップ
HTMLの基本設計「よくわかるSEO対策」構造化(マークアップ)編

  HTML5がリリースされて随分経ちました。 それにより多くのタグが増え、それにより今までデザインを目的と使用されていたものが「構造化」という本来の役割を持たされるようになりました。    構造化は、目に見えにくい部分です   それぞれの役割を理解していなければ、せっかくきれいなサ...

なぜプロは有線のマウスやキーボードを選ぶのか?【有線VS無線】
雑記
Bluetooth
なぜプロは有線のマウスやキーボードを選ぶのか?【有線VS無線】

  無線が普及する現代、何故有線のマウスやキーボードは売れているのか   いろんなものが製品の進化と共に無線化している一方、有線の需要も高く、とくにプロなど上層で活躍する人は有線を選択するケースが少なくありません。 今回は、そんな有線と無線の違いや、それぞれのメリットについて解説していき...

【変数とは】初心者が最短でPHPを使えるようになるための実践的な学び方
プログラミング
HTML,PHP,プログラミング学習
【変数とは】初心者が最短でPHPを使えるようになるための実践的な学び方

  ※PHP初心者へ向けた内容となりますので、ある程度HTMLの知識がある方を対象とした内容になります。予めご了承ください。    Webプログラミングを学ぶ方はHTML、そしてCSSを学び、そしてJavascriptやPHPという順に学んでいくひとが多いでしょう。 私も実際に、似たような手順で学んでいきました。   ...

これってスパム?amazon・paypalを装う悪質メールの対処方法とは
ネットワーク
amazon,Paypal,Xserver,スパム,三井住友,楽天,迷惑メール
これってスパム?amazon・paypalを装う悪質メールの対処方法とは

定期更新、役立つコラムのコーナー!   今回の注目したのは「迷惑(悪質)メールについて」です。   以前はamazonや楽天を名乗る業者から届いた迷惑メールについて紹介、その対処方法について取り上げましたが、今回は更にレベルアップしたスパムがいくつか届いたので、それらも紹介がてら、騙されないため...

Zoomも飲み屋もなくならない 〜コロナ収束後の本当の世界〜
雑記
YouTube,Zoom,コロナ,テレワーク,リモートワーク
Zoomも飲み屋もなくならない 〜コロナ収束後の本当の世界〜

  新型コロナウイルスのニュースが絶えない毎日を過ごす中、コロナの内容に一度も触れていませんでしたがそろそろ触れておこうと思います。   マイナスな内容は不安を煽るような推測はSNSやニュースでイヤというほど目にしているので、可能性を感じられる内容と現実をお届けします。   コロナが収束した時、この...

手っ取り早く情報強者になる簡単な方法
雑記
アウトプット,インプット,ニュース
手っ取り早く情報強者になる簡単な方法

  ニュースや情報番組、討論番組をみると、出演者の方々の情報量の多さに圧倒されることがあります。 また、ユニークな考え方に共感を得る人も多いでしょう。   どうやって、情報を仕入れているのか? なぜそんなことまで知っているのか?   メディアで取り上げられているような人や、活躍している人の多く...

カテゴリ

SEO対策 イベント デザイン ネットワーク ビジネスモデル フリーランス プログラミング マーケティング ライティング 動画編集 雑記

タグ

5G Adobe AfterEffects AI ajax amazon Animate api artisan atom Automator AWS Bluetooth CSS CVR description EC-CUBE4 ECショップ ESLint Facebook feedly foreach function Google Google AdSense Honeycode htaccess HTML IEEE 802.11ax Illustrator Instagram IoT JavaScript jQuery jQuery UI keyword LAN Laravel Linux MacBook MAMP meta MLM MySQL NoCode note OS OSI参照モデル Paypal Photoshop PHP phpMyAdmin PHPポケモン PremierePro rss SEO SEO対策 Sequel Pro Skype SNS SSH Symfony TCP/IP title Toastr Trait Twig Twitter UCC V系 WAN WebSub Wi-Fi wiki Windows WordPress XAMPP xml Xserver YouTube YouTuber Zoom アーティスト アウトプット アクセス層 アニメーション アフィリエイト イーブイ インターネット インプット エンジニア オブジェクト指向 お金配り クリック単価 クリック数 コミュニケーション能力 コロナ コンサルティング サムネイル システムエンジニア スタートアップ スタイルシート スパム データベース ディープフェイク デザイナー デザイン テレワーク ナンパ ニュース ネットワークモデル ノマドワーク バナー ピカチュウ ビジネス フィード フリーランス ブロガー ブログ プログラマー プログラミング プログラミング学習 プログラミング教育 プロトコル ホームページ制作 ポケモン マークアップ マーケティング メール リモートワーク レンダリング 三井住友 三宮 仕事依頼 児童デイ 児童デイサービス 児童発達支援 公開鍵 初心者 助成金 勉強法 営業 広告 広告収入 必勝マニュアル 放課後等デイサービス 朝活 楽天 深層学習 無線LAN 独立 神戸 福祉 秘密鍵 翻訳 自己啓発 英語 見積書 計算機 読書 起業 迷惑メール 配列 銀の弾丸 集客 雑学力