PHP+Gtk实例(求24点)
- 作者: Laruence(
) - 本文地址: http://www.laruence.com/2009/05/26/871.html
- 转载请注明出处
最近要安排我为BIT提供的《PHP高级应用–关于PHP你不知道的》一门课的讲课素材, 其中有部分涉及到PHP和Gtk2开发桌面应用的部分, 于是抽空就想写一了一个demo出来.
这是一个经典的求24的算法的PHP实现, 加上了Gtk2的界面, 其实也没什么复杂的, 和MFC开发没什么太大的区别, 唯一的不爽, 就是要自己用代码来写布局。。。
有兴趣的同学可以看看.
后记: 这里有一个网页版的, 可以用来玩玩: http://www.laruence.com/stashes/compute.php
运行截图
完整源代码(PHP-Gtk example):
- <?php
- /**
- * A 24 maker
- * @version 1.0.0
- * @author laruence<laruence at yahoo.com.cn>
- * @copyright (c) 2009 http://www.laruence.com
- */
- class TwentyFourCal extends GtkWindow {
- private $chalkboard;
- private $inputs;
- public $needle = 24;
- public $precision = '1e-6';
- function TwentyFourCal() {
- parent::__construct();
- $this->draw();
- $this->show();
- }
- /**
- * 画窗体方法
- */
- public function draw() {
- $this->set_default_size(200, 200);
- $this->set_title("24计算器");
- $mesg = new GtkLabel('Please input 4 integer(0-99):');
- $this->chalkboard = new GtkLabel();
- $this->inputs = $inputs = array(
- new GtkEntry(),
- new GtkEntry(),
- new GtkEntry(),
- new GtkEntry()
- );
- /**
- * container
- */
- $table = new GtkTable(4, 1, 0);
- $layout = array(
- 'left' => 0,
- 'right' => 1,
- 'top' => 0,
- 'bottom' => 1,
- );
- $vBox = new GtkVBox(false, true);
- $vBox->pack_start($mesg);
- foreach ( $inputs as $input ) {
- $input->set_max_length(2);
- $table->attach($input, $layout['left'], $layout['right'],
- $layout['top']++, $layout['bottom']++);
- }
- $vBox->pack_start($table);
- $button = new GtkButton("Calculate");
- $button->connect("clicked", array($this, "calculate"));
- $vBox->pack_start($this->chalkboard);
- $vBox->pack_start($button, true, false);
- $this->add($vBox);
- }
- public function show() {
- $this->show_all(); // 显示窗体
- }
- private function notice($mesg) {
- $this->chalkboard->set_text($mesg);
- }
- /**
- * 取得用户输入方法
- */
- public function calculate() {
- $operants = array();
- $inputs = $this->inputs;
- foreach ($inputs as $input) {
- $number = $input->get_text();
- if (!preg_match('/^\s*\d+\s*$/', $number)) {
- $this->notice('pleas input for integer(0-99)');
- return ;
- }
- array_push($operants, $number);
- }
- $length = count($operants);
- try {
- $this->search($operants, 4);
- } catch (Exception $e) {
- $this->notice($e->getMessage());
- return;
- }
- $this->notice('can\'t compute!');
- return;
- }
- /**
- * 求24点算法PHP实现
- */
- private function search($expressions, $level) {
- if ($level == 1) {
- $result = 'return ' . $expressions[0] . ';';
- if ( abs(eval($result) - $this->needle) <= $this->precision) {
- throw new Exception($expressions[0]);
- }
- }
- for ($i=0;$i<$level;$i++) {
- for ($j=$i+1;$j<$level;$j++) {
- $expLeft = $expressions[$i];
- $expRight = $expressions[$j];
- $expressions[$j] = $expressions[$level - 1];
- $expressions[$i] = '(' . $expLeft . ' + ' . $expRight . ')';
- $this->search($expressions, $level - 1);
- $expressions[$i] = '(' . $expLeft . ' * ' . $expRight . ')';
- $this->search($expressions, $level - 1);
- $expressions[$i] = '(' . $expLeft . ' - ' . $expRight . ')';
- $this->search($expressions, $level - 1);
- $expressions[$i] = '(' . $expRight . ' - ' . $expLeft . ')';
- $this->search($expressions, $level - 1);
- if ($expLeft != 0) {
- $expressions[$i] = '(' . $expRight . ' / ' . $expLeft . ')';
- $this->search($expressions, $level - 1);
- }
- if ($expRight != 0) {
- $expressions[$i] = '(' . $expLeft . ' / ' . $expRight . ')';
- $this->search($expressions, $level - 1);
- }
- $expressions[$i] = $expLeft;
- $expressions[$j] = $expRight;
- }
- }
- return false;
- }
- function __destruct() {
- Gtk::main_quit();
- }
- }
- new TwentyFourCal();
- Gtk::main(); //进入GTK主循环
- ?>
GTK1的API Reference : http://gtk.php.net/manual/en/gtk.gtkentry.php
GTK2的API Reference: 很不完整
PHP+Gtk实例(求24点)的更多相关文章
- C 语言实例 - 求两数最小公倍数
C 语言实例 - 求两数最小公倍数 用户输入两个数,其这两个数的最小公倍数. 实例 - 使用 while 和 if #include <stdio.h> int main() { int ...
- C 语言实例 - 求两数的最大公约数
C 语言实例 - 求两数的最大公约数 用户输入两个数,求这两个数的最大公约数. 实例 - 使用 for 和 if #include <stdio.h> int main() { int n ...
- JAVA 数组实例-求学生成绩的最大成绩,获取数组中的最大值、最小值
实例: import java.util.*; //求学生最大成绩 public class Test{ public static void main(String[] args){ System. ...
- Mapreduce实例--求平均值
求平均数是MapReduce比较常见的算法,求平均数的算法也比较简单,一种思路是Map端读取数据,在数据输入到Reduce之前先经过shuffle,将map函数输出的key值相同的所有的value值形 ...
- Java文件写入与读取实例求最大子数组
出现bug的点:输入数组无限大: 输入的整数,量大: 解决方案:向文件中输入随机数组,大小范围与量都可以控制. 源代码: import java.io.BufferedReader; import j ...
- ASP.NET Core 6框架揭秘实例演示[24]:中间件的多种定义方式
ASP.NET Core的请求处理管道由一个服务器和一组中间件组成,位于 "龙头" 的服务器负责请求的监听.接收.分发和最终的响应,针对请求的处理由后续的中间件来完成.中间件最终体 ...
- C#中按指定质量保存图片的实例代码 24位深度
/// <summary> /// 按指定的压缩质量及格式保存图片(微软的Image.Save方法保存到图片压缩质量为75) /// </summary ...
- MapReduce实例——求平均值,所得结果无法写出到文件的错误原因及解决方案
1.错误原因 mapreduce按行读取文本,map需要在原有基础上增加一个控制语句,使得读到空行时不执行write操作,否则reduce不接受,也无法输出到新路径. 2.解决方案 原错误代码 pub ...
- C 语言实例 -求分数数列1/2+2/3+3/5+5/8+...的前n项和
程序分析:抓住分子与分母的变化规律:分子a:1,2,3,5,8,13,21,34,55,89,144...分母b:2,3,5,8,13,21,34,55,89,144,233...分母b把数赋给了分子 ...
随机推荐
- 自定义ExtJS插件
http://cache.baiducontent.com/c?m=9f65cb4a8c8507ed4fece763105392230e54f73b6f93834c28c3933fc239045647 ...
- 学习MongoDB 二:MongoDB添加、删除、修改
一.简介 MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSQL数据库产品中最热门的一种.数据被分组存储在数据集中,被称为一个集合(Collenction)和对于存储在MongoDB ...
- HADOOP与HDFS数据压缩格式
1.cloudera 数据压缩的一般准则 一般准则 是否压缩数据以及使用何种压缩格式对性能具有重要的影响.在数据压缩上,需要考虑的最重要的两个方面是 MapReduce 作业和存储在 HBase 中的 ...
- opencv3.1+contrib的配置大总结(配置了两天,遇到问题无数)
开门见山的说:别用opencv3.0,这个版本添加扩展库不怎么好,能不能成功我不敢说,我是试了无数次都不行!!! 我的配置:W7+64位+opencv3.1+Cmake3.7.2 下载 下载什么的大家 ...
- linux高效shell命令总结
免废话,直接上代码 .c |awk 'NR==21{gsub(/t09/,"ruiy");printf $0}' 1,comm[2文件间行比较] [root@localhost r ...
- Latex Error:‘acmart.cls’ not found 解决方案:
windows下latex编译ACM论文模板时,出现Latex Error:‘acmart.cls’ not found,解决方案: 首先cd至模板所在目录下,然后运行以下命令: tex acma ...
- 自动化运维工具 SaltStack 在云计算环境中的实践
http://www.talkwithtrend.com/Article/218473
- maven下载与配置
转自:https://www.cnblogs.com/jdys/p/3770534.html 1.访问官网:从maven官网下载maven http://maven.apache.org/downlo ...
- 使用django + celery + redis 异步发送邮件
参考:http://blog.csdn.net/Ricky110/article/details/77205291 环境: centos7 + python3.6.1 + django2.0.1 ...
- oracle imp dmp
windows>cmd> imp userid=用户名/密码@orcl file=d:\nc60.dmp full=y imp userid=SYSTEM/password@orcl fi ...