写在前面:登录注册功能是在纯Unity3D环境内实现的,用到UGUI绘制界面技术,数据库的部分是后面拓展加进来的,这里数据存储是指存在XML用户文件中。


注册用户名和密码

zc()

用户名和密码登录

denglu()

检测用户名是否存在

按钮选择进入和返回

open_bz()/close_bz()

一、登录窗口绘制

1、Create    UI    Panel 面板 (和窗口屏幕一样大)

√   Canvas 设置

Rander  Mode → Screen Space - Camera(模式)

把主摄像机 变成它的渲染相机 → 拖拽Main Camera → Render Camera

这里可以用  小手鼠标操作  拖拽面板  放大操作

2、√  Canvas   Scaler   屏幕模式

Ui  Scale Mode → Scale with Screen Si

设计(参考)分辨率:X:800  Y:600

Screen Math Mode → Match Width Or Height 匹配高

3、Panel 改名称 → Panel_bg(背景)

给一张图片:Source Image  …

颜色透明度:Image(Script) color:… 4个数值 → 往大调

4、Panel_bg下增加一个 Panel块   Panel_k

透明度:同样的改法  → SF Window 图片(边框)

color:可以改变颜色,任意颜色

Text:文本 → Font:自备(华文行楷)Bold → Rich Text(副文本)将√取消 → Best Fit(大小自适应)√勾选 → color 选择颜色

5、Button 按钮

text:修改文本文字 xxxx

Transition(过渡效果):Color Tint颜色过渡

  • Normal Color 正常颜色(自选)
  • Hightlight Color 高亮颜色(自选)

Sprit  Swap 过渡图片

6、InputField  输入框

placeholder :占位符 有提示,可输入

Text :文本控件 用来接收用户输入的信息用的

Source Image:背景图片

Color:颜色

√ Input Field(Script)→ Interactable √ 允许交互,一定要勾上

7、Character Limit:……  最大输入字符限制(0为没有限制)

Content Type:……  standard 标准输入模式     Password 星号密码输入模式

8、创建Script文件 - dl.C#文件 实现退出功能

//退出函数
public void Quit ()
{
#if UNITY_EDITOR
UnityEditor.EditorApplication.isPlaying = false;
#else
Application.Quit();
#endif
}
  • 拖拽文件到Canvas上,关联dl
  • 关联Button_tc 选择Button_tc,点击底部加号 +
  • [ none ]     物体选择   Canvas
  • No   Function → 选Quit 退出方法
二、注册窗口绘制

1、Canvas中创建UI → Image 调节图片大小 → 绘一张纯色的背景图片

在图片下 创建子物体

2、继续写 dl.C# 功能代码

√  显示Image_zc 打勾即显示(现在不显示,要去掉这个√),要用代码打勾√

public void open_zc(){
……
//(ture) 打勾 → 打开
//(false) 取消 → 关闭
}

实现关联注册按钮   同样, Canvas → open_zc()

注册窗口里“确认提交”和“取消提交”也要关联  Canvas → close_zc()

dl → 关联物体 - Image_zc

三、通用信息框的制作和测试

1、通用信息框:提示信息,包括两个文本框和一个按钮

dl → 关联物体

  • Image_ty_xxk  →Button_ty_xxk
  • Text_info
  • Text_ts

2、关联事件 - Canvas → dl → ty_xxk_close() "确定”按钮  关闭信息框

四、创建XML用户文件

1、在dl代码中 引入命令控件

  • using System.IO;
  • using System.Xml;

2、添加 void start() 函数 → 判断本地xml文件是否存在,存在不创建,不存在自动创建

  • 发布成Exe文件时,user.xml文件在同步生成的data文件夹中
  • 没发布时,user.xml文件在编辑器里,Assets目录下

3、记得修改默认帐号信息 → 用户名,密码

五、注册函数

1、添加其他的用户资料,写入本地xml文件中 → 写之前检测特定的空

  • 空着没写
  • 乱写(有不符合要求的)
  • 两个密码不一致

2、在dl文件中,写入注册函数 public void zc() → 关联“确认提交”Button_zc_ok,点击加号 + , Canvas → zc()

六、检查用户名是否被占用

1、先把密码的内容类型设置为:password 星号密码类型

2、打开用户文件,查找已有的子节点<Root> ,获取User信息,与用户在“注册”中填的信息,比较

  • 有,给出提示,直接返回
  • 没有,继续操作
七、完整的dl.C#代码

 

//dl.C#(登录注册功能)

using UnityEngine;
using System.Collections;
using UnityEngine.UI;
using UnityEngine.EventSystems;
using System.IO;
using System.Xml;
public class dl1 : MonoBehaviour {
public Image image_zc;
public Image image_ty_xxk;
public Text text_info;
public Text text_ts;
private string _xmlpath;
public InputField InputField_name_zc;
public InputField InputField_pass_zc;
public InputField InputField_pass1_zc;
public InputField InputField_tel_zc;
public InputField InputField_qq_zc;
public InputField InputField_name;
public InputField InputField_pass;
//创建xml文件
void Start () {
_xmlpath=Application.dataPath+"/user.xml";
if (!File.Exists (_xmlpath)) {
//新建xml实例
XmlDocument xmlDoc = new XmlDocument();
//创建根节点,最上层节点
XmlElement root = xmlDoc.CreateElement("Root");
xmlDoc.AppendChild(root);
//创建用户子节点
XmlElement user = xmlDoc.CreateElement("User");
user.SetAttribute("user_name","Elena");
user.SetAttribute("user_pass","I1314");
root.AppendChild(user);
xmlDoc.Save(_xmlpath);
Debug.Log("xml creat success!");
}
}
//退出函数
public void Quit ()
{
#if UNITY_EDITOR
UnityEditor.EditorApplication.isPlaying = false;
#else
Application.Quit();
#endif
}
//打开注册窗口
public void open_zc(){
image_zc.gameObject.SetActive (true); }
//关闭注册窗口
public void close_zc(){
image_zc.gameObject.SetActive (false); }
//打开通用信息框窗口
public void ty_xxk(string str){
image_ty_xxk.gameObject.SetActive (true);
text_info.text = str;
text_ts.text = str;
}
//关闭通用信息框窗口
public void ty_xxk_close(){
image_ty_xxk.gameObject.SetActive (false); }
//注册函数 public void zc(){
if (InputField_name_zc.text == "" || InputField_pass_zc.text == "" || InputField_pass1_zc.text == "" || InputField_tel_zc.text == "" || InputField_qq_zc.text == "") {
ty_xxk("信息不完整!有空的项目!");
return;
}
if (InputField_pass1_zc.text != InputField_pass_zc.text) {
ty_xxk("两次输入的密码不一致!!");
return;
}
//判断用户帐号是否被占用!
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(_xmlpath);
XmlNodeList nodeList = xmlDoc.SelectSingleNode("Root").ChildNodes;
foreach (XmlElement xe in nodeList){
if (xe.GetAttribute("user_name") == InputField_name_zc.text){
ty_xxk("该用户名已被占用!请更换用户名!");
return;
}
} //取得根节点
XmlNode root = xmlDoc.SelectSingleNode("Root");
//创建User新节点
XmlElement user = xmlDoc.CreateElement("User");
//XmlElement user1 = xmlDoc.CreateElement("User_lov");
//XmlText lov = xmlDoc.CreateTextNode ("158");
//user1.AppendChild (lov);
//设置属性
user.SetAttribute("user_name",InputField_name_zc.text);
user.SetAttribute("user_pass",InputField_pass_zc.text);
//将新节点加入根节点
root.AppendChild(user);
//root.AppendChild(user1);
//保存文件
xmlDoc.Save(_xmlpath);
//打开通用信息窗口显示信息
ty_xxk("恭喜!注册成功!");
//请空已注册的信息
InputField_name_zc.text="";
InputField_pass_zc.text="";
}
//登录函数
public void denglu(){
if (InputField_pass.text == "" || InputField_name.text == "") {
ty_xxk("用户名或密码不能为空!");
return;
}
//判断用户名是否已注册
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(_xmlpath);
XmlNodeList nodeList = xmlDoc.SelectSingleNode("Root").ChildNodes;
foreach (XmlElement xe in nodeList){
//判断用户名是否已注册
if (xe.GetAttribute("user_name") == InputField_name.text){
var mima=xe.GetAttribute("user_pass");
if(InputField_pass.text==mima){
ty_xxk("登录成功!");
Application.OpenURL ("http://www.cnblogs.com/ljq66/");
return;
}else{
ty_xxk("登录失败!密码错误!");
return;
}
}
}
//没有注册
ty_xxk("此用户帐号还没有注册!请注册!");
}
}

注:转载请注明出处

【Salvation】——登录注册存储数据&验证用户的更多相关文章

  1. node+mysql+express实现登录/注册/修改密码/删除用户 接口

    实现用户的注册.登录.修改密码.删除用户操作 用到的数据库:nodecms:表:user 目录结构: db目录下存放数据库操作语句: userSQL.js 用户有关的操作语句 router目录 接口路 ...

  2. Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册

    说明:这里没练习静态自动验证:如果用到静态验证首先自定义一个控制器,再在Model文件夹里创建一个NiHaoModel.php 类  NiHao是自定义的,前缀可以随意,但是一定要用驼峰法(首字母大写 ...

  3. vue登录注册及token验证

    // router.jsimport Vue from 'vue'import VueRouter from 'vue-router' Vue.use(VueRouter) const routes ...

  4. 模拟用户登录,内含验证码验证和request等操作

    模拟用户登录,内含验证码验证和jsp等操作 1.案例需求: 1. 访问带有验证码的登录页面login.jsp 2. 用户输入用户名,密码以及验证码. * 如果用户名和密码输入有误,跳转登录页面,提示: ...

  5. Java实战之01Struts2-03属性封装、类型转换、数据验证

    九.封装请求正文到对象中 1.静态参数封装 在struts.xml配置文件中,给动作类注入值.调用的是setter方法. 原因:是由一个staticParams的拦截器完成注入的. 2.动态参数封装: ...

  6. strut2 的数据验证

    数据验证 用户的输入验证,必须做,且工作量巨大. 1.验证的方式 客户端验证:javascript 服务端验证:逻辑验证(我们的代码) 注意:如果客户端和服务端二选一的话,服务器端的不能省. 实际开发 ...

  7. 学习Struts--Chap06:Struts2之数据验证

    1.数据验证的概述 1.1.数据验证的重要性 数据验证是非常必要的,不但和我们的常识性理解有关系,还有可能涉及到一些非法输入等问题,所以我们需要进行必要的数据验证,以保证我们在数据输入的时候都是正确且 ...

  8. 项目一:第八天 1、前台系统导入 实现客户注册 发验证码,邮件 springdata-redis存储数据 3、实现客户登陆

    1 前台系统客户注册功能 页面:signup.html 1.1 验证手机号是否注册(邮箱同样) 1. 使用Jquery-validate插件进行相关校验,使用校验规则 <input type=& ...

  9. Ruby Rails学习中:User 模型,验证用户数据

    用户建模 一. User 模型 实现用户注册功能的第一步是,创建一个数据结构,用于存取用户的信息. 在 Rails 中,数据模型的默认数据结构叫模型(model,MVC 中的 M).Rails 为解决 ...

随机推荐

  1. OpenShift中的持续交付

    上一文中讲述了如何在AWS下搭建OpenShift集群.这篇文章将目光转向如何在OpenShift中实现CI/CD以及产品环境的部署. 持续交付 如果要打造一个持续交付的流水线,首先要考虑多环境的问题 ...

  2. BlockingQueue<> 队列的作用

    BlockingQueue<> 队列的作用 BlockingQueue 实现主要用于生产者-使用者队列 BlockingQueue 实现主要用于生产者-使用者队列,BlockingQueu ...

  3. Android 之数据存储(sdCard,sharedPreference,sqlite数据库)

    sdCard:默认路径在 /storage/sdcard/... Android支持OpenFileOutput和openFileInput方式访问手机存储器上的文件. Context提供了如下两个方 ...

  4. jquery实现点击div外隐藏div

    html <div style="width:100px;height:100px;border:1px solid #ff0" id="div"> ...

  5. 【转】Mapreduce部署与第三方依赖包管理

    Mapreduce部署是总会涉及到第三方包依赖问题,这些第三方包配置的方式不同,会对mapreduce的部署便捷性有一些影响,有时候还会导致脚本出错.本文介绍几种常用的配置方式: 1. HADOOP_ ...

  6. struts2的防止表单重复提交

    防止表单重复提交其实就是struts2的一个拦截器的使用: struts.xml配置文件: <?xml version="1.0" encoding="UTF-8& ...

  7. Linux命令行与脚本编程大全第一章

    1, 2,linux内核:内存管理.进程管理.文件管理.设备管理. 其中内存管理如下图: 通过命令 cat/proc/meminfo查看系统的内存状态.通过ipcs查看共享内存.信号量.消息队列信息. ...

  8. Ubuntu16笔记本双显卡安装NVIDIA驱动

    blockquote { direction: ltr; color: rgb(0, 0, 0) } blockquote.western { font-family: "Liberatio ...

  9. windows下怎么解决Python双版本问题

    相信大家会在windows下会遇到Python双版本问题 当我们装了Python2和Python3时我们好只能在命令栏调出最高版本的那个低版本的难道消失了吗?今天我们就解决这个问题! 1.下载 我们在 ...

  10. asp.net core封装layui组件示例分享

    用什么封装?自然是TagHelper啊,是啥?自己瞅文档去 在学习使用TagHelper的时候,最希望的就是能有个Demo能够让自己作为参考 怎么去封装一个组件? 不同的情况怎么去实现? 有没有更好更 ...