今年の新人研修で電卓アプリを作るらしいので、どんなプログラムが出てくるか楽しみにしながらぼくも作ってみました。
ざっくり仕様
大まかな仕様は以下のような感じです。
・iOS搭載の標準電卓と同じ仕様
・使用可能な言語はHTMlとPHPのみ ※JavaScriptを使ってはいけない!
プログラム
<?php
$disp_num = $_POST['disp_num'];
$pre_num = $_POST['pre_num'];
$input_num = $_POST['input_num'];
$ope = $_POST['ope'];
$button = $_POST['button'];
$pre_button = $_POST['pre_button'];
if (isNumBtn($button) || empty($button)) {
if (isOpeBtn($pre_button)) {
$pre_num = $disp_num;
if (preg_match('/\./', $button)) {
$disp_num = '0.';
} else {
$disp_num = $button;
}
} else {
$disp_num = $disp_num . $button;
}
$input_num = $disp_num;
} else {
switch ($button) {
case 'C':
$disp_num = '';
$pre_num = '';
$input_num = '';
break;
case '+/-':
$disp_num = -$disp_num;
break;
case '%':
$disp_num = $disp_num / 100;
break;
default:
if (!empty($pre_num) && (preg_match('/=/', $button) || (isOpeBtn($button) && isNumBtn($pre_button)))) {
switch ($ope) {
case '+':
$disp_num = $pre_num + $disp_num;
break;
case '−':
$disp_num = $pre_num - $disp_num;
break;
case '✕':
$disp_num = $pre_num * $disp_num;
break;
case '÷':
$disp_num = $pre_num / $disp_num;
break;
default:
break;
}
}
$pre_num = $input_num;
$ope = $button == '=' ? $ope : $button;
break;
}
}
$pre_button = $button;
function convertDispNum($num) {
preg_match('/(-?)(\d+)(\.?\d*)/', $num, $matches);
return $matches[1] . number_format($matches[2]) . $matches[3];
}
function isOpeBtn($btn) {
return preg_match('/(+|−|✕|÷)/', $btn);
}
function isNumBtn($btn) {
return preg_match('/(\d|\.)/', $btn);
}
?>
<!DOCTYPE html>
<html>
<head>
<title>Calculator</title>
</head>
<body>
<h2>Calculator</h2>
<p><?php echo convertDispNum($disp_num); ?></p>
<form action="?" method="post">
<input type="hidden" name="disp_num" value="<?php echo $disp_num; ?>" />
<input type="hidden" name="pre_num" value="<?php echo $pre_num; ?>" />
<input type="hidden" name="input_num" value="<?php echo $input_num; ?>" />
<input type="hidden" name="pre_button" value="<?php echo $pre_button; ?>" />
<input type="hidden" name="ope" value="<?php echo $ope; ?>" />
<table>
<tr>
<td><button type="submit" name="button" value="C">C</button></td>
<td><button type="submit" name="button" value="+/-">+/-</button></td>
<td><button type="submit" name="button" value="%">%</button></td>
<td><button type="submit" name="button" value="÷">÷</button></td>
</tr>
<tr>
<td><button type="submit" name="button" value="7">7</button></td>
<td><button type="submit" name="button" value="8">8</button></td>
<td><button type="submit" name="button" value="9">9</button></td>
<td><button type="submit" name="button" value="✕">✕</button></td>
</tr>
<tr>
<td><button type="submit" name="button" value="4">4</button></td>
<td><button type="submit" name="button" value="5">5</button></td>
<td><button type="submit" name="button" value="6">6</button></td>
<td><button type="submit" name="button" value="−">−</button></td>
</tr>
<tr>
<td><button type="submit" name="button" value="1">1</button></td>
<td><button type="submit" name="button" value="2">2</button></td>
<td><button type="submit" name="button" value="3">3</button></td>
<td><button type="submit" name="button" value="+">+</button></td>
</tr>
<tr>
<td colspan="2"><button type="submit" name="button" value="0">0</button></td>
<td><button type="submit" name="button" value=".">.</button></td>
<td><button type="submit" name="button" value="=">=</button></td>
</tr>
</form>
</body>
</html>
※ACとCの切り替え処理作ってなかったです。。。
動作確認
サクサク作れましたが、思った以上に難しかったなという印象です。
※たぶんバグもあるでしょう。。
普段、Webサイトのカスタマイズなど既存システムの改修ばかりなので、1からロジックを考える力が衰えてるなって思いました。
もっと良いプログラム作れるよって方はぜひ挑戦してみてください。