gitbook/从0开始学游戏开发/docs/12179.md
2022-09-03 22:05:03 +08:00

72 lines
9.3 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# 第34讲 | 热点剖析(七):谈谈微信小游戏的成功点
在定下这个专栏目录的时候,微信小游戏仅仅出现了唯一一款《跳一跳》。在写下这篇文章的时候,微信小游戏已经在小程序领域占据了绝大部分的江山。大量开发者涌入微信小游戏,为微信生态、为微信小程序的生态增添了无数可能性。作为游戏开发者,免不了要被挤入这场战斗。今天我们就来了解一下微信小程序和小游戏背后的技术,来看看它们成功的背后,有哪些技术上的支持和创新。
## 微信小游戏的技术创新
最早以前微信小游戏有3M程序大小的限制而到了现在这个大小限制已经上升到了8M这使得微信小游戏从轻量级的休闲游戏逐渐往中级、重量级的方向发展。游戏的品质和操作性也有了质的提升。
小游戏的体积为什么会有限制呢因为体积较小的话我们可以从服务器快速拉取资源数据来开启游戏。现在微信平台本身已经可以做到20M的体积限制只是微信并不愿意开放地太快因为开发者有一个循序渐进的过程微信平台本身的战略规划也有一个循序渐进的过程。
我在之前的热点剖析部分分析过HTML5技术发展以及HTML5游戏引擎**其实微信小游戏、小程序甚至微信本身都是基于HTML5技术的而微信小游戏用的其实就是HTML5技术只是在小游戏中运用的是Canvas 2D的API和WebGL 1.0的API。**
毕竟微信小游戏也属于小程序的范畴,所以我们先来看一下微信小程序。
微信小程序用的是基于WebView的技术。所谓的WebView你可以理解为在手机中内置一款高性能WebKit内核的浏览器然后将这个浏览器核心封装成SDK供接口方调用。这个浏览器核心没有地址栏和导航栏只是单纯的在软件需要的地方展示一个网页界面。
微信小程序本身分为页面的视图层和逻辑层。页面的视图层运用的是WXML和WXSS它们是两种腾讯修改过的HTML和CSS技术而逻辑层则分为Manager和API。视图层和逻辑层都呼叫了JSBridge技术更下层则是一些网络服务、离线存储再下层则是系统层。具体的结构你可以看我画的这幅图。
微信小游戏脱胎于微信小程序。小游戏兼顾传统HTML5技术和小程序技术但是小游戏却没有用到WebView技术而是修改了HTML5规范的一些接口内容成为腾讯自己的内容。也就是说同一款游戏如果要在微信小游戏和普通网站都能运行需要编写两套代码。
那么你或许就要问了为什么微信要自己开发一套Web体系而不用Web本身的标准体系呢这样不是增加了前端程序员的工作量吗如果说都是一套Web体系的话大家不就可以皆大欢喜到这里可以用移植到那儿也可以用。
同样的问题我们是不是可以这么问为什么苹果公司要自己研发iOS系统用最早最成熟的塞班系统不是挺好诺基亚用得也挺不错。为什么谷歌要开发一套Go语言现成的Java、Python不也挺好都挺成熟为什么一定要开发新的东西让工程师入坑呢
有很多人说,自己开发一套体系是因为微信下的棋很大,野心很大,你可以这么理解,我们今天从技术本身来看看,事情是什么样的。
我们从以下几个方面来看为什么微信要自己定义一套体系。
1. **可以自定义Web标准**。为什么要自定义Web标准呢我们从结果来看自然是为了提升用户体验。而从技术层面讲这和Web兼容性有关。Web标准本身是个庞大的体系。所以如果既要全部兼容Web体系又要按照自己的意愿去实现功能这是很难做到的事情。比如如果微信本身的小程序浏览器会重塑一套渲染规则比如播放视频的时候自动屏蔽广告、按钮默认变成椭圆形等等因此自定义Web标准可以去做更多的事情。
2. **可以自定义开发标准**。微信扔掉了Web兼容性以及标准HTML5的内容之后就开始自定义开发标准了所以微信强制要求开发者按照某种编码规则来编写代码从而解决了在普通Web编程中“如果不用某种规则来编码就会出现兼容性问题”的难题这样就从源头上解决了这个问题。事实上这也是“强制约束开发者写出素质较高的代码”。
3. **可以有比HTML5更强的功能**。完全兼容标准HTML5的话并非不可能如果你熟悉前端开发的话就会知道这个坑会有多大。因为首先HTML5不具备很多功能比如获取手机设备信息、获取手机罗盘、地图定位等等。但如果用自定义的体系加上从微信作为App本身具有的底层获取功能就完全可以做到了。
4. **防止刷流量、刷广告**。在防止垃圾HTML5页面出现的这件事情上微信做了大量的工作比如你应该经常可以看到的如果出现单纯的IP地址的页面微信就给出提示询问你是否跳转或者提示你可以举报诱导分享等等当然这都不能完全避免垃圾HTML5页面出现在微信生态下所以在小程序自定义规则的情况下你只能按照定义规则来开发如果想钻空子最后小程序和小游戏的上线还有一道人工审核的关卡所以想要出现垃圾HTML5页面的情况几乎是不可能出现的。
5. **方便后续优化**。由于微信自己那一套体系是高层次抽象层,所以微信小程序团队可以在用户完全没有感知的情况下进行底层优化,而上层不用修改任何代码就可以了。
所以说微信小游戏其实是基于HTM5技术并在此之上充分结合自己的需求和产品特性添加了自己的创新。
## 微信小游戏成功的原因
微信小游戏建立在微信本体上,因此微信能获取到的移动端的**底层功能**小游戏基本都能一并获取比如网络连接、内部存储等等而HTML5做不到这点。微信可以获取底层平台的接口且并不需要授权因为微信安装上去后已经获取了手机的权限小游戏想要或者一部分权限是很容易的事情相比HTML5游戏要从浏览器获取权限那就是很麻烦的一件事情。
其次,因为微信本身作为**流量入口**对于小游戏的传播是一个极大的便利独立开发者或者中小游戏开发公司如果前期没有推广资源和推广渠道那么通过微信本身这个巨大的流量入口就可以获取相比传统HTML5游戏更好的效果。
除此之外传统HTML5小游戏可以包装成App的外壳做成App的形式供人下载因此又多了一个获客途径。到了后期苹果公司加大了对于HTML5应用和游戏包装成App这种形式的审核力度加上网页机制的运行效率限制HTML5套壳程序比原生应用的体验感也更差。
传统HTML5游戏发布之后如果需要更新则需要重新上传一次网页代码。如果用户端还需要重新刷新网页甚至清除浏览器缓存等复杂的操作如果做成App套壳那就更需要在各个渠道市场上传一遍程序这在效率上就慢了一截。而微信作为平台本身更新游戏后你重新获取只需要上传到微信平台就可以了获取新游戏刷新网页缓存微信一并帮你做了。
传统HTML5游戏的**广告接入**,是非常麻烦的一件事情,你需要去和广告商去做分成机制、对接广告接口等等。如果是微信小游戏,你只需要对接微信自己的广告渠道就可以,可以说是一键就能对接几种广告机制,广告分成也是透明的、公开的。
微信平台本身拥有**打击拷贝游戏**的能力,如果有一款游戏被抄袭了,你可以投诉,如果发现属实,微信就会将抄袭的游戏下架,这样一来,就保护了原创游戏,激发广大开发者创作出更好的游戏,给微信带来更好的游戏生态。当然这里所谓的原创机制,是指的微信小游戏本身生态下的原创,因为作为成熟的游戏生态来讲,已经基本不存在狭义上的“原创”这两个字了。
## 小结
这节内容差不多了,我们来总结一下。我和你讲了这样几个内容。
* 微信小游戏、小程序都是基于HTML5技术的而微信小游戏的技术就是HTML5技术只是在小游戏中运用的框架并不是普通的HTML5的框架。
* 微信小程序用的是基于WebView的技术小游戏却没有用到WebView技术而是修改了HTML5规范的一些接口内容成为腾讯自己的内容。
* 微信平台之所以要自定义自己的一套体系比如Web标准、开发标准等等是因为可以结合微信本身的特性在此基础上制作出更契合腾讯生态的产品一句话就是为了方便自己开发、优化和管理。
* 微信小游戏基于微信的底层获取功能、广告接入优势和打击拷贝的能力,塑造了一个更好的微信小程序生态。
迄今为止,你最喜欢玩的一款微信小游戏是什么?它吸引你的点是什么?
欢迎留言说出你的看法。我在下一节的挑战中等你!