Hello everyone, and welcome to the inaugural development diary for "Run for Seoul." If you've followed my previous projects like "Find with Seoul" and "Stations in Seoul," you'll find that this new game is taking a different direction.
A New Experience
Unlike my previous titles, "Run for Seoul" is envisioned as a party game that multiple people can enjoy together. The aim is to create a fun, engaging experience that stands apart from what I've done before.
Why a Party Game?
I wanted to explore new avenues in game development and felt that a party game would offer a fresh, communal experience. It's a genre that I believe has a lot of potentials to bring people together and offer a different kind of fun.
Hello everyone, and welcome back to the 12th installment of the development diary for "Stations in Seoul." It's been a journey filled with ups and downs, delays, and moments of uncertainty. But here we are, still pushing forward.
Roadmap Update
I've finally put together a roadmap for the game. The process has been challenging, especially since I'm working on this project alone. However, I've come to realize that the best way to make progress is to get your feedback. That's why I've decided to go ahead and release the game in Early Access.
Why Early Access?
I'm well aware that the game isn't where I'd like it to be just yet. But Early Access provides a platform for me to gather invaluable feedback from you all. Your thoughts, suggestions, and even criticisms will help shape this game into something better.
Feedback is Crucial
Your feedback is more than welcome; it's essential. Whether it's bugs you've found, features you'd like to see, or any other thoughts you might have, I'm eager to hear them.
Hello players! Jay from Future Cat Labs here with your 21st 'Find with Seoul' development diary. Thanks for sticking with me. Let's get right into it.
About That Map... I have to apologize; the promised map isn't ready. I've realized my planning was a bit ambitious, so to get things on track, I've created a roadmap. Expect to see updates on this weekly.
New Monthly Goal: One Map Despite the hiccup, delivering a new map within this month is still the main aim. The roadmap should help keep things in focus.
That's the snapshot for now. Your support is my inspiration, and your feedback is always my guide.
Until next week, Jay at Future Cat Labs
P.S. Stay tuned, and let's keep leveling up together!
Jay here from Future Cat Labs, coming at you with the 20th installment of our 'Find with Seoul' development diary. Your enthusiasm and support are the very fuel that keeps this engine going, so let's get into what's been cooking.
Updates Are on the Way, Just Hang Tight! Apologies for the radio silence on new updates. The wheels are definitely turning behind the scenes, and I'm geared up to bring you some new excitement real soon.
In the Lab: Lip-Sync for Written Dialogue Ever thought how neat it would be for characters to really "speak" their lines? Well, I've been tinkering with making their lips move in sync with the written text. It's a small detail that I hope adds a whole new layer of immersion.
Stage Navigation via Keyboard Switching gears a bit, I'm working on enabling keyboard controls for navigating through the game stages. Your hands won't know what hit 'em!
Upcoming Map: It's Still a Thing! If you're itching for fresh terrain, rest assured, a new map is still in the works and I'm aiming to release it this month. It's going to be a game-changer, pun intended.
Thank you for being the co-pilots in this incredible journey. Your continual support and input make all the difference.
Here's to another week of top-notch gaming, Jay at Future Cat Labs
P.S. We're in this for the long haul, and the best is still to come. Let's continue to level up together!
Hey players! It's Jay from Future Cat Labs, back with the 19th edition of our development diary for 'Find with Seoul.' You're the spark that keeps my creative fires burning, and your encouragement means the world.
No Fresh Updates—But I'm Hard at Work! I apologize for not rolling out new updates this week. They're brewing, though, and I'm hustling to get them just right for you.
On the Drawing Board: Dynamic Characters How cool would it be to see game characters' mouths move when they talk? I'm brainstorming ideas to breathe even more life into our virtual buddies, so they're not just digital mannequins. It's all about the little things that add a dash of realism and a heap of charm.
New Stage Alert! A brand-new stage is in the pipeline! My goal is to get it out to you within the month. Fresh story, new challenges, and more fun await!
A Quick Note Sorry for the delay in releasing this diary entry. Balancing personal responsibilities, like figuring out living expenses, with game development took a bit more time than I expected. But know that I'm committed to keeping things timely moving forward.
You guys are the wind beneath my wings. Your ongoing support, your invaluable feedback—it's the stuff that dreams are made of.
Wishing you a week full of epic gaming, Jay at Future Cat Labs
P.S. Keep those seat belts fastened; the ride is just getting started. So thrilled you're here for the journey. Let's continue to reach new heights together!
Welcome to the 11th development diary for 'Stations in Seoul' from Future Cat Labs. Your support fuels my creativity, and I've got some updates to share!
What's Happening?
Focusing on Convenience: I'm committed to enhancing your experience in the game. Every detail matters, and I'm working to make everything just right.
Expanding the Story: There's more to explore in 'Stations in Seoul'. New chapters, more excitement, and endless fun are on the horizon.
A Week of Reflection: No major updates this week, but that doesn't mean I'm not hard at work. I'm brainstorming, planning, and dreaming big for our next steps.
Thank you for being part of this journey. Your encouragement and feedback continue to inspire me. Here's to making 'Stations in Seoul' a game you'll love!
Welcome to the 18th development diary for Find with Seoul! Your encouragement fuels my creativity and drives me to make this game a work of heart.
No New Updates This Week, but the Wheels Are Turning!
Always Striving for Convenience! I'm like a detective with a magnifying glass, still examining those little nooks and crannies that need smoothing out. I'm on a mission to make your experience with Find with Seoul as comfortable as a cozy chair in your favorite cafe.
Cooking Up More Story and Future Plans! The plot thickens, and the future's bright! I'm knee-deep in thoughts and sketches, crafting additional storylines, and pondering where our adventure goes next. It's like being a novelist and a game creator rolled into one, and I can't wait to share these new chapters with you.
Although this week may seem quiet, it's been a time of reflection, planning, and laying the groundwork for the exciting twists and turns ahead. Rest assured, the gears are always turning here at Future Cat Labs!
I couldn't do this without your constant support. You're the co-pilots on this thrilling journey, and your feedback and ideas are always welcome.
Wishing you a fantastic gaming week, Jay at Future Cat Labs
P.S. Stay tuned, adventurers! The best is yet to come, and I'm beyond thrilled to have you all aboard this incredible ride. Let's keep reaching for the stars together!
이 유형의 통계는 독특하고 매우 유용한 기능을 제공하지만 설명하려면 조금 더 자세한 설명이 필요합니다.
"시간당 획득한 포인트"와 같은 평균 통계를 추적하고자 하는 경우를 생각해 보겠습니다. 한 가지 접근 방식은 두 개의 통계, 즉 INT "총 포인트"와 FLOAT "총 플레이 시간 시간"을 가진 다음 포인트를 시간으로 나누어 시간당 포인트를 구하는 것입니다.
이 구현의 단점은 플레이어가 상당한 양의 플레이 시간을 누적하면 계산된 평균이 매우 느리게 변한다는 것입니다. 실제로 사용자가 게임을 더 많이 플레이할수록 평균의 반응성이 떨어집니다. 사용자가 100시간 동안 게임을 플레이했다면, 계산된 평균은 그 중 약 50시간 정도 "지연"됩니다. 스킬이 증가해도 시간당 포인트가 기대만큼 증가하지 않습니다.
평균 통계 유형을 사용하면 평균에 "슬라이딩 윈도우" 효과를 구현할 수 있습니다. 예를 들어, 이전 몇 시간의 게임 플레이만 활용할 수 있으므로 통계에 플레이어의 현재 스킬 레벨이 더 정확하게 반영됩니다.
이전 20시간의 게임 플레이만 값에 영향을 미치는 "시간당 포인트"를 구현하기 위해 AVGRATE 통계를 설정해 보겠습니다. 이렇게 하려면 다음과 같이 하세요:
평균은 "시간당"이므로 이 통계와 관련된 모든 시간 매개변수의 시간 단위는 "시간"이 됩니다. 이는 통계 자체의 Window 프로퍼티와 아래의 UpdateAvgRateStat에 전달된 "dSessionLength" 파라미터에도 적용됩니다.
flCountThisSession - UpdateAvgRateStat를 마지막으로 호출한 이후 플레이어가 획득한 포인트 수입니다.
dSessionLength - UpdateAvgRateStat를 마지막으로 호출한 이후의 게임 시간입니다. 단위는 통계의 창 프로퍼티에 있는 단위와 동일해야 합니다. 이 경우 "시간"입니다.
예를 들어, 플레이어가 0.225시간(13.5분) 동안 지속된 마지막 라운드에서 77점을 획득했다면, SteamUserStats()->UpdateAvgRateStat( "AvgPointsPerHour", 77, 0.225 )가 됩니다.
위의 예에서 Steam은 현재 라운드 평균 점수인 시간당 342.2점(77을 0.225로 나눈 값)을 이전 값과 혼합합니다. 결과는 플레이어의 지난 20시간 게임 시간 동안의 총 평균을 반영합니다. 현재 사용자에 대한 스탯이 처음 업데이트된 경우 현재 값은 342.2가 됩니다.
이 예에서는 시간 단위로 '시간'을 사용했지만 원하는 시간 단위를 사용할 수 있습니다. 다만 "dSessionLength" 및 Window 프로퍼티의 기본 단위로 해당 단위를 일관되게 사용해야 한다는 점만 기억하세요.
Steam은 통계 및 업적 데이터의 로컬 캐시를 유지하여 오프라인 모드에서도 API를 정상적으로 사용할 수 있도록 합니다. 커밋할 수 없는 통계는 사용자가 다음에 온라인 상태가 될 때를 위해 저장됩니다. 두 대 이상의 컴퓨터에서 수정이 이루어진 경우, Steam은 자동으로 업적을 병합하고 더 많이 진행된 통계 세트를 선택합니다. Steam은 통계 데이터의 로컬 캐시를 보관하므로 게임에서 디스크에 데이터의 로컬 캐시를 보관할 필요는 없습니다. 이러한 캐시가 충돌하는 경우가 종종 발생하며, 충돌이 발생하면 사용자에게는 진행 상황이 되돌아간 것처럼 보이므로 매우 불쾌한 경험이 될 수 있습니다.
게임 서버 통계
ISteamUserStats와 유사하게 게임 서버를 위한 ISteamGameServerStats가 있습니다. 이 서버는 클라이언트와 동일한 방식으로 사용자 통계를 가져올 수 있습니다(위에서 설명한 대로). 또한 통계를 설정하고 업적을 수여할 수도 있지만, '설정 기준'이 GS(게임 서버) 또는 공식 GS로 설정된 경우에만 가능합니다. 게임 서버와 공식 게임 서버의 차이점은 공식 게임 서버는 회원님이 직접 호스팅하고 관리하는 서버라는 점입니다. 공식 게임 서버를 사용하여 통계를 설정하면 사용자가 자신의 게임 서버를 수정하거나 게임 서버로 위장할 수 있으므로 부정행위에 대한 보안이 강화됩니다. 공식 게임 서버를 정의하려면 여기에 서버의 IP 범위를 입력합니다.
게임 서버에서 설정할 수 있는 통계 및 도전 과제는 클라이언트에서 설정할 수 없습니다. 게임 서버는 현재 서버에서 플레이 중인 사용자의 스탯과 도전 과제만 설정할 수 있습니다. 사용자가 서버를 떠나는 경우 최종 통계를 설정할 수 있는 짧은 유예 기간이 있지만, 그 이후에는 새로운 업로드가 거부됩니다. 이는 일관성을 보장하고 악의적인 게임 서버가 언제든지 다른 사람의 통계를 설정할 수 없도록 하기 위한 조치입니다. 이러한 제한을 고려할 때, 스탯을 설정하기 위해 라운드가 끝날 때까지 기다리지 않는 것이 중요합니다. 사용자가 종료할 때 저장할 수 있도록 지속적으로 설정해야 합니다.
클라이언트는 게임 서버가 스탯을 변경하면 자동으로 업데이트됩니다. 그러나 클라이언트와 마찬가지로 서버가 다른 사용자를 위해 로드한 통계는 자동으로 새로 고쳐지지 않으며 오래될 수 있습니다.
통계 초기화
개발 중에는 테스트를 위해 계정 또는 모든 계정의 통계와 업적을 완전히 지우는 것이 바람직한 경우가 종종 있습니다. 계정의 통계를 초기화하려면 bAchievementsToo를 true로 설정한 상태에서 ISteamUserStats::ResetAllStats를 호출하여 업적도 초기화하세요. 이 함수를 호출한 후에는 통계와 도전 과제를 다시 실행하고 메모리 내 게임 상태를 초기화하는 것을 잊지 마세요. 모든 사용자의 스탯과 도전 과제를 전역적으로 지울 수 있는 방법은 없습니다. 그 이유 중 하나는 전역 초기화를 수행하더라도 진행 중인 게임이 초기화를 인식하지 못하고 인메모리 값을 다시 기록할 수 있기 때문입니다. 다행히도 게임에 글로벌 초기화 시스템을 쉽게 구축할 수 있는 방법이 있습니다. 방법은 다음과 같습니다:
이렇게 하면 전역 초기화를 원할 때마다 하드코딩된 통계 버전 번호만 변경하면 됩니다. 그러면 사람들이 새 빌드를 받을 때 전역 삭제가 수행됩니다.
통계 일관성
관련 통계가 어떻게 일관성이 없어질 수 있는지 고려하는 것이 좋습니다. 예를 들어 "GamesWon", "GamesLost", "GamesPlayed" 통계가 세 개 있을 수 있습니다. 최선의 의도에도 불구하고 통계는 서로 동기화되지 않을 수 있고 실제로 동기화되지 않습니다. 이 경우 이긴 게임과 잃은 게임이 총 플레이한 게임에 합산되지 않을 수 있습니다. "GamesLost" 통계를 제거하고 대신 "GamesPlayed" - "GamesWon"으로 계산하여 이 문제를 해결했다면, 불일치로 인해 "GamesLost"가 음수가 될 수 있습니다. 이 경우 "GamesPlayed" 통계를 삭제하고 "GamesWon" + "GamesLost"로 계산하는 것이 가장 좋습니다.
글로벌 통계
관리자 페이지에서 통계를 집계된 것으로 표시하여 Steam이 모든 사용자의 통계 값을 전체적으로 합산하도록 할 수 있습니다. 이를 통해 경제의 총 돈, 총 킬 수, 좋아하는 무기, 좋아하는 지도, 어느 팀이 더 잘하는 경향이 있는지에 대한 데이터를 얻을 수 있습니다. 반대로 '최다 킬 수'와 같은 통계에는 여러 사용자에 대해 합산하는 것은 의미가 없으므로 사용해서는 안 됩니다. 통계는 사용자의 손에 달려 있기 때문에 이 데이터는 조작될 수 있습니다. 따라서 집계된 통계를 사용할 때는 최소값, 최대값, 증분만(적절한 경우), 최대 변화에 대한 적절한 범위를 설정하는 것이 중요합니다. 최대 변화는 집계된 통계에서 특별한 의미를 갖습니다. 새 값이 업로드되면 글로벌 값은 최대 변경 값보다 더 많이 변경되지 않습니다. 이는 부정 행위자가 글로벌 총계에 얼마나 빨리 영향을 미칠 수 있는지를 제한합니다.
앱이 출시되기 전에는 Steam 커뮤니티나 라이브러리에서 어떤 도전 과제를 획득했는지 확인할 수 없습니다. 앱에서 사용자가 획득한 업적을 출력할 수 있는 방법이 필요합니다.
게임에 코드를 추가하지 않고 도전 과제나 통계를 지우려면 Steam 클라이언트 콘솔을 사용하면 됩니다. 그런 다음 steam.exe -console로 실행하세요:
achievement_clear <appid> <achievement name>
reset_all_stats <appid>
Steam 커뮤니티
게임이 출시되면 개인 및 글로벌 업적 진행 상황에 대한 정보가 Steam 커뮤니티에 표시됩니다. 각 플레이어는 커뮤니티 프로필에서 자신이 달성한 업적과 아직 잠금 해제하지 않은 업적을 보여주는 페이지로 이동할 수 있는 링크를 받게 됩니다.
NOTE: 앱이 커뮤니티에 어느 정도 공개될 때까지 업적은 표시되지 않습니다.
각 업적은 Steamworks 제어판에 설정된 대로 해당 아이콘과 이름 및 설명이 표시됩니다. 업적 이름과 설명이 사용자가 선택한 언어로 현지화된 경우 해당 언어로 표시됩니다.
또한 이 페이지와 게임의 기본 Steam 페이지에서 게임의 글로벌 업적 통계로 연결되는 링크가 있습니다. 여기에는 가장 일반적인 업적부터 가장 희귀한 업적까지 순서대로 각 업적을 달성한 Steam 플레이어의 비율이 표시됩니다. 이 정보는 플레이어가 재미있게 볼 수 있을 뿐만 아니라 개발자에게도 유용한 자료가 됩니다: 특별 업적이 충분히 어려운가요? 아니면 너무 어려운가요? (이 정보는 판매 및 활성화 보고서 사이트에서도 확인할 수 있습니다).