Unreal Engine 集成 Steamworks SDK 教程

前言

STEAMWORKS 是什么? 它针对游戏项目提供了一整套的工具与服务,能帮助游戏开发者与发行商构建游戏,并从在 Steam 上分发游戏中获得最佳效益。简单的说就是类似 Appstore 或者 Google 商城一样的应用分发平台,所以如果您的游戏想在 Steam 上分发的话,那接入 STEAMWORKS SDK 就成了必做题。

需求分析

目前接入 Steamworks SDK 有好几种方式,根据你游戏引擎的不同,可操作性也不一样,这里我要带大家讲解的是如何在 UnrealEngin 中集成 Steamworks SDK,我总结了三种方式,分别如下:

  • UE 自带的 Steamworks SDK 版本太低,不想使用,我想直接下载最新的 SDK 接入游戏
  • UE 自带的 Steamworks SDK 能够满足我的需求
  • 使用 Epic 的 OnlineSubSystem

那接下来,咱就来简单的看下这几种方式该如何接入。

不使用 UE 自带的 Steamworks SDK

下载最新版本的 Steamworks SDK, 下载地址:partner.steamgames.com/downloads/s...

在 .cs 中引入相应配置,将下载好的 SDK 中的 steam 文件夹 copy 到工程的 source/工程名 中,然后在 .cs 配置文件中加入如下配置:

PublicAdditionalLibraries.Add(Path.Combine(ModuleDirectory, "steam", "lib", "steam_api64.lib"));

引入头文件 #include "steam/steam_api.h"

示例代码:

c++ 复制代码
FFileHelper::SaveStringToFile(TEXT(RAW_APP_ID), TEXT("steam_appid.txt"));
	SteamAPI_RestartAppIfNecessary(atoi(APP_ID));

	if (SteamAPI_Init())
	{
		GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Green, FString::Printf(TEXT("22222")));
	}
	else
	{
		GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Green, FString::Printf(TEXT("33333")));
	}

接入 UE 自带的 Steamworks SDK

在 .cs 中引入引擎提供的 Steamworks

AddEngineThirdPartyPrivateStaticDependencies(Target, "Steamworks");

引入头文件 #include "steam/steam_api.h"

示例代码调用:

c++ 复制代码
    FFileHelper::SaveStringToFile(TEXT(RAW_APP_ID), TEXT("steam_appid.txt"));
	SteamAPI_RestartAppIfNecessary(atoi(APP_ID));

	if (SteamAPI_Init())
	{
		
	}

使用Epic OnlineSubSystem

在 .cs 中引入配置

PublicDependencyModuleNames.AddRange(new string[] { "Core", "CoreUObject", "Engine", "InputCore", "OnlineSubsystem", "OnlineSubsystemSteam" });

当然必须也要参考UE文档,加入你们游戏项目所需的必要配置:

DefaultEngine.ini

ini 复制代码
[/Script/Engine.GameEngine]
+NetDriverDefinitions=(DefName="GameNetDriver",DriverClassName="OnlineSubsystemSteam.SteamNetDriver",DriverClassNameFallback="OnlineSubsystemUtils.IpNetDriver")

[OnlineSubsystem]
DefaultPlatformService=Steam

[OnlineSubsystemSteam]
bEnabled=true
SteamDevAppId=480

; If using Sessions
; bInitServerOnClient=true

[/Script/OnlineSubsystemSteam.SteamNetDriver]
NetConnectionClassName="OnlineSubsystemSteam.SteamNetConnection"

测试代码:

c++ 复制代码
#include "OnlineSubsystem.h"
#include "Interfaces/OnlineSessionInterface.h"

public:
	static constexpr char* APP_ID = RAW_APP_ID; 
	TSharedPtr<class IOnlineSession, ESPMode::ThreadSafe> myOnlineSessionInterface;
	
	
	
		IOnlineSubsystem* myOnlineSubsystem = IOnlineSubsystem::Get();
	if(myOnlineSubsystem)
	{
		myOnlineSessionInterface = myOnlineSubsystem->GetSessionInterface();
		GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Green, FString::Printf(TEXT("%s"), *myOnlineSubsystem->GetSubsystemName().ToString()));
	}

最后

以上就是在虚幻引擎中集成 Steamworks SDK 的几种方式,如果您有更好的方法,不妨也与我分享一下,另外记得在打出的包中 加入 steam_appid.txt ,并填写正确的 AppID.

我是杰少,如果您觉的我写的不错,那请给我 点赞+评论+收藏 后再走哦!

相关推荐
伍哥的传说18 分钟前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
yugi98783820 分钟前
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
前端
浪裡遊32 分钟前
Sass详解:功能特性、常用方法与最佳实践
开发语言·前端·javascript·css·vue.js·rust·sass
旧曲重听11 小时前
最快实现的前端灰度方案
前端·程序人生·状态模式
默默coding的程序猿1 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
夏梦春蝉2 小时前
ES6从入门到精通:常用知识点
前端·javascript·es6
归于尽2 小时前
useEffect玩转React Hooks生命周期
前端·react.js
G等你下课2 小时前
React useEffect 详解与运用
前端·react.js
我想说一句2 小时前
当饼干遇上代码:一场HTTP与Cookie的奇幻漂流 🍪🌊
前端·javascript
funnycoffee1232 小时前
Huawei 6730 Switch software upgrade example版本升级
java·前端·华为