PHP图形计算器(计算三角形矩形周长面积)
运用PHP面向对象的知识设计一个图形计算器,同时也运用到了抽象类知识,这个计算器可以计算三角形的周长和面积以及矩形的周长和面积。本图形计算器有4个页面:1.PHP图形计算器主页index.php; 2.形状的抽象类shape.class.php; 3三角形计算类triangle.class.php; 4.矩形计算类rect.class.php。
PHP图形计算器代码点击下载: php图形计算器.zip
代码分别如下:
PHP图形计算器主页:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
<html> <head> <title>简单的图形计算器</title> <meta http-equiv= "Content-Type" content= "text/html;charset=utf-8" /> </head> <body> <center> <h1>简单的图形计算器</h1> <a href= "index.php?action=rect" >矩形</a> || <a href= "index.php?action=triangle" >三角形</a> </center> <hr><br> <?php error_reporting (E_ALL & ~E_NOTICE); //设置自动加载这个程序需要的类文件 function __autoload( $classname ){ include strtolower ( $classname ). ".class.php" ; } //判断用户是否有选择单击一个形状链接 if (! empty ( $_GET [ 'action' ])) { //第一步:创建形状的对象 $classname = ucfirst( $_GET [ 'action' ]); $shape = new $classname ( $_POST ); //第二步:调用形状的对象中的界面view() $shape -> view(); //第三步:用户是否提交了对应图形界面的表单 if (isset( $_POST [ 'dosubmit' ])) { //第四步:查看用户输出的数据是否正确, 失败则提示 if ( $shape ->yan( $_POST )) { //计算图形的周长和面积 echo $shape ->name. "的周长为:" . $shape ->zhou(). "<br>" ; echo $shape ->name. "的面积为:" . $shape ->area(). "<br>" ; } } //如果用户没有单击链接, 则是默认访问这个主程序 } else { echo "请选择一个要计算的图形!<br>" ; } ?> </body> </html> |
形状的抽象类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
abstract class Shape{ //形状的名称 public $name ; //形状的计算面积方法 abstract function area(); //形状的计算周长的方法 abstract function zhou(); //形状的图形表单界面 abstract function view(); //形状的验证方法 abstract function yan( $arr ); } |
三角形计算类文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
class Triangle extends Shape { private $bian1 ; private $bian2 ; private $bian3 ; function __construct( $arr = array ()) { if (! empty ( $arr )) { $this ->bian1 = $arr [ 'bian1' ]; $this ->bian2 = $arr [ 'bian2' ]; $this ->bian3 = $arr [ 'bian3' ]; } $this ->name = "三角形" ; } function area() { $p = ( $this ->bian1 + $this ->bian2 + $this ->bian3)/2; return sqrt( $p *( $p - $this ->bian1)*( $p - $this ->bian2)*( $p - $this ->bian3)); } function zhou() { return $this ->bian1 + $this ->bian2 + $this ->bian3; } function view() { $form = '<form action="index.php?action=triangle" method="post">' ; $form .= $this ->name. '第一个边:<input type="text" name="bian1" value="' . $_POST [ 'bian1' ]. '" /><br>' ; $form .= $this ->name. '第二个边:<input type="text" name="bian2" value="' . $_POST [ 'bian2' ]. '" /><br>' ; $form .= $this ->name. '第三个边:<input type="text" name="bian3" value="' . $_POST [ 'bian3' ]. '" /><br>' ; $form .= '<input type="submit" name="dosubmit" value="计算"><br>' ; $form .= '<form>' ; echo $form ; } function yan( $arr ) { $bj = true; if ( $arr [ 'bian1' ] < 0) { echo "第一个边不能小于0!<br>" ; $bj = false; } if ( $arr [ 'bian2' ] < 0) { echo "第二个边不能小于0!<br>" ; $bj = false; } if ( $arr [ 'bian3' ] < 0) { echo "第三个边不能小于0!<br>" ; $bj = false; } if (( $arr [ 'bian1' ]+ $arr [ 'bian2' ] < $arr [ 'bian3' ]) || ( $arr [ 'bian1' ] + $arr [ 'bian3' ] < $arr [ 'bian2' ]) || ( $arr [ 'bian2' ]+ $arr [ 'bian3' ] < $arr [ 'bian1' ])) { echo "两边之和必须大于第三个边" ; $bj = false; } return $bj ; } } |
矩形计算类文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
class Rect extends Shape { private $width ; private $height ; function __construct( $arr = array ()) { if (! empty ( $arr )) { $this ->width = $arr [ 'width' ]; $this ->height = $arr [ 'height' ]; } $this ->name = "矩形" ; } function area() { return $this ->width * $this ->height; } function zhou() { return 2*( $this ->width + $this ->height); } function view() { $form = '<form action="index.php?action=rect" method="post">' ; $form .= $this ->name. '的宽:<input type="text" name="width" value="' . $_POST [ 'width' ]. '" /><br>' ; $form .= $this ->name. '的高:<input type="text" name="height" value="' . $_POST [ 'height' ]. '" /><br>' ; $form .= '<input type="submit" name="dosubmit" value="计算"><br>' ; $form .= '<form>' ; echo $form ; } function yan( $arr ) { $bg = true; if ( $arr [ 'width' ] < 0) { echo $this ->name. "的宽不能小于0!<br>" ; $bg = false; } if ( $arr [ 'height' ] < 0) { echo $this ->name. "的高度不能小于0!<br>" ; $bg = false; } return $bg ; } } |
PHP图形计算器(计算三角形矩形周长面积)的更多相关文章
- python3 练手实例1 计算三角形周长和面积
def j(): a,b,c=map(float,input('请输入三角形三条边的长度,用空格隔开:').split()) if a>0 and b>0 and c>0 and a ...
- Java练习 SDUT-3339_计算长方形的周长和面积(类和对象)
计算长方形的周长和面积(类和对象) Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 设计一个长方形类Rect,计算长方形 ...
- 25.按要求编写一个Java应用程序: (1)编写一个矩形类Rect,包含: 两个属性:矩形的宽width;矩形的高height。 两个构造方法: 1.一个带有两个参数的构造方法,用于将width和height属性初化; 2.一个不带参数的构造方法,将矩形初始化为宽和高都为10。 两个方法: 求矩形面积的方法area() 求矩形周长的方法perimeter() (2)通过继承Rect类编写一个具有
package zhongqiuzuoye; //自己写的方法 public class Rect { public double width; public double height; Rect( ...
- OpenJudge计算概论-计算三角形面积【海伦公式】
/*============================================== 计算三角形面积 总时间限制: 1000ms 内存限制: 65536kB 描述 平面上有一个三角形,它的 ...
- 计算概论(A)/基础编程练习2(8题)/3:计算三角形面积
#include<stdio.h> #include<math.h> int main() { // 声明三角形的三个顶点坐标和面积 float x1, y1, x2, y2, ...
- Java入门:基础算法之计算三角形面积
本部分介绍如何计算三角形面积. /** * @author: 理工云课堂 * @description: 程序计算三角形的面积.三角形的底和高由用户输入 */ import java.util.Sca ...
- 大一C语言学习笔记(11)---编程篇--写一个程序,可以获取从键盘上输入的的三个数,并能够判断是否可以以这三个数字作为边长来构成一个三角形,如果可以的话,输出此三角形的周长及面积,要求 0 bug;
考核内容: 写一个程序,可以获取从键盘上输入的的三个数,并能够判断是否可以以这三个数字作为边长来构成一个三角形,如果可以的话,输出此三角形的周长及面积: 答案: #include<stdio.h ...
- PHP面向对象实例(图形计算器)
效果:
- php:兄弟连之面向对象版图形计算器1
曾经看细说PHP的时候就想做这个,可是一直没什么时间,这次总算忙里偷闲搞了代码量比較多的project. 首先,文档结构,都在一个文件夹下就好了,我的就例如以下. 一開始,进入index.php文件. ...
随机推荐
- Codeforces Round #333 (Div. 1)--B. Lipshitz Sequence 单调栈
题意:n个点, 坐标已知,其中横坐标为为1~n. 求区间[l, r] 的所有子区间内斜率最大值的和. 首先要知道,[l, r]区间内最大的斜率必然是相邻的两个点构成的. 然后问题就变成了求区间[l, ...
- 348. Design Tic-Tac-Toe
提示给的太直白了.. 比如player 1占据了(0,1),那么row[0]++ col[1]++ 表示第一行有1个O,第一列有1个X,假设PLAYER 1最终在第一行连成一排,那最终row[0] = ...
- BASH_SOURCE 用法
参考 bash少见的用法 http://blog.csdn.net/wonderisland/article/details/22892759. 原有项目里自带的启动脚本用到了bash_source获 ...
- PKU 1511 Invitation Cards (SPFA+邻接表)
题目链接:点击打开链接 题目需要求从原点到所有点的最短距离之和和所有点到原点的最短距离之和,在求所有点到原点最短距离的时候用到了一个技巧:即把图反向,求原点到所有其他点的最短距离,这样用一次SPFA就 ...
- Eclipse debug经常使用基本技巧
1.F5单步调试,步入,进入函数体内部 2.F6单步调试.步过.不进入函数体 3.F7返回 4.F8运行到最后 5.退出时.右键点击右上角Debug选择退出就可以 $(function () { $( ...
- Etcd学习(一)安装和.NETclient測试
Etcd是一个比較新的分布式协调框架,由CoreOS的开发团队开发,如今才仅仅到0.4.6版本号,还没公布1.0版本号 我看了一下GitHub上作者们的提交记录,如今应该还在如火如荼的开发以及改动Bu ...
- QT unit test code coverage
准备环境: qt-creator5.2.1 , gcov(gcc 默认安装),lcov(gcov 的图形化显示界面),qt_testlib 各环境介绍: 1.gcov gcov 是一个可用于C/C ...
- TabBarController创建及使用方法简介
TabBarController创建及使用方法简介 大致讲解一下TabBarController的创建过程: 首先,我们需要一些视图,如创建UIControllerView类型的view1,view2 ...
- RT:How HTTP use TCP connection
In HTTP/0.9 (not used anymore), each request uses a separate TCP connection, and the end of a respon ...
- [转] Linux下查看文件和文件夹大小
当磁盘大小超过标准时会有报警提示,这时如果掌握df和du命令是非常明智的选择. df可以查看一级文件夹大小.使用比例.档案系统及其挂入点,但对文件却无能为力. du可以查看文件及文件夹的大小. ...