2022年圣诞节到来啦,很高兴这次我们又能一起度过~
提示:使用unity来制作一个拼图游戏,图片便是圣诞树。
圣诞树拼图游戏
圣诞树拼图游戏最终效果。
游戏中效果如图:
游戏拼图完成后效果如图:
第一步,先新建场景,场景中包含内容如下图:
背景图Background是拼图的最终目标图片。用来为拼图作为参照的。
Body上绑定一个脚本main,脚本是用来生成图片拼图碎片的,并且以此为父物体,通过代码生成拼图碎片子物体。
运行后对应场景中的图片是:
第二步代码内容说明:在body这个物体上绑定一个脚本main,在代码中有tex all这个数组,该数组用来放置不同的图片。也就是说游戏不止一个拼图,可以是多个关卡,每个关卡是一张图片。图片可以通过给tex all这个数组赋值来修改。
下面的_RandomPos这个变量是用来设定,生成图片拼图碎片的位置。一张大图片可以随机生成6个区域的小图片。
生成的样式如下图:
生成的子物体在代码中已经定义好了,名字为:tempObj.name = "Item" + k;。但生成的子物体通过鼠标拖动的还需要一个代码。
子物体就是场景中的物体Plane。该物体添加的脚本如图:
main脚本详情如下:
using UnityEngine; using System.Collections; public class main : MonoBehaviour { public GameObject _plane; public GameObject _planeParent; public GameObject _background; public Texture2D[] _texAll; public Vector3[] _RandomPos; public int row = 3; public int column = 3; public float factor = 0.25f; GameObject[] _tempPlaneAll; float sideLength = 0; int finishCount = 0; int _index = 0; Vector2 originPoint; Vector2 space; void Start() { sideLength = _background.transform.localScale.x; space.x = sideLength / column; space.y = sideLength / row; originPoint.x = -((column - 1) * space.x) / 2; originPoint.y = ((row - 1) * space.y) / 2; Vector2 range; range.x = space.x * factor * 10f; range.y = space.y * factor * 10f; _tempPlaneAll = new GameObject[row * column]; int k = 0; for(int i = 0 ; i != row ; ++i) { for(int j = 0 ; j != column ; ++j) { GameObject tempObj = (GameObject)Instantiate(_plane); tempObj.name = "Item" + k; tempObj.transform.parent = _planeParent.transform; tempObj.transform.localPosition = new Vector3((originPoint.x + space.x * j) * 10f, (originPoint.y - space.y * i) * 10f, 0); tempObj.transform.localScale = new Vector3(space.x, 1f, space.y); Vector2 tempPos = new Vector2(originPoint.x + space.x * j, originPoint.y - space.y * i); float offset_x = (tempPos.x <= 0 + Mathf.Epsilon) ? (0.5f - Mathf.Abs((tempPos.x - space.x / 2) / sideLength)) : (0.5f + (tempPos.x - space.x / 2) / sideLength); float offset_y = (tempPos.y <= 0 + Mathf.Epsilon) ? (0.5f - Mathf.Abs((tempPos.y - space.y / 2) / sideLength)) : (0.5f + (tempPos.y - space.y / 2) / sideLength); float scale_x = Mathf.Abs(space.x / sideLength); float scale_y = Mathf.Abs(space.y / sideLength); tempObj.GetComponent<Renderer>().material.mainTextureOffset = new Vector2(offset_x, offset_y); tempObj.GetComponent<Renderer>().material.mainTextureScale = new Vector2(scale_x, scale_y); tempObj.SendMessage("SetRange", range); _tempPlaneAll[k] = tempObj; ++k; } } } void OnGUI() { if(GUI.Button(new Rect(10, 10, 100, 30), "Play")) StartGame(); if(GUI.Button(new Rect(10, 80, 100, 30), "Next Textrue")) ChangeTex(); } void StartGame() { for(int i = 0 ; i != _tempPlaneAll.Length ; ++i) { int tempRank = Random.Range(0, _RandomPos.Length); _tempPlaneAll[i].transform.localPosition = new Vector3(_RandomPos[tempRank].x, _RandomPos[tempRank].y, 0f); } gameObject.BroadcastMessage("Play"); } void SetIsMoveFale() { gameObject.BroadcastMessage("IsMoveFalse"); } void IsFinish() { ++finishCount; if(finishCount == row * column) Debug.Log("Finish!"); } void ChangeTex() { _background.GetComponent<Renderer>().material.mainTexture = _texAll[_index]; gameObject.BroadcastMessage("SetTexture", _texAll[_index++]); if(_index > _texAll.Length - 1) _index = 0; } }脚本plane详细如下:
using UnityEngine; using System.Collections; public class plane : MonoBehaviour { Transform mTransform; Vector3 offsetPos; Vector3 finishPos = Vector3.zero; Vector2 range; float z = 0; bool isPlay = false; bool isMove = false; void Start() { mTransform = transform; finishPos = mTransform.localPosition; } void Update() { if(!isPlay) return ; Vector3 tempMousePos = Camera.main.ScreenToWorldPoint(Input.mousePosition); if(Input.GetMouseButtonDown(0) && tempMousePos.x > GetComponent<Collider>().bounds.min.x && tempMousePos.x < GetComponent<Collider>().bounds.max.x && tempMousePos.y > GetComponent<Collider>().bounds.min.y && tempMousePos.y < GetComponent<Collider>().bounds.max.y) { mTransform.parent.SendMessage("SetIsMoveFale"); offsetPos = mTransform.position - tempMousePos; z = mTransform.position.z; isMove = true; } if(isMove && Input.GetMouseButton(0)) { tempMousePos = Camera.main.ScreenToWorldPoint(Input.mousePosition); mTransform.position = new Vector3(tempMousePos.x + offsetPos.x, tempMousePos.y + offsetPos.y, z - 0.1f); } if(Input.GetMouseButtonUp(0)) { mTransform.position = new Vector3(mTransform.position.x, mTransform.position.y, z); isMove = false; } IsFinish(); } void IsFinish() { if(mTransform.localPosition.x > finishPos.x - range.x && mTransform.localPosition.x < finishPos.x + range.x && mTransform.localPosition.y > finishPos.y - range.y && mTransform.localPosition.y < finishPos.y + range.y) { isPlay = false; mTransform.localPosition = finishPos; mTransform.parent.SendMessage("IsFinish"); } } void Play() { isPlay = true; } void IsMoveFalse() { isMove = false; } void SetRange(Vector2 _range) { range = _range; } void SetTexture(Texture2D _tex) { mTransform.GetComponent<Renderer>().material.mainTexture = _tex; } }
在脚本main中用GUI写了两个按钮,一个是开始玩游戏的play按钮,另一个是切换到下一张图片的按钮。如图:

?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
本教程将在Unity3D中混合Optitrack与数据手套的数据流,在人体运动的基础上,添加双手手指部分的运动。双手手背的角度仍由Optitrack提供,数据手套提供双手手指的角度。 01 客户端软件分别安装MotiveBody与MotionVenus并校准人体与数据手套。MotiveBodyMotionVenus数据手套使用、校准流程参照:https://gitee.com/foheart_1/foheart-h1-data-summary.git02 数据转发打开MotiveBody软件的Streaming,开始向Unity3D广播数据;MotionVenus中设置->选项选择Unit
目录1.AdmobSDK下载地址2.将下载好的unityPackagesdk导入到unity里编辑 3.解析依赖到项目中
Unity自动旋转动画1.开门需要门把手先动,门再动2.关门需要门先动,门把手再动3.中途播放过程中不可以再次进行操作觉得太复杂?查看我的文章开关门简易进阶版效果:如果这个门可以直接打开的话,就不需要放置"门把手"如果门把手还有钥匙需要旋转,那就可以把钥匙放在门把手的"门把手",理论上是可以无限套娃的可调整参数有:角度,反向,轴向,速度运行时点击Test进行测试自己写的代码比较垃圾,命名与结构比较拉,高手轻点喷,新手有类似的需求可以拿去做参考上代码usingSystem.Collections;usingSystem.Collections.Generic;usingUnityEngine;u
动漫制作技巧是很多新人想了解的问题,今天小编就来解答与大家分享一下动漫制作流程,为了帮助有兴趣的同学理解,大多数人会选择动漫培训机构,那么今天小编就带大家来看看动漫制作要掌握哪些技巧?一、动漫作品首先完成草图设计和原型制作。设计草图要有目的、有对象、有步骤、要形象、要简单、符合实际。设计图要一致性,以保证制作的顺利进行。二、原型制作是根据设计图纸和制作材料,可以是手绘也可以是3d软件创建。在此步骤中,要注意的问题是色彩和平面布局。三、动漫制作制作完成后,加工成型。完成不同的表现形式后,就要对设计稿进行加工处理,使加工的难易度降低,并得到一些基本准确的概念,以便于后续的大样、准确的尺寸制定。四、
修改(澄清问题)我已经花了几天时间试图弄清楚如何从Facebook游戏中抓取特定信息;但是,我遇到了一堵又一堵砖墙。据我所知,主要问题如下。我可以使用Chrome的检查元素工具手动查找我需要的html-它似乎位于iframe中。但是,当我尝试抓取该iframe时,它是空的(属性除外):如果我使用浏览器的“查看页面源代码”工具,这与我看到的输出相同。我不明白为什么我看不到iframe中的数据。答案不是它是由AJAX之后添加的。(我知道这既是因为“查看页面源代码”可以读取Ajax添加的数据,也是因为我有b/c我一直等到我可以看到数据页面之后才抓取它,但它仍然不存在)。发生这种情况是因为
关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion是否有适用于这些的3d游戏引擎?
写在之前Shader变体、Shader属性定义技巧、自定义材质面板,这三个知识点任何一个单拿出来都是一套知识体系,不能一概而论,本文章目的在于将学习和实际工作中遇见的问题进行总结,类似于网络笔记之用,方便后续回顾查看,如有以偏概全、不祥不尽之处,还望海涵。1、Shader变体先看一段代码......Properties{ [KeywordEnum(on,off)]USL_USE_COL("IsUseColorMixTex?",int)=0 [Toggle(IS_RED_ON)]_IsRed("IsRed?",int)=0}......//中间省略,后续会有完整代码 #pragmamulti_c
三分钟集成Tap防沉迷SDK(Unity版)一、SDK介绍基于国家对上线所有游戏必须增加防沉迷功能的政策下,TapTap推出防沉迷SDK,供游戏开发者进行接入;允许未成年用户在周五、六、日以及法定节假日晚上8:00-9:00进行游戏,防沉谜时间段进入游戏会弹窗进行提示!开发环境要求:Unity2019.4或更高版本iOS10或更高版本Android5.0(APIlevel21)或更高版本🔗Unity集成Demo参考链接🔗UnityTapSDK功能体验APK下载链接二、集成前准备1.创建应用进入开发者后台,按照提示开始创建应用;2.开通服务在使用TDS实名认证和防沉迷服务之前,需要在上面创建的应
写在前面前两天学习并整理的大气散射基础知识:【Unity大气渲染】关于单次大气散射的理论知识,收获了很多,但不得不承认的是,这其实已经是最早的、90年代的非常古老的方法了,后来也出现了一些优化性的计算思路和方法。因此,我打算先不急着跟各种教程在Unity中实现大气散射,而是再花时间来看看最近的游戏是如何去实现大气渲染的:06.游戏中地形大气和云的渲染(下)|GAMES104-现代游戏引擎:从入门到实践接下来就跟着GAMES104讲地形大气和云渲染的部分学习并做简单的记录,涉及到之前没提到的Mie散射也只选择直接截图PPT的方式记录啦!毕竟对于做作品来说,之后实现出来才是重要的~当然,May佬的