Intermediate C++ Game Programming Tutorial 25

From Chilipedia
Revision as of 02:59, 9 March 2020 by R vdw (Talk | contribs) (Tutorial 25 - Bonus)

Jump to: navigation, search

Function pointers allow you to store and change what function is to be called dynamically at runtime. Combine that with containers to have collections of actions/behaviors that can be selected from, and then jam in the power std::function to allow you to wrap up pretty much any kind of callable thing and bring them together in one container. Groovy.

Topics Covered

  • Function pointers
  • Functionoids
  • std::function

Bonus Video

  • Pointers to member functions
  • std::bind
  • std::mem_fn
  • std::reference_wrapper (a little)
  • Pointer to static member function (it's the same as for normal funcy bois)
  • You can use normal func pointers for lambdas if they do not capture anything

Video Timestamp Index

Tutorial 25 - Function Pointers

[Expand]
  • How to switch on a string? (execute some code based on the string passed to the switch): using Functionoids 0:15
  • Introducing Function Pointers 5:13
  • Using Function Pointers with a map 7:27
  • Alternative route: use std::function<> in order to map to lambda functions 9:33
  • Example: making a single string switch class 13:01
  • Homework assignment: time to face the music 20:06

Tutorial 25 - Bonus

[Expand]
  • Pointers to a member function of a class/struct 0:07
  • Defining std::function to hold a pointer to a member function 3:30
  • std::bind from the Utilities library adapts function signatures <functional>5:57
  • Reference wrappers std::reference_wrapper 10:20
  • mem_fn creates a function object out of a pointer to a member 12:12
  • Lambda functions can bind much more elegantly 12:36
  • Operator function objects 14:55
  • Making a function pointer to a static member function 16:30
  • WORK-IN-PROGRESS

Tutorial 25 - Solution

[Expand]
  • A look at world.step( dt,8,3 );<code> in <Game::UpdateModel() 28:39
  • Solution to 1st part: destroy boxes of same color when they collide 33:50
  • Solution to 2nd part: pattern matching 42:20
  • The Spawn function of the Box class 53:00
  • Solution to 3rd part: add box tagging pattern 58:46
  • Solution to 3rd part: add box splitting pattern 59:39
  • Solution to 3rd part: add box splitting pattern 1:10:06
  • WORK-IN-PROGRESS

Homework Assignment

This homework might wreck your butthole a little, but hopefully not too badly. Anyways, you get the code from the repo, you try and get it to build. The project requires Box2D, but the repo doesn't have it included so you're gonna need to wrangle it yourself. The easiest way to accomplish this is to pull in dependencies into your system with vcpkg. Some of you are probably going to run into some speed bumps at this point getting vcpkg to work on your system, but I recommend powering through and not giving the fuck up, because vcpkg is immensely useful for adding amazing libraries to your projects easily. If you search YouTube, you'll find a video of me showing how to install vcpkg and use it to grab SFML, so that might be a good starting point.

After you get that shit working, the party has just started. Then you need to figure out how the codebase actually works. Use all the tools at your disposal (debugger, Google, Box2D documentation, etc.), and don't get bogged down in unimportant distractions (you don't need to know how the triangle rendering pipeline works to understand the general simulation system, for example).

The actual tasks are, as laid out in the video:

  1. Implement destruction of boxes when two boxes with the same color trait hit each other
  2. Implement a box splitting mechanic
  3. Implement a pattern matching collision event manager based on std::unordered_map (this is the main task that ties into Intermediate 25)
  4. Use the pattern matching system together with box splitting and other effects to define simulation with various action that occur based on what colors of boxes collide with each other.

Chili will hook you up with a solution video that A) explains the starting codebase in some detail and B) goes over the process of implementing all the the above.

The repo: GitHub

See also