阿健的iOS开发Demo(加法计算器、图片浏览(动画))

2024-01-06 05:10

本文主要是介绍阿健的iOS开发Demo(加法计算器、图片浏览(动画)),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

</pre> 首先,我想声明我这里说的开发入门并不是指零基础开发入门,读者需有一定的IOS学习基础,初步了解面向对象编程思想。我写博客不是因为我是什么大牛,只是当做自己在iOS开发中的一个小工具,记录一下接触过的东西。希望读者在阅读时也可以指出不足,大家相互学习,共同进步。<p></p><p><span style="white-space:pre"></span>接下来进入正题,任何app的开发都是一个循序渐进的过程,都是很多小程序小功能一步步构成的。一个最基础的小程序,主要是由界面、业务逻辑和数据构成的。下图是我们开发中用得到的UI控件:</p><p><img src="https://img-blog.csdn.net/20151102232733746?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" width="520" height="180" align="middle" alt="" /></p><p>上图中红色表示常用,蓝色次之,黑色表示不常用,我们将对前两者加以学习。上面的控件可能不会顺序使用。</p><p><DEMO1>接下来我们来看第一个小demo,简易加法计算器:</p><p></p><pre name="code" class="objc">- (IBAction)resignButton:(id)sender {self.firstNum.text = [NSString stringWithFormat:@""];self.secondNum.text = [NSString stringWithFormat:@""];self.result.text = [NSString stringWithFormat:@"%d",0];self.noticeText.text = [NSString stringWithFormat:@""];[self.view endEditing:YES];//清空收回键盘
}
- (IBAction)caculatorButton:(id)sender {if (self.firstNum.text.length == 0|| self.secondNum.text.length == 0) {_noticeText.text = @"请输入两个数";_noticeText.textColor = [UIColor redColor];//设置字体颜色return ;}int num1 = [self.firstNum.text intValue];int num2 = [self.secondNum.text intValue];self.noticeText.text = @"";self.result.text = [NSString stringWithFormat:@"%d",num1+num2];
}
我这里使用的是StoryBoard来作界面布局的,布局和运行效果如下图:

                         

这里实现了一个简易加法计算器逻辑和界面呈现,caculatorButton:是“计算”的点击方法,进入方法内部首先判断两个UITextLable是否都有输入,若不是都有输入,UITextLable下方的UILable显示红色提示,程序返回。resignButton:对应“清空”的点击事件,给两个UITextLable重新赋值为空。这个demo是给初学者了解程序开发初级流程的,没有什么难度。

我们在开发过程中所用到的UI控件都是继承自UIView,所以这些UI控件都拥有UIView的一些常见属性和方法:

@property(nonatomic,readonly) UIView *superview;//获得父控件对象
@property(nonatomic,readonly,copy)NSArray *subviews;//获得自己所有子控件对象
@property(nonatomic)NSInteger tag;//控件ID\标识,父控件可以通过tag值找到相应子控件
@property(nonatomic)CGAffineTransform transfom;//控件的形变属性(可设置旋转角度、比例缩放、平移等属性)
@property(nonatomic)CGRect frame;//控件所在矩形框在父控件中的位置和尺寸
@property(nonatomic)CGRect bounds;//控件在矩形框中的位置和尺寸,x、y一般为0
@property(nonatomic)CGPoint center;//控件中心点的位置
- (void)addSubview:(UIView *)view;
//添加一个子控件view
- (void)removeFromSuperview;
//从父控件中移除
- (UIView *)viewWithTag:(NSInteger)tag;
//根据一个tag标识找出对应的控件(一般都是子控件)
通过这些公共属性或者方法我们可以修改控件的状态,例如位置、颜色、大小等。

给相同控件设置不同tag值,这样就不用在写方法的时候分别给每个控件都写一个方法,只需在一个方法中根据不同的tag值执行不同的代码即可。

transform属性也是一个经常用到的重要属性,给控件transform属性直接赋值:

CGAffineTransform CGAffineTransformMakeTranslation(CGFloat tx,  CGFloat ty) ;
CGAffineTransform CGAffineTransformMakeScale(CGFloat sx, CGFloat sy);
CGAffineTransform CGAffineTransformMakeRotation(CGFloat angle)
这里angle是指弧度,并非角度。

给控件的transform属性叠加一个值:

CGAffineTransform CGAffineTransformTranslate(CGAffineTransform t, CGFloat tx, CGFloat ty);
CGAffineTransform CGAffineTransformScale(CGAffineTransform t, CGFloat sx, CGFloat sy);
CGAffineTransform CGAffineTransformRotate(CGAffineTransform t, CGFloat angle);
当我们想把控件transform属性复原到初始值时,用下方法即可:

view.transform = CGAffineTransformIdentity;
<DEMO2>接下来说一个图片按顺序播放的demo,当图片数量和播放间隔合适时就看起来是一个动画效果了

-(void)startAnimationWithImageCount:(NSInteger )count andPreOfImages:(NSString *)preStr {if (self.imageView.isAnimating) {  //判断图片是否处于播放状态中,是则返回return;}NSMutableArray *knockArray = [NSMutableArray array];  //用数组存放需要播放的图片for (int i = 0; i<count; i++) {NSString *str = [NSString stringWithFormat:@"%@_%02d",preStr,i];[knockArray addObject:[UIImage imageNamed:str]];}//下面是设置动画播放的图片、次数和间隔时间self.imageView.animationImages = knockArray;self.imageView.animationRepeatCount = 1;self.imageView.animationDuration = knockArray.count*0.06;[self.imageView startAnimating];//开始播放}

我这里用的是汤姆猫游戏中的图片,做的是点击按钮播放相应动画的一个效果,下图是点击牛奶按钮的一个效果截图:

   
这里我们需要的注意点是在数组中的图片名字需要有序,并且需要判断动画的执行状态,即开头if语句的效果,没有动画才会执行后面的代码
当图片名字是存放在一个plist文件中时,我们可以将图片数组设置为程序的一个属性,利用懒加载(将属性在get方法中初始化的方法)加载图片,属性中有数组或者字典时我们一般都会用懒加载初始化。

这里还有一个需要注意的问题:加载图片方法

(1)+ (UIImage*)imageNamed:(NSString*)name方法缺点是有缓存,内存会随着加载次数一直减少,优点是从第二次加载开始加载速度会变快,直接从缓存中读取

(2)+ (UIImage*)imageWithContentsOfFile:(NSString *)path和- (id)initWithContentsOfFile:(NSString*)path方法优点是不会做缓存,缺点是每次加载图片都会有延迟,是从文件路径中去读取图片

我们手机内存十分精贵,所以在实际开发中,我们常常使用后两者,同样也可以根据实际情况自由选择加载方法



这篇关于阿健的iOS开发Demo(加法计算器、图片浏览(动画))的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/575295

相关文章

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取