游戏微端的多渠道思路和简易的自动化打包工具

简介:



页游微端的几个问题及解答

为什么要开发游戏微游?

众所周知,Google大佬的Chrome浏览器在2015年时停止支持NPAPI,unity3d引擎的web player也是NPAPI的范畴,而我司的3D网页游戏正是使用unity3d引擎的web player,所以在Chrome 45及之后版本将打开我们的游戏。

微端版是导出windows平台而不是web player?

正是如此,下载微端玩的正是导出game.exe+game_Data而不是webplayer.unity3d+html,简单点来说: 通过下载微端玩游戏其实是客户端游戏(端游),而通过网页入口玩游戏还是unity web player.

为什么微端不是内嵌网页而是客户端游戏?

这个问题问的好!

假如是内嵌网页,那么玩家的还是要已安装unity web player才能进入游戏(网页插件类似flash)

客户端游戏无需安装web player插件,且端游可以利用更多系统性能,比如多线程,保存资源到本地等

为什么要做多平台/渠道打包功能?

我司U3D开发的大型3DMMORPG网页游戏,先后在腾讯,49游上线,近期内将和更多渠道和平台联运,包括多玩(yy),37玩,爱乐玩等。

微端登录和充值的流程

  1. 微端登录器 ——> 登录渠道——>回调游戏服务器 ——>启动并进入游戏
  2. 游戏内充值——> 跳到渠道的充值接口——>回调游戏服务器——>向游戏发放道具

1. 代理商和策划提出的需求

  • 腾讯的游戏版本是1.1
  • 多玩的版本是1.2
  • 49游的版本是1.3

所以游戏资源需要进行分渠道管理,代码也进行分支版本管理。

2. 不同渠道/平台的微端有什么区别?

  • 腾讯渠道:ab资源+代码,微端登录页QQ空间,支付是跳转到广点通
  • 49游渠道:ab资源+代码,微端登录页平台分配的游戏入口,支付是跳转到49游充值
  • 多玩渠道:ab资源+代码,微端登录页yy登录,支付是跳转到yy游戏充值中心
  • 爱 乐 玩 :ab资源+代码,微端登录页平台分配的游戏入口,支付是跳转到爱乐玩充值

3. 多平台要做的事

从上述2中可以看出,不同的渠道对应不同的微端以应付差异化,目前来说资源路径,代码,登录,充值链接等一些配置信息上的差异,当然每个渠道微端的外观也可能有差异

微端的技术分析请阅读:[http://www.cnblogs.com/zhaoqingqing/p/5671398.html](http://www.cnblogs.com/zhaoqingqing/p/5671398.html)

多渠道思路分析

思路1.单母包+安装器+配置表

微端只打包一次,安装器打包多次,每个平台/渠道有自己的专属配置文件

如何识别微端的渠道?

微端启动时读取目录中的配置文件识别当前平台,并将参数传递给游戏客户端

如何发布不同渠道的微端?

  • A渠道 = 母包 + A渠道配置文件 + A渠道安装器

  • B渠道 = 母包 + B渠道配置文件 + B渠道安装器

  • N渠道 = 母包 + N渠道配置文件 + N渠道安装器

微端母包有那些文件?

  • fileupdate : 检查更新程序
  • launcher: 游戏登录器/启动器
  • uninst : 卸载程序
  • unity pc game : unity 导出的windows程序,包含游戏的初始资源及配置文件

更多微端的技术分析请阅读:http://www.cnblogs.com/zhaoqingqing/p/5671398.html

思路2.打多次包 宏定义

把渠道的配置信息写在代码中,通过宏定义区分不同的渠道,但需要打包多次

         string loginURL = "";
#if you49
        loginURL = http://ylxxz.49you.com/client_login.html
#elif ewan21
        loginURL = http://www.2lewan.com/client/ylxxz
#elif duowan
        loginURL = http://www.duowan.com/ylxxz
#endif

如何识别微端的渠道?

答:微端启动时,通过代码中的宏定义识别识别当前平台,并将参数传递给游戏客户端

如何发布不同渠道的微端?

  • A渠道 = 打包A渠道包
  • A渠道 = 打包B渠道包
  • N渠道 = 打包N渠道包

我的解决方案

经过思考后我使用思路1母包+配置表 (注意点:针对不同的渠道,安装器需要重新打包)

实现步骤

自己编写简易的多渠道打包工具,打包工具主要功能及界面如下

  • 主界面:自动编译母包+安装器
  • 渠道选择:从列表选择渠道,程序自动验证渠道配置信息并提供预览
  • 打包结果:记录并显示打包结果

项目设定

打包工具结合项目的配置信息,进行多渠道打包,项目工程目录如下

  • 微端母包 源代码
  • 微端安装器 源代码
  • 各个平台/渠道 配置文件 /channel_configs 里面的文件如下
  • 49you.json
  • 2lewan.json
  • duowan.json
  • 37wan.json

  • 打包后的渠道文件存放位置 /channel_packages
  • /49you
  • /2lewan
  • /duowan
  • /37wan

安装器打包思路

  1. 合并安装器+配置文件
  2. vs打包配置(xml)
  3. 配置信息写在代码中,打包时替换代码文件或动态生成代码文件

思路1. 安装器和config合并

通过ilmerge合并文件

只能合并.net assemblies ,不能合并txt等非.net类型文件

http://www.microsoft.com/en-us/download/details.aspx?id=17630

https://ilmergegui.codeplex.com/

通过配置文件创建纯资源dll

https://msdn.microsoft.com/zh-cn/library/24b2tcy0%28VS.80%29.aspx?f=255&MSPPError=-2147217396

此方法觉得本末倒置了,所以决定使用msbuild来打包不同的安装器

思路2. msbuild

在 Visual Studio 中构建应用程序的三种方式: https://msdn.microsoft.com/zh-cn/library/cyz1h6zd.aspx

msbuild 参考: https://msdn.microsoft.com/zh-cn/library/dd393574.aspx

msbuild + xml (project.csproj)

msbuild 打包

条件编译符号(预编译宏)

项目解决方案:WinForm.sln,主要代码如下:

    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
            string channel = "default";
#if GooglePlay
            channel="google play";
#elif Samsung
            channel="sam sung store";
#elif AppStore
            channel="app store";
#endif
            this.textBox1.Text = channel;
        }
    }

假设当前要打包 googleplay渠道

msbuild /m WinForm.sln /t:Rebuild /p:Configuration=Debug /p:DefineConstants="GooglePlay"

假设当前要打包 AppStore渠道

msbuild /m WinForm.sln /t:Rebuild /p:Configuration=Debug /p:DefineConstants="AppStore"

/p:DefineConstants="AppStore" 指定宏

proj配置文件分析

*.proj (.net项目文件),本质上是一个xml文件,在build时根据这里面的参数进行build

  <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
    <PlatformTarget>AnyCPU</PlatformTarget>
    <DebugSymbols>true</DebugSymbols>
    <DebugType>full</DebugType>
    <Optimize>false</Optimize>
    <OutputPath>bin\Debug\</OutputPath>
    <DefineConstants>TRACE;DEBUG;AppStore</DefineConstants>
    <ErrorReport>prompt</ErrorReport>
    <WarningLevel>4</WarningLevel>
    <Prefer32Bit>false</Prefer32Bit>
  </PropertyGroup>

msbuild 文档资料

MSBuild 命令行参考 https://technet.microsoft.com/zh-cn/library/ms164311(v=vs.85).aspx

msbuild-msdn : https://msdn.microsoft.com/zh-cn/library/dd393574.aspx

可能遇到的问题

msbuild 不是内部或外部命令?

起因:家里的机器上同时安装VS2013 ,VS15(2016) 莫名出现msbuild不是内部或外部命令

解决办法:
C:\Program Files (x86)\MSBuild\12.0\Bin\ 添加到环境变量的 path 中

devenv 不是内部或外部命令?

解决办法:C:\Program Files (x86)\Microsoft Visual Studio 12.0\Common7\IDE 添加到环境变量的path中

示例打包脚本

打包单个项目和打包多个项目的示例脚本
https://github.com/zhaoqingqing/blog_samplecode/blob/master/build-tools/build_donet_signle_csproj.bat
https://github.com/zhaoqingqing/blog_samplecode/blob/master/build-tools/build_donet_muilt_csproj.bat

msbuild打包脚本可参考
https://github.com/zhaoqingqing/blog_samplecode/blob/master/build-tools/msbuild-sample.cmd


本文转自赵青青博客园博客,原文链接:http://www.cnblogs.com/zhaoqingqing/p/5774509.html,如需转载请自行联系原作者

相关文章
|
6天前
|
运维 持续交付 开发工具
自动化运维工具:Ansible入门教程
【8月更文挑战第60天】在现代IT运维管理中,自动化工具的使用已成为提高生产效率、减少人为错误和确保环境一致性的重要手段。本文将介绍Ansible——一款流行的开源自动化运维工具,通过其简单易学的语法和强大的功能,帮助读者快速入门并实现自动化部署和管理。我们将从Ansible的基本概念讲起,逐步深入到实际的代码示例,展示如何利用Ansible简化日常的运维任务。无论你是新手还是有经验的系统管理员,这篇文章都将为你提供实用的知识和技巧,让你轻松驾驭Ansible,开启自动化运维之旅。
|
6天前
|
运维 监控 jenkins
自动化运维之路:从脚本到工具的演变
【9月更文挑战第29天】在数字化浪潮中,运维不再是简单的服务器管理。本文将带您穿越自动化运维的发展历程,揭示如何通过技术革新提升效率与可靠性。我们将探索自动化工具如何解放双手,实现快速部署、监控和故障恢复,最终达到高效运维的目标。
|
12天前
|
运维 关系型数据库 MySQL
自动化运维工具:Ansible入门与实践
【9月更文挑战第23天】本文将带你进入自动化运维的世界,以Ansible为例,从基础概念到实际操作,让你轻松掌握自动化运维技能。我们将一起探索如何通过代码实现批量部署、配置管理和任务执行等功能,提高运维效率,减轻工作压力。让我们一起开启自动化运维之旅吧!
|
9天前
|
运维 Prometheus 监控
运维中的自动化工具与实践指南
本文深入探讨了自动化工具在IT运维中的重要性,提供了多种实用工具的推荐与应用实例。通过分析自动化工具如何提升运维效率、减少错误率,我们将揭示其在现代信息技术管理中的核心价值。无论你是IT新手还是经验丰富的专家,都能从中汲取到有益的知识,进而提升你的工作效果。
|
16天前
|
机器学习/深度学习 人工智能 运维
自动化运维:从脚本到工具的演进之路
【9月更文挑战第19天】在数字化时代的浪潮中,自动化运维如同一剂强心针,赋予IT系统以生命力。本文将带领读者穿梭于自动化运维的历史长河,探索它的起源、成长与变革。我们将一同见证如何从简单的shell脚本起步,逐步演化为复杂的自动化工具和平台。通过深入浅出的语言,我们不仅分享实用的代码示例,还将探讨自动化运维的最佳实践、面临的挑战以及未来的发展趋势。让我们开始这段旅程,解锁自动化运维的秘密,提升你的技术洞察力。
|
17天前
|
测试技术
基于LangChain手工测试用例转App自动化测试生成工具
在传统App自动化测试中,测试工程师需手动将功能测试用例转化为自动化用例。市面上多数产品通过录制操作生成测试用例,但可维护性差。本文探讨了利用大模型直接生成自动化测试用例的可能性,介绍了如何使用LangChain将功能测试用例转换为App自动化测试用例,大幅节省人力与资源。通过封装App底层工具并与大模型结合,记录执行步骤并生成自动化测试代码,最终实现高效自动化的测试流程。
30 4
|
18天前
|
存储 运维 网络安全
自动化运维工具:Ansible入门与实践
【9月更文挑战第17天】本文将介绍Ansible的基本概念、安装和简单使用,以及如何编写一个简单的Ansible playbook。通过本文,您可以了解到Ansible的基本原理和使用方法,以及如何在实际工作中应用Ansible进行自动化运维。
|
25天前
|
运维 监控 应用服务中间件
自动化运维工具的演变与实践
【9月更文挑战第10天】在数字化浪潮中,自动化运维工具如同星辰般璀璨,它们助力企业高效管理IT资源。从脚本编写到集成平台,工具的演进不仅提升了运维效率,更促进了技术生态的繁荣。本文将探讨自动化运维的发展历程、现代工具的选择与应用,并分享实践经验,旨在为读者提供深入理解与实用指导。
43 6
|
1天前
|
运维 持续交付 数据库
自动化运维工具的探索与实践
【9月更文挑战第34天】在快速发展的IT行业,高效、可靠的运维工作是保障系统稳定运行的关键。本文将介绍一些主流的自动化运维工具,并分享如何通过这些工具来提升运维效率和质量。
|
23天前
|
运维 Prometheus 监控
提升运维效率:自动化工具的应用与实践
运维工作作为信息技术领域的重要组成部分,其效率和质量直接关系到整个系统的稳定运行。随着科技的进步,自动化工具在运维中的应用越来越广泛。本文将探讨几种常见的自动化工具及其在实际操作中的应用案例,旨在为读者提供一些提升运维效率的思路和方法。通过合理利用这些工具,运维人员不仅可以提高工作效率,还能有效降低出错率,从而保障系统的高可用性。
17 0
下一篇
无影云桌面