IOS 开发qq登陆界面

//
// ViewController.m
// QQUI_bydfg
//
// Created by Kevin_dfg on 16/4/15.
// Copyright © 2016年 kevin_dfg. All rights reserved.
//
#import "ViewController.h"
//图片选择器协议
@interface ViewController () <UINavigationControllerDelegate, UIImagePickerControllerDelegate>
//**************************设置控件的坐标*********************************
//屏幕宽高
#define screenWidth self.view.frame.size.width
#define screenHeight self.view.frame.size.height
//qq头像宽高
#define qqY 80
#define qqW 0.25*screenWidth
#define qqX (screenWidth - qqW)/2
#define qqH qqW
//账号
#define accountX 0
#define accountY qqY+qqH+20
#define accountW screenWidth
#define accountH 50
//密码
#define passwdX 0
#define passwdY accountY+accountH+20
#define passwdW screenWidth
#define passwdH 30
//登陆按钮
#define loginX 35
#define loginY passwdY+passwdH+20
#define loginW screenWidth-2*loginX
#define loginH 50
//登陆失败
#define failedX 10
#define failedY 0.95*screenHeight
#define failedW 80
#define failedH 25
//注册用户按钮
#define newX 0.8*screenWidth
#define newY 0.95*screenHeight
#define newW 80
#define newH 25
//************声明头像,密码,登陆失败,注册用户*********************************
@property(nonatomic,strong)UIButton *headBtn ;
@property(nonatomic,strong)UIButton *loginBtn;
@property(nonatomic,strong)UIButton *failedBtn ;
@property(nonatomic,strong)UIButton *signBtn;
@property(nonatomic,strong)UITextField *account, *passwd;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
//*****************************qq头像******************************
//分配初始化qq头像按钮
self.headBtn =[[UIButton alloc]initWithFrame:CGRectMake(qqX, qqY, qqW, qqH)];
//设置qq头像
[_headBtn setBackgroundImage:[UIImage imageNamed:@"head.jpg" ] forState:UIControlStateNormal];
//添加图层蒙版,圆角化
_headBtn.layer.cornerRadius=qqH/2;
_headBtn.layer.masksToBounds=YES;
[_headBtn addTarget:self action:@selector(changHeadAction:) forControlEvents:UIControlEventTouchUpInside];
//添加头像按钮到视图
[self.view addSubview:_headBtn];
//****************************账户和密码控件*****************************
//分配初始化账户和密码按钮
_account =[[UITextField alloc]initWithFrame:CGRectMake(accountX, accountY, accountW, accountH)];
_passwd =[[UITextField alloc]initWithFrame:CGRectMake(passwdX, passwdY, passwdW, passwdH)];
//设置账户的背景图片
[_account setBackground:[UIImage imageNamed:@"login_textfield.png"]];
//设置账户和密码的属性:居中,数字键盘,提示符
_account.textAlignment=NSTextAlignmentCenter;
_account.keyboardType=UIKeyboardTypeNumberPad;
_account.placeholder=@"qq号/手机号/邮箱";
_passwd.textAlignment=NSTextAlignmentCenter;
_passwd.keyboardType=UIKeyboardTypeAlphabet;
_passwd.placeholder=@"qq密码";
//设置密码的密文显示
_passwd.secureTextEntry=YES;
[self.view addSubview:_account];
[self.view addSubview:_passwd];
//**************************登陆按钮*********************************
//分配初始化登陆按钮
_loginBtn=[[UIButton alloc]initWithFrame:CGRectMake(loginX, loginY, loginW, loginH)];
//设置登陆按钮的效果
[_loginBtn setBackgroundImage:[UIImage imageNamed:@"loginBtn_nor.png"] forState:UIControlStateNormal];
[_loginBtn setBackgroundImage:[UIImage imageNamed:@"loginBtn_h.png"] forState:UIControlStateHighlighted];
//为登陆按钮设置监听事件
[_loginBtn addTarget:self action:@selector(loginAction:) forControlEvents:UIControlEventTouchUpInside];
//将登陆按钮添加到视图
[self.view addSubview:_loginBtn];
//**************************登陆失败按钮*********************************
//分配初始化登陆失败按钮
_failedBtn =[[UIButton alloc]initWithFrame:CGRectMake(failedX, failedY, failedW, 25)];
//设置登陆失败按钮的效果
[_failedBtn setBackgroundImage:[UIImage imageNamed:@"failed.png"] forState:UIControlStateNormal];
[_failedBtn setBackgroundImage:[UIImage imageNamed:@"failed.png"] forState:UIControlStateHighlighted];
//为登陆失败按钮设置监听事件
[_failedBtn addTarget:self action:@selector(failedAction:) forControlEvents:UIControlEventTouchUpInside];
//将登陆失败按钮添加到视图
[self.view addSubview:_failedBtn];
//***********************新用户注册按钮*********************************
//分配初始化新用户注册按钮
_signBtn =[[UIButton alloc]initWithFrame:CGRectMake(newX , newY, newW, newH)];
//设置新用户注册按钮的效果
[_signBtn setBackgroundImage:[UIImage imageNamed:@"new.png"] forState:UIControlStateNormal];
[_signBtn setBackgroundImage:[UIImage imageNamed:@"new.png"] forState:UIControlStateHighlighted];
//为新用户注册按钮设置监听事件
[_signBtn addTarget:self action:@selector(signAction:) forControlEvents:UIControlEventTouchUpInside];
//将新用户注册按钮添加到视图
[self.view addSubview:_signBtn];
}
//**************************************改变头像事件***************************************
-(void)changHeadAction:(UIButton *)headBtn{
//分配初始化图片选择器
UIImagePickerController *picker=[[UIImagePickerController alloc] init];
//设置图片来源:系统相册
picker.sourceType=UIImagePickerControllerSourceTypePhotoLibrary;
//为图片选择器设置委托事件
picker.delegate=self;
//模态窗口显示图片选择器
[self presentViewController:picker animated:YES completion:nil];
}
//**************************图片选择器委托事件*********************************
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingImage:(UIImage *)image editingInfo:(nullable NSDictionary<NSString *,id> *)editingInfo{
//选择系统相册里的图片当头像
[_headBtn setBackgroundImage:image forState:UIControlStateNormal];
//退出模态窗口
[picker dismissViewControllerAnimated:YES completion:nil];
}
//**************************登陆按钮事件*********************************
-(void)loginAction:(UIButton *)loginBtn{
//判断账号和密码是否为空
if (_account.text.length >0 &&_passwd.text.length >0) {
//分配初始化提示控制窗口
UIAlertController *alert = [UIAlertController alertControllerWithTitle:[NSString stringWithFormat:@"账号:%@",_account.text] message:[NSString stringWithFormat:@"密码:%@",_passwd.text] preferredStyle:UIAlertControllerStyleAlert];
//将确定按钮添加到提示框内
[alert addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:nil]];
//模态窗口显示提示窗
[self presentViewController:alert animated:YES completion:nil];
}else{
//分配初始化提示控制窗口
UIAlertController *alert = [UIAlertController alertControllerWithTitle:@"错误" message:@"用户或密码不能为空" preferredStyle:UIAlertControllerStyleAlert];
//将确定按钮添加到提示框内
[alert addAction:[UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:nil]];
//模态窗口显示提示窗
[self presentViewController:alert animated:YES completion:nil];
}
}
//*************************登陆失败事件**********************************
-(void)failedAction:(UIButton *)failedBtn{
//分配初始化提示控制窗口
UIAlertController *alert= [UIAlertController alertControllerWithTitle:@"找回密码" message:@"短信登陆" preferredStyle:UIAlertControllerStyleActionSheet];
//将确定按钮添加到提示框内
[alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];
//模态窗口显示提示窗
[self presentViewController:alert animated:YES completion:nil];
}
//**************************新用户注册事件*********************************
-(void)signAction:(UIButton *)signBtn{
//分配初始化提示控制窗口
UIAlertController *alert= [UIAlertController alertControllerWithTitle:@"验证手机号码" message:@"中国 +86 " preferredStyle:UIAlertControllerStyleActionSheet];
//将确定按钮添加到提示框内
[alert addAction:[UIAlertAction actionWithTitle:@"取消" style:UIAlertActionStyleCancel handler:nil]];
//模态窗口显示提示窗
[self presentViewController:alert animated:YES completion:nil];
}
@end
IOS 开发qq登陆界面的更多相关文章
- [iOS基础控件 - 3.1] QQ登陆界面
A.storyboard 控件版 1.label 2.textfield a.Keyboard Type 账号:Number Pad 密码:Num ...
- WPF和Expression Blend开发实例:模拟QQ登陆界面打开和关闭特效
不管在消费者的心中腾讯是一个怎么样的模仿者抄袭者的形象,但是腾讯在软件交互上的设计一直是一流的.正如某位已故的知名产品经理所说的:设计并非外观怎样,感觉如何.设计的是产品的工作原理.我觉得腾讯掌握了其 ...
- IOS开发之记录用户登陆状态,ios开发用户登陆
IOS开发之记录用户登陆状态,ios开发用户登陆 上一篇博客中提到了用CoreData来进行数据的持久化,CoreData的配置和使用步骤还是挺复杂的.但熟悉CoreData的使用流程后,CoreDa ...
- 用户登陆状态,ios开发用户登陆
IOS开发之记录用户登陆状态,ios开发用户登陆 上一篇博客中提到了用CoreData来进行数据的持久 化,CoreData的配置和使用步骤还是挺复杂的.但熟悉CoreData的使用流程后,CoreD ...
- iOS开发 QQ粘性动画效果
QQ(iOS)客户端的粘性动画效果 时间 2016-02-17 16:50:00 博客园精华区 原文 http://www.cnblogs.com/ziyi--caolu/p/5195615.ht ...
- Qt 之 模仿 QQ登陆界面——样式篇
一.简述 今天晚上花了半天时间从QQ登录界面抠了些图,顺便加了点样式基本上实现了QQ的登陆界面全部效果.虽不说100%相似,那也有99.99%相似了哈O(∩_∩)O. QQ好像从去年开始,登录界面有了 ...
- ios swift模仿qq登陆界面,xml布局
给大家推荐两个学习的地址: 极客学院的视频:http://www.jikexueyuan.com/path/ios/ 一个博客:http://blog.csdn.net/lizhongfu2013/a ...
- iOS开发--QQ音乐练习,后台播放和锁屏界面
一.设置后台播放 首先允许程序后台播放 代码实现 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOpti ...
- [UI基础][QQ登陆界面]
[目标] 1.QQ号码文本框要有“请输入QQ号码”的提示(用户输入时会自动消失) 2.QQ密码文本框要有“请输入QQ密码”的提示(用户输入文字会自动消失) 3.QQ号码文本框只能输入数字 4.QQ密码 ...
随机推荐
- iis7.5 设置伪静态
1)首先新建一个应用程序池,名称任意,比如:nettest,托管管道模式先暂时设置为集成模式,等下面的一系列设置完成之后再设置成经典模式: 2)部署好站点,并将此站点的应用程序池设置为nettest; ...
- 解决python version 2.7 required,which was not find in the registry
程序自动写注册表 http://www.vvivv.com/post-143.html 手工写 http://blog.csdn.net/baikaishui525/article/details/9 ...
- ImageLoder配置以及使用(个人阅读使用)
http://blog.csdn.net/vipzjyno1/article/details/23206387 在gradle添加: compile 'com.nostra13.universalim ...
- hdu4283 区间dp
//Accepted 300 KB 0 ms //区间dp //dp[i][j] 表示i到j第一个出场的最小diaosizhi //对于i到j考虑元素i //(1)i第一个出场,diaosizhi为 ...
- UVa 10318 Security Panel
题意:给你一个3*3的翻转模版,深色部分表示翻转,浅色部分不变.然后你可以在r*c的矩形里依照模版进行翻转,要求所有点亮所有块.输出最小的步骤. 思路:有一点比较好想.每个块至多被翻转一次,翻两次的效 ...
- SVG 2D入门2 - 图形绘制
基本形状 SVG提供了很多的基本形状,这些元素可以直接使用,这一点比canvas好多了.废话不说了,直接看例子,这个最直接: <svg width="200" heigh ...
- SQL实现字段内容查找和替换
- Juniper SRX防火墙-NAT学习笔记!
Junos NAT第一部分:SRX NAT介绍第二部分:Source NAT:Interface NAT第三部分:Source NAT:Address Pools第四部分:Destination NA ...
- C#操作指针
如何:递增和递减指针 使用增量和减量运算符 ++ 和 -- 可以将 pointer-type* 类型的指针的位置改变 sizeof (pointer-type). 增量和减量表达式的形式如下: ++p ...
- 转载: SQL Server中的索引
http://www.blogjava.net/wangdetian168/archive/2011/03/07/347192.html 1 SQL Server中的索引 索引是与表或视图关联的磁盘上 ...