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.

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

相关推荐
HIT_Weston3 分钟前
67、【Ubuntu】【Hugo】搭建私人博客(一)
前端·ubuntu·hugo
阿里巴啦16 分钟前
用React+Three.js 做 3D Web版搭建三维交互场景:模型的可视化摆放与轻量交互
前端·react·three.js·模型可视化·web三维·web三维交互场景
Liu.77426 分钟前
vue3组件之间传输数据
前端·javascript·vue.js
|晴 天|26 分钟前
前端闭包:从概念到实战,解锁JavaScript高级技能
开发语言·前端·javascript
开发者小天28 分钟前
react的拖拽组件库dnd-kit
前端·react.js·前端框架
用户44455436542637 分钟前
在Android开发中阅读源码的指导思路
前端
用户542778485154039 分钟前
ESM 模块(ECMAScript Module)详解
前端
全栈前端老曹1 小时前
【ReactNative】核心组件与 JSX 语法
前端·javascript·react native·react.js·跨平台·jsx·移动端开发
用户54277848515401 小时前
JavaScript 闭包详解:由浅入深掌握作用域与内存管理的艺术
前端
小小黑0071 小时前
快手小程序-实现插屏广告的功能
前端·javascript·小程序