1.çµèç¨ä»ä¹På¾è½¯ä»¶
2.前端实战:从零到一实现H5拼图小游戏(附源码)
çµèç¨ä»ä¹På¾è½¯ä»¶
æ¨èGIMPï¼GIMPå¨å ¶å®æ¹ç½ç«å°±å¯ä»¥ä¸è½½å°ï¼å®å ¨å¼æºå è´¹ãGIMPæ¯ï¼The拼图 GNU Image Manipulation Programçç®ç§°ï¼ï¼ä¸ä¸ªç¨GTKç¼åçå¾åç¼è¾å¤çç¨åºãGIMPæ¯è·¨å¹³å°è½¯ä»¶ï¼æåäº Linux å¹³å°ï¼ç®åå¨windowsä¸ä¹å¹¿æ³åºç¨ï¼äº¦æ¯æMacã
GIMPè¿æ¬¾è½¯ä»¶ï¼é¤äºè·¨å¹³å°ï¼å è´¹å¼æºä»¥å¤ï¼Photoshop大é¨åçåè½GIMPé½è½åå°ï¼På¾èªç¶æ¯ä¸å¨è¯ä¸ãèä¸GIMPå ç¨èµæºå°ï¼å¤çå¾çé度æå¿«çä¼ç¹ãGIMPæ件åªæå¤MBï¼å¦æ社åºæä¾çå¤ä¸ªæä»¶å ¨è£ å®åªæä¹MBã
å¹³æ¶å¤çç §çï¼GIMPä¹æä¾äºå¤§éçå 置滤éãå 置滤é满足ä¸äºéæ±çè¯ï¼GIMP社åºä¸ä¹æå¾å¤åè½å¼ºå¤§ç第ä¸æ¹ç滤éå¯ä»¥ä½¿ç¨ã
æ©å±èµæï¼
éæ©GIMPä½ä¸ºé¦æ¬¾På¾è½¯ä»¶ççç±ã
对äºéä¸ä¸äººå£«åå¦å¾åå¤çï¼ä½¿ç¨GIMPæå¾å¤§çä¼å¿ãè½ç¶PSåè½å¼ºå¤§ï¼ä½å¹¶ä¸éåæ°äººä½¿ç¨ï¼å¯¹äºæ³è¦ç®åPå¾ï¼ä¸å±äºä½¿ç¨âç¾å¾ç§ç§âä¹æµï¼å对å®å¶åæè¦æ±çç¨æ·æ¥è¯´ï¼PSæ¾å¾è¿äºèè¿åºå¤§ï¼å¹¶ä¸æ¯æä½³éæ©ã
Adobe å ¬å¸çPhotoshopåè½å ¬è®¤ç强大ï¼ä¸å På¾è½å强大ï¼ç»ç»æ¹é¢ä¹æå ¶ä¼ç§ãæ¯å ¨çå ¬è®¤çè¡ä¸æ åãä½è¯¥è½¯ä»¶å¯¹æ®é人并ä¸å好ï¼å¦ä¹ å¨æè¾é¿ï¼ä»·æ ¼è¾è´µï¼æ¯æ9.ç¾å ï¼æ¯å ¶é®é¢åå¨ã
ææ°çæ¬çPhotoshop çå ç¨ç£ç空é´è¾¾å°2.5个GBï¼å·²ç»æ¯åºç¶å¤§ç©äºï¼å ³é®æ¯åå ¶æ¶èç³»ç»èµæºï¼å¯¹ç¡¬ä»¶è¦æ±è¾é«ãå¾çå¤çé度并ä¸ä¼ç§ï¼ç»å¸¸åºç°åæ»ï¼å¡é¡¿ï¼éªéçç°è±¡ï¼å¹¶ä¸æ¨èæ°äººä½¿ç¨ã
ç¸æ¯è¾GIMPåºäºGNUåè®®çå 费软件ãå ¨çåå°çç¼ç¨é«æåå¾åå¤ççä¸å®¶ä¸ç´ä¸åå°æ¹è¿åç»´æ¤è½¯ä»¶ç设计åå¾åå¤ççç®æ³ï¼ä¿è¯äºè½¯ä»¶çå è¿æ§ä¸è¾äºä»»ä½ä¸ä¸ªåä¸è½¯ä»¶ã
å¦å¤ä¸ªäººçç §çåå¾åçå ¶ä»å¤çå ¶å®ä¹æ¯åå¨çæé®é¢çï¼å¤çè¿çç §çéè®°è½½äºæ使ç¨ç软件çä¿¡æ¯ï¼ï¼è使ç¨GIMPå¯ä»¥å å»ä»»ä½ä¾µæçé£é©ãGIMPä¸ä» å è´¹ï¼åæ¶è¿æ¯å¼æ¾æºä»£ç ç软件ãå¦ææ¢æ¯æå½±ç±å¥½è åæ¶åæ¯ç¨åºåï¼è¿å¯ä»¥ä½¿ç¨å¼æ¾çGIMPçæºä»£ç ç¼åèªå·±çä¸ç¨è½¯ä»¶ã
å为ä¸ä¸è½¯ä»¶ï¼äºè çå¦ä¹ ææ¬é½å·®ä¸å¤ï¼Photoshopç¥å¾®å¤æäºãä½å¦æå¦ä¼äºGIMPï¼åå»å¦ä¹ PSæ¯å¾å®¹æçãå 为GIMPç´§è·Photoshopçæ¥ä¼ï¼äºè ä¸å çé¢æå ¶ç¸ä¼¼ï¼åè½ä¹åºæ¬å·®ä¸å¤ã
åºæ¬Photoshopæçåè½ï¼GIMPé½ä¼å¨çæ¬æ´æ°ä¸å¼¥è¡¥ãGIMPç±äºæ¯å¼æºçï¼å¹¶æ²¡æPhotoshopçå¢éé£ä¹å¼ºå¤§ï¼å æ¤å¾å¤åè½åªæ¯ä¼å»¶åä¸äºï¼å½å2..8çæ¬çGIMPåPhotoshopæ¯å·®è·å·²ç»å¾å°äºã
åèèµææ¥æºï¼ç¾åº¦ç¾ç§ââ GIMP
前端实战:从零到一实现H5拼图小游戏(附源码)
去年,我开发了一个基于H5、软件JavaScript和CSS3的源码拼图小游戏。这款游戏利用了我自己封装的拼图类Jquery框架Xuery,融合了许多经典的软件JavaScript算法和CSS3特性,对提升大家的源码高培溯源码编程能力大有裨益。文章末尾将提供源码获取方式,拼图供大家学习体验。软件
由于这款应用属于H5游戏,源码为了使项目更轻量,拼图我没有使用第三方UI库。软件如果大家想使用基于Vue的源码第三方移动端UI库,我可以推荐几个我之前使用过的拼图靠谱组件库:[此处省略推荐内容]。以上推荐的软件都是社区完善、bug较少的源码组件库,大家可以试试看。
回到我们的洗车会员源码小游戏开发,主要考验大家对JavaScript和CSS3的掌握程度。学习完这篇文章后,相信大家对JavaScript和CSS3的编程能力都会有极大的提升。之后,我还会介绍如何使用canvas实现生成战绩海报图的功能。
我们先来看看游戏的预览界面:
本文的算法实现方式在之前的拼拼乐文章中已有说明,这里主要介绍核心算法,至于vue-cli的真人测源码使用方法,我之前也写过对应的文章,大家可以研究学习一下。vue-cli搭建项目方式如下:[此处省略搭建方法]。
关于vue-cli3配置实战,可以参考《一张图教你快速玩转vue-cli3》。
目前,我主要整理了以下核心功能,接下来我会一一为大家实现:实现纯JavaScript上传预览、android 10源码实现拼图分割功能、实现洗牌算法、实现生成战绩海报功能。
1. 实现纯JavaScript上传预览:文件上传预览主要采用FileReader API实现,原理是将file对象传给FileReader的readAsDataURL,然后转化为data:URL格式的字符串(base编码)以表示所读取文件的内容。具体代码如下:[此处省略代码]。
2. 实现拼图分割功能:一般处理拼图游戏时,transactional源码分析我们会采用以下方案:使用canvas分割、采用n张不同的切好的切片(方法简单,但会造成多次请求)、动态背景分割。经过权衡,我选择了一种自认为比较优雅的方法——动态背景分割,只需使用1张,然后利用CSS切割,有点像经典的雪碧图。具体实现如下:[此处省略实现方法]。
3. 实现洗牌算法:洗牌逻辑依托于随机算法,结合坐标系,实现一个随机生成二维坐标系的逻辑,然后通过改变每个切片的translate位置,配合过渡动画,即可实现洗牌功能和洗牌动画。具体实现如下:[此处省略实现方法]。
4. 实现生成战绩海报功能:生成战绩海报我采用canvas来实现,对于canvas的api不熟悉的可以查看MDN,讲得比较详细。这里我简单实现一个供大家参考:[此处省略实现方法]。
H5拼图小游戏我已在github开源,感兴趣的朋友可以在我github上学习参考。以上逻辑部分的代码可以直接整合到vue项目中,由于实现比较简单,这里我就不详细介绍了。
如果想学习更多H5游戏、webpack、node、gulp、css3、javascript、nodeJS、canvas数据可视化等前端知识和实战,欢迎在《趣谈前端》一起学习讨论,共同探索前端的边界。