【触摸案例-多点触摸的案例 Objective-C语言】

一、我们来做这个多点触摸的案例

通知

1.首先呢,按着这个option键啊,可以模拟多点触摸,

通知

然后呢,再去怎么着去画圈儿,

通知

它这个里边就会产生一个imageView,跟着你去变,会有这么一个效果,

那么,首先啊,我们新建一个项目,

Name:03-多点触摸的案例

通知

1)首先,我们把控制器的view,直接变成黑色的,

通知

黑色的完了以后呢,

通知

2)我要在这个黑色的view上面做事情,我要给它绑定一个类,BGView,

通知

New一个File,继承自UIView,叫做BGView,

通知

粘贴一下名称,BGView,

通知

选中这一段儿注释,删掉,

通知

在这个里边写代码啊,

3)首先,当我点击屏幕的时候,它就会出来这么一个imageView,

通知

当我两个手指头点击的时候,它会出来两个imageView,所以我们touchesBegan:一定是要有的,我们先来把touchesBegan:先来写一下,

// 手指触摸这个view的时候调用

- (void)touchesBegan:(NSSet< UITouch * > *)touches withEvent:(UIEvent *)event{

}

通知

4)我们首先要把两个手指头的做出来才行,先让它把两个手指头,做出来,才行啊,怎么着来做,实际上,这个touches,说是一个集合,我们之前做的呢,一直是一个元素,那么,两个手指头,怎么着去做啊,首先,touches里边,放的都是UITouch类型的元素,你有几个元素,就证明你有几个手指头,一块儿点着我了,如果你五个手指头,一块儿点屏幕,touches里边儿,应该有五个元素,这个Set里边儿,应该有五个元素,也就是说,有五个UITouch对象,

有5个UITouch对象,然后,每一个UITouch对象,都可以去获取不同的locationInView,获取不同的位置,

我们这里NSLog一下touches.count,看看里边有多少个元素,

通知

NSLog(@“@ld”,touches.count);

通知

当我一个手指头点击屏幕的时候,输出的是1,

通知

我现在按着option,点,还是1,

不是说有几个手指头点击这个屏幕,touches里边就有几个对象吗,这是这个样子的啊,默认啊,这个View呢,是不支持多点触控的,

在storyboard里边,选中这个view,右边有一个Multiple Touch,勾选上

通知

Multiple Touch:多点触控,

你要把它勾上,然后command + R,这个时候,按住option键,点屏幕,输出的就是2了吧,

通知

这就是2,看到了吧,默认,这个view,是不支持多点触控的,把这个Multiple Touch选项,开一下,就好了,

3)在我们的这个BGView里边儿,当我点击的时候,我要出来一个UIView,

然后,我们说,这个Set里边儿,有两个手指头,所以呢,我待会儿还是要去循环去做,涉及到循环的话,我个人的思路,还是先写一个,然后呢,再去加一个for循环,就可以了,

5.我们现在要做的事情,是我点击屏幕,单个儿手指头啊,它就出来一个ImageView,加上去,这是我要做的事情啊,

通知

1)// 获取触摸对象

通知

UITouch *t = touches.anyObject;

然后呢,接下来,在这个触摸对象的位置上,去添加一个ImageView,然后,让它过几秒钟消失,实际上,就可以了,

2)// 获取手指的位置

我们首先,要去获取手指的位置,才能够添加,没有位置,往哪儿去添加啊,

CGPoint p = [t locationInView:(UIView *)view];

  • 14
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,以下是用Objective-C纯代码实现的签到日期界面。实现的界面包括一个导航栏、一个显示当前日期的标签和一个签到按钮。 ViewController.h文件: ```objective-c #import <UIKit/UIKit.h> @interface ViewController : UIViewController @end ``` ViewController.m文件: ```objective-c #import "ViewController.h" @interface ViewController () @property (nonatomic, strong) UILabel *dateLabel; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. // 设置导航栏标题 self.navigationItem.title = @"签到"; // 设置背景颜色 self.view.backgroundColor = [UIColor whiteColor]; // 创建并添加日期标签 self.dateLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 200, 50)]; self.dateLabel.center = CGPointMake(self.view.frame.size.width/2, self.view.frame.size.height/2 - 50); self.dateLabel.textAlignment = NSTextAlignmentCenter; self.dateLabel.textColor = [UIColor blackColor]; [self.view addSubview:self.dateLabel]; // 更新日期标签的文本 [self updateDateLabel]; // 创建并添加签到按钮 UIButton *checkInButton = [UIButton buttonWithType:UIButtonTypeSystem]; checkInButton.frame = CGRectMake(0, 0, 200, 50); checkInButton.center = CGPointMake(self.view.frame.size.width/2, self.view.frame.size.height/2 + 50); [checkInButton setTitle:@"签到" forState:UIControlStateNormal]; [checkInButton addTarget:self action:@selector(checkInButtonClicked:) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:checkInButton]; } // 更新日期标签的文本 - (void)updateDateLabel { NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; formatter.dateFormat = @"yyyy年MM月dd日"; self.dateLabel.text = [formatter stringFromDate:[NSDate date]]; } // 签到按钮点击事件 - (void)checkInButtonClicked:(UIButton *)sender { // TODO: 处理签到逻辑 // 更新日期标签的文本 [self updateDateLabel]; } @end ``` 在AppDelegate.m文件中,将ViewController设置为根视图控制器: ```objective-c #import "AppDelegate.h" #import "ViewController.h" @interface AppDelegate () @end @implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { // Override point for customization after application launch. self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds]; ViewController *viewController = [[ViewController alloc] init]; UINavigationController *navigationController = [[UINavigationController alloc] initWithRootViewController:viewController]; self.window.rootViewController = navigationController; [self.window makeKeyAndVisible]; return YES; } ``` 这样就完成了一个简单的签到日期界面的实现。运行程序后,可以看到一个带有日期标签和签到按钮的界面。点击签到按钮后,日期标签上的日期会更新为当前日期。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清风清晨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值