more colors and typo fixing :3
This commit is contained in:
parent
857bcfa75d
commit
0d18bb4f83
2 changed files with 8 additions and 2 deletions
|
@ -35,11 +35,11 @@ class Shield: Armor {}
|
|||
|
||||
In the above scenario, we have [three layers of inheritance](https://wiki.c2.com/?MaxThreeLayersOfInheritance). We can imagine that `Item` handles behaviors like item management such as being added or removed from an inventory and highly generic item behavior. `Weapon` would then be responsible for an item which is capable of dealing damage at any range. We can expect that the specifics of its attack behavior would be implemented by a subclass. Similarly for `Armor`, this would handle generic damage interactions such as common mitigation or avoidance calculations while leaving specific implementation details to its subclasses.
|
||||
|
||||
Seasoned game devs, disciplined object-oriented programmers, and existing ECS developers can likely already see what comes next. A new requirement.
|
||||
Seasoned game devs, disciplined object-oriented programmers, and existing ECS developers can likely already see what comes next: a new requirement.
|
||||
|
||||
How do we add a Spiked Shield item -- one which derives the behaviors of `Weapon` and `Armor`? If we were using a language which supports multiple inheritance this could potentially be a nonissue: except that multiple inheritance is often [purposefully missing](https://en.wikipedia.org/wiki/Multiple_inheritance#The_diamond_problem) in many languages. We could decide that the item belongs more to one class than the other and just duplicate the missing behavior but these types of decisions often introduce unforeseen complexity: will the damage algorithm need to do a specific type check for `SpikedShield`? What about the equipment screen? And of course, what happens when we need to implement a damaging potion?
|
||||
|
||||
Perhaps the most appropriate solution this case would be to forgo the inheritance pattern in favor of [composition](https://en.wikipedia.org/wiki/Composition_over_inheritance). In C#, this could be achieved with `interfaces` and default implementations.
|
||||
Perhaps the most appropriate solution this case would be to forgo the inheritance pattern in favor of [composition](https://en.wikipedia.org/wiki/Composition_over_inheritance). In C#, this could be achieved with interfaces and default implementations.
|
||||
|
||||
```cs
|
||||
interface ICollectable {
|
||||
|
|
|
@ -35,6 +35,7 @@
|
|||
--foreground-color: var(--white);
|
||||
--background-color: var(--black);
|
||||
--secondary-background-color: var(--dark-violet);
|
||||
--code-color: var(--primary-complement-color);
|
||||
|
||||
--border-color: var(--secondary-color);
|
||||
--header-color: var(--secondary-triad-1-color);
|
||||
|
@ -54,6 +55,7 @@
|
|||
--foreground-color: var(--black);
|
||||
--background-color: var(--white);
|
||||
--secondary-background-color: var(--light-violet);
|
||||
--code-color: var(--tertiary-triad-1-color);
|
||||
|
||||
--border-color: var(--tertiary-color);
|
||||
--header-color: var(--tertiary-triad-1-color);
|
||||
|
@ -129,6 +131,10 @@ img {
|
|||
max-width: 100%;
|
||||
}
|
||||
|
||||
code {
|
||||
color: var(--code-color);
|
||||
}
|
||||
|
||||
pre, code {
|
||||
font-size: 1rem;
|
||||
padding: 0.5rem;
|
||||
|
|
Loading…
Reference in a new issue