OC中使用UI自己定义控件实现计算器的设计(版本号1简单的加减乘除,连加,连减,连除,连乘)
OC中使用UI自己定义控件实现计算器的设计(版本号1简单的加减乘除,连加。连减,连除,连乘)
#import <UIKit/UIKit.h>
@interface ViewController : UIViewController<UIApplicationDelegate>
{
float _operator1;
float _operator2;
float _result;
}
@end
#import "ViewController.h"
@interface ViewController ()
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
UITextField * textFied1 = [[UITextField alloc]initWithFrame:CGRectMake(10, 30, 300 ,50)];
textFied1.borderStyle = UITextBorderStyleLine;
textFied1.backgroundColor = [UIColor redColor];
[self.view addSubview:textFied1];
textFied1.clearButtonMode = UITextFieldViewModeAlways;
textFied1.tag = 007;
UIButton * btn1 = [UIButton buttonWithType:UIButtonTypeCustom];
btn1.Frame=CGRectMake(10, 90, 70, 70);
btn1.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn1];
[btn1 setTitle:@"7" forState:UIControlStateNormal];
[btn1 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
btn1.tag = 7;
UIButton * btn2 = [UIButton buttonWithType:UIButtonTypeCustom];
btn2.Frame=CGRectMake(85, 90, 70, 70);
btn2.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn2];
[btn2 setTitle:@"8" forState:UIControlStateNormal];
btn2.tag = 8;
[btn2 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn3 = [UIButton buttonWithType:UIButtonTypeCustom];
btn3.Frame=CGRectMake(160, 90, 70, 70);
btn3.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn3];
[btn3 setTitle:@"9" forState:UIControlStateNormal];
btn3.tag = 9;
[btn3 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn4 = [UIButton buttonWithType:UIButtonTypeCustom];
btn4.Frame=CGRectMake(235, 90, 70, 70);
btn4.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn4];
[btn4 setTitle:@"/" forState:UIControlStateNormal];
btn4.tag = 13;
[btn4 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn5 = [UIButton buttonWithType:UIButtonTypeCustom];
btn5.Frame=CGRectMake(10, 165, 70, 70);
btn5.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn5];
[btn5 setTitle:@"4" forState:UIControlStateNormal];
btn5.tag = 4;
[btn5 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn6 = [UIButton buttonWithType:UIButtonTypeCustom];
btn6.Frame=CGRectMake(85, 165, 70, 70);
btn6.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn6];
[btn6 setTitle:@"5" forState:UIControlStateNormal];
btn6.tag = 5;
[btn6 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn7 = [UIButton buttonWithType:UIButtonTypeCustom];
btn7.Frame=CGRectMake(160, 165, 70, 70);
btn7.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn7];
[btn7 setTitle:@"6" forState:UIControlStateNormal];
btn7.tag = 6;
[btn7 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn8 = [UIButton buttonWithType:UIButtonTypeCustom];
btn8.Frame=CGRectMake(235, 165, 70, 70);
btn8.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn8];
[btn8 setTitle:@"X" forState:UIControlStateNormal];
btn8.tag = 12;
[btn8 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn9 = [UIButton buttonWithType:UIButtonTypeCustom];
btn9.Frame=CGRectMake(10, 240, 70, 70);
btn9.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn9];
[btn9 setTitle:@"1" forState:UIControlStateNormal];
btn9.tag = 1;
[btn9 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn10 = [UIButton buttonWithType:UIButtonTypeCustom];
btn10.Frame=CGRectMake(85, 240, 70, 70);
btn10.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn10];
[btn10 setTitle:@"2" forState:UIControlStateNormal];
btn10.tag = 2;
[btn10 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn11 = [UIButton buttonWithType:UIButtonTypeCustom];
btn11.Frame=CGRectMake(160, 240, 70, 70);
btn11.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn11];
[btn11 setTitle:@"3" forState:UIControlStateNormal];
btn11.tag = 3;
[btn11 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn12 = [UIButton buttonWithType:UIButtonTypeCustom];
btn12.Frame=CGRectMake(235, 240, 70, 70);
btn12.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn12];
[btn12 setTitle:@"-" forState:UIControlStateNormal];
btn12.tag = 11;
[btn12 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn13 = [UIButton buttonWithType:UIButtonTypeCustom];
btn13.Frame=CGRectMake(10, 315, 70, 70);
btn13.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn13];
[btn13 setTitle:@"0" forState:UIControlStateNormal];
btn13.tag = 0;
[btn13 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn14 = [UIButton buttonWithType:UIButtonTypeCustom];
btn14.Frame=CGRectMake(85, 315, 145, 70);
btn14.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn14];
[btn14 setTitle:@"=" forState:UIControlStateNormal];
btn14.tag = 14;
[btn14 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
UIButton * btn15 = [UIButton buttonWithType:UIButtonTypeCustom];
btn15.Frame=CGRectMake(235, 315, 70, 70);
btn15.backgroundColor = [UIColor orangeColor];
[self.view addSubview:btn15];
[btn15 setTitle:@"+" forState:UIControlStateNormal];
btn15.tag = 10;
[btn15 addTarget:self action:@selector(btnClick:) forControlEvents:UIControlEventTouchUpInside];
// Do any additional setup after loading the view, typically from a nib.
}
//enum calCul
//{
// add,
// sub,
// mul,
// mod
//};
//
//typedef enum calCul calCul;
int count;
-(void)btnClick:(UIButton *)btn
{
NSString * str = [[NSString alloc]init];
if (btn.tag == 0) {
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"0";
//_operator1 = 0;
field.text = str;
}
else if(btn.tag==1)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"1";
//_operator2 = 1;
field.text = str;
}
else if(btn.tag==2)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"2";
field.text = str;
}
else if(btn.tag==3)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"3";
field.text = str;
}
else if(btn.tag==4)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"4";
field.text = str;
}
else if(btn.tag==5)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"5";
field.text = str;
}
else if(btn.tag==6)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"6";
field.text = str;
}
else if(btn.tag==7)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"7";
field.text = str;
} else if(btn.tag==8)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"8";
field.text = str;
}
else if(btn.tag==9)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"9";
field.text = str;
}
else if(btn.tag==10)
{
count = 1;
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
//str = @"+";
str = field.text;
//_result = _operator1;
_operator1 = [str doubleValue];
//str = [[NSString alloc]initWithFormat:@"%.2f",_result];
field.text = str;
}
else if(btn.tag==11)
{
count = 2;
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
//str = @"-";
//_result = _operator1 + _operator2;
str = field.text;
_operator1 = [str doubleValue];
field.text = str;
}
else if(btn.tag==12)
{
count = 3;
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
//str = @"*";
str = field.text;
_operator1 = [str doubleValue];
field.text = str;
}
else if(btn.tag==13)
{
count = 4;
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
//str = @"/";
str = field.text;
_operator1 = [str doubleValue];
field.text = str;
}
else if(btn.tag==14)
{
UITextField * field = ( UITextField * )[self.view viewWithTag:007];
str = @"=";
str = field.text;
_operator2 = [str doubleValue];
if (count==1) {
_result = _operator1 + _operator2;
}
else if(count == 2)
{
_result = _operator1 - _operator2;
}
else if(count == 3)
{
_result = _operator1 * _operator2;
}
else if(count==4)
{
_result = _operator1 / _operator2;
}
str = [[NSString alloc]initWithFormat:@"%.6f",_result];
field.text = str;
}
}
-(BOOL)textFieldShouldBeginEditing:(UITextField *)textField
{
return YES;
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
@end
OC中使用UI自己定义控件实现计算器的设计(版本号1简单的加减乘除,连加,连减,连除,连乘)的更多相关文章
- duilib中加入自己定义控件之后怎么可以在xml文件里配置使用
加入自己定义控件可能有两种不同的情况: 1. 在duilib库中加入的自己定义控件. 2. 在我们的应用程序中自己重写了一个控件. 以下開始解说不同的情况下怎么才干支持在xml文件配置控件: 1. ...
- android 自己定义控件
Android自己定义View实现非常easy 继承View,重写构造函数.onDraw.(onMeasure)等函数. 假设自己定义的View须要有自己定义的属性.须要在values下建立attrs ...
- Android 自己定义控件开发入门(二)
上一次我们讲了一堆实现自己定义控件的理论基础.列举了View类一些能够重写的方法,我们对这些方法的重写是我们继承View类来派生自己定义控件的关键 我通过一个最简单的样例给大家展示了这一个过程,不管是 ...
- git-osc自己定义控件之:CircleImageView
git-osc自己定义控件之:CircleImageView 一.CircleImageView的使用 在项目中能够发现,用户的头像都是圆形的.感觉非常好奇,昨天最终发现了,原来是自定了一个Image ...
- Android中如何利用attrs和styles定义控件
一直有个问题就是,Android中是如何通过布局文件,就能实现控件效果的不同呢?比如在布局文件中,我设置了一个TextView,给它设置了 textColor,它就能够改变这个TextView的文本的 ...
- Android开发——fragment中数据传递与刷新UI(更改控件)
数据传递: 1.通过数据库进行数据的传递 如在fragment中将数据保存在数据库中,之后其他的fragment或者activity直接读取数据库中的数据,数据库使用还算简单,这里就不多说,建议使用l ...
- 关于如何在 Unity 的 UI 菜单中默认创建出的控件 Raycast Target 属性默认为 false
关于如何在 Unity 的 UI 菜单中默认创建出的控件 Raycast Target 属性默认为 false 我们在 Unity 中通过 UI 菜单创建的各种控件,比如 Text, Image 等, ...
- qt 在ui界面添加控件后在cpp文件中无法调用?
问题:qt 在ui界面添加控件后在cpp文件中无法调用? 解决方法:在build选项中选择“重新build项目”,再次在cpp中调用添加的控件发现可以调用了. 还有一种情况导致添加控件后无法调用,就是 ...
- 背水一战 Windows 10 (7) - 控件 UI: VisualState, VisualStateManager, 控件的默认 UI
[源码下载] 背水一战 Windows 10 (7) - 控件 UI: VisualState, VisualStateManager, 控件的默认 UI 作者:webabcd 介绍背水一战 Wind ...
随机推荐
- input点击修改样式
<input id="geren" type="button" value="个人奖励" style="BORDER-TOP ...
- 工具分享3:VMware 10虚拟机、MS-DOS 7.1、安装教程(MS-DOS环境安装)
VMware 10工具下载地址: 网页下载链接:http://www.xp510.com/xiazai/ossoft/desktools/22610.html MS-DOS .10镜像下载地址: 网页 ...
- [转]ORACLE EXECUTE IMMEDIATE 小结
转自:http://www.cnblogs.com/huanghai223/archive/2011/06/29/2093660.html EXECUTE IMMEDIATE 代替了以前Oracl ...
- html与css命名规范小结
一.命名规则说明 所有的命名最好都用小写 使用英文命名 给每一个表格和表单加上一个唯一的.结构标记id 给每个图片加上alt标签,优点在于图片发生错误时,alt可以体现给用户 二.相对网页外层重要部分 ...
- AI:IPPR的模式生成-学习/训练方式(基本结构)
前言: 一个完备的模式识别系统,必然包含一个模式识别模型,此外还要附加一个评价模型,以及为了构建识别模型而构建的学习模型,并选择在学习模型中使用的学习方法. 否则 w=w 这样,)那样 ...
- 使用NDK编译VTK
VTK提供了对安卓的CMAKE编译支持,其介绍文件在源代码根目录下的 "/cmake/android.toolchain.cmake". 对Wndows的编译自持描述为: 注意:但 ...
- Combobox 下拉框赋值
string sql = "select distinct RoleName from tb_Role"; DataTable dt = SqlHelper.DataTable(s ...
- 利用node、express初始化项目
前端做整站是开发,例如:前端是用了vue创建初始化项目,后端我们不会php.java等,我们只能用node去创建去做后端代码,本文就给大家讲解最基础的从零开始创建一个项目的后端环境. 一般来说前后端代 ...
- HashMap源码分析笔记(一)
一.结构 HashMap的结构由数组和链表组成,可以说是一个链表类型的数组: 快速定位方式:key值得hash变换作为数组索引快速找到对应数组块,之后通过hash值对比从链表中查找到匹配项. hash ...
- 9.简单理解ES分布式
主要知识点: 1.Elasticsearch对复杂分布式机制的透明隐藏特性 2.Elasticsearch的垂直扩容与水平扩容 3.增减或减少节点时的数据rebalance 4.master节 ...