-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
181 changed files
with
8,990 additions
and
9,037 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -348,3 +348,6 @@ MigrationBackup/ | |
|
||
# Ionide (cross platform F# VS Code tools) working folder | ||
.ionide/ | ||
|
||
# Rider | ||
.idea |
143 changes: 71 additions & 72 deletions
143
Negum.Core/Configurations/Animations/IAnimationElement.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,84 +1,83 @@ | ||
namespace Negum.Core.Configurations.Animations | ||
namespace Negum.Core.Configurations.Animations; | ||
|
||
/// <summary> | ||
/// Represents a single animation frame defined in an AIR file. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationElement | ||
{ | ||
/// <summary> | ||
/// Represents a single animation frame defined in an AIR file. | ||
/// 1st number is the sprite's group number. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationElement | ||
{ | ||
/// <summary> | ||
/// 1st number is the sprite's group number. | ||
/// </summary> | ||
int SpriteGroup { get; } | ||
int SpriteGroup { get; } | ||
|
||
/// <summary> | ||
/// 2nd number is the sprite's image number. | ||
/// </summary> | ||
int SpriteImage { get; } | ||
/// <summary> | ||
/// 2nd number is the sprite's image number. | ||
/// </summary> | ||
int SpriteImage { get; } | ||
|
||
/// <summary> | ||
/// The 3rd and 4th numbers of the element are the X and Y offsets from this sprite's axis. | ||
/// If you want the sprite to appear 5 pixels forwards, put "5" for the 3rd number. | ||
/// </summary> | ||
int OffsetX { get; } | ||
/// <summary> | ||
/// The 3rd and 4th numbers of the element are the X and Y offsets from this sprite's axis. | ||
/// If you want the sprite to appear 5 pixels forwards, put "5" for the 3rd number. | ||
/// </summary> | ||
int OffsetX { get; } | ||
|
||
/// <summary> | ||
/// The 3rd and 4th numbers of the element are the X and Y offsets from this sprite's axis. | ||
/// To make the sprite 15 pixels up, put "-15" for the 4th number, and so on. | ||
/// </summary> | ||
int OffsetY { get; } | ||
/// <summary> | ||
/// The 3rd and 4th numbers of the element are the X and Y offsets from this sprite's axis. | ||
/// To make the sprite 15 pixels up, put "-15" for the 4th number, and so on. | ||
/// </summary> | ||
int OffsetY { get; } | ||
|
||
/// <summary> | ||
/// 5th number is the length of time to display the element before moving onto the next, measured in game-ticks. | ||
/// There are 60 game-ticks in one second at normal game speed. | ||
/// For the 5th number, you can specify "-1" if you want that element to be displayed indefinitely (or until you switch to a different action). | ||
/// If you choose to do this, do it only on the last element of the action. | ||
/// </summary> | ||
int DisplayTime { get; } | ||
/// <summary> | ||
/// 5th number is the length of time to display the element before moving onto the next, measured in game-ticks. | ||
/// There are 60 game-ticks in one second at normal game speed. | ||
/// For the 5th number, you can specify "-1" if you want that element to be displayed indefinitely (or until you switch to a different action). | ||
/// If you choose to do this, do it only on the last element of the action. | ||
/// </summary> | ||
int DisplayTime { get; } | ||
|
||
/// <summary> | ||
/// If you want to flip the sprite horizontally and/or vertically, you will need to use the "flip" parameters: | ||
/// V - for vertical flip, | ||
/// H - for horizontal flip. | ||
/// These parameters will be 6th on the line. | ||
/// | ||
/// Flipping the sprite around is especially useful for making throws. | ||
/// The opponent who is being thrown will temporarily get the player's animation data, and enter the "being thrown" animation action. | ||
/// You'll might have to flip the sprites around to make the "thrown" action look correct. | ||
/// </summary> | ||
string Flip { get; } | ||
/// <summary> | ||
/// If you want to flip the sprite horizontally and/or vertically, you will need to use the "flip" parameters: | ||
/// V - for vertical flip, | ||
/// H - for horizontal flip. | ||
/// These parameters will be 6th on the line. | ||
/// | ||
/// Flipping the sprite around is especially useful for making throws. | ||
/// The opponent who is being thrown will temporarily get the player's animation data, and enter the "being thrown" animation action. | ||
/// You'll might have to flip the sprites around to make the "thrown" action look correct. | ||
/// </summary> | ||
string? Flip { get; } | ||
|
||
/// <summary> | ||
/// For certain things such as hit sparks, you might like to use color addition to draw the sprite, making it look "transparent". | ||
/// You won't need to use this to make a character, so you don't have to worry about this if you choose not to. | ||
/// The parameters for color addition and subtraction are "A" and "S" respectively, and should go as the 7th on the line. | ||
/// | ||
/// If you wish to specify alpha values for color addition, use the parameter format "AS???D???", | ||
/// where ??? represents the values of the source and destination alpha respectively. | ||
/// Values range from 0 (low) to 256 (high). | ||
/// For example, "AS64D192" stands for "Add Source_64 to Dest_192". | ||
/// Also, "AS256D256" is equivalent to just "A". A shorthand for "AS256D128" is "A1". | ||
/// </summary> | ||
string Color { get; } | ||
} | ||
|
||
/// <summary> | ||
/// For certain things such as hit sparks, you might like to use color addition to draw the sprite, making it look "transparent". | ||
/// You won't need to use this to make a character, so you don't have to worry about this if you choose not to. | ||
/// The parameters for color addition and subtraction are "A" and "S" respectively, and should go as the 7th on the line. | ||
/// | ||
/// If you wish to specify alpha values for color addition, use the parameter format "AS???D???", | ||
/// where ??? represents the values of the source and destination alpha respectively. | ||
/// Values range from 0 (low) to 256 (high). | ||
/// For example, "AS64D192" stands for "Add Source_64 to Dest_192". | ||
/// Also, "AS256D256" is equivalent to just "A". A shorthand for "AS256D128" is "A1". | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationElement : IAnimationElement | ||
{ | ||
public int SpriteGroup { get; internal set; } | ||
public int SpriteImage { get; internal set; } | ||
public int OffsetX { get; internal set; } | ||
public int OffsetY { get; internal set; } | ||
public int DisplayTime { get; internal set; } | ||
public string Flip { get; internal set; } | ||
public string Color { get; internal set; } | ||
} | ||
string? Color { get; } | ||
} | ||
|
||
/// <summary> | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationElement : IAnimationElement | ||
{ | ||
public int SpriteGroup { get; internal init; } | ||
public int SpriteImage { get; internal init; } | ||
public int OffsetX { get; internal init; } | ||
public int OffsetY { get; internal init; } | ||
public int DisplayTime { get; internal init; } | ||
public string? Flip { get; internal set; } | ||
public string? Color { get; internal set; } | ||
} |
49 changes: 24 additions & 25 deletions
49
Negum.Core/Configurations/Animations/IAnimationSection.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,30 +1,29 @@ | ||
namespace Negum.Core.Configurations.Animations | ||
namespace Negum.Core.Configurations.Animations; | ||
|
||
/// <summary> | ||
/// Represents a definition of a section in configuration which describe AIR aka Animation file. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationSection : IConfigurationSection | ||
{ | ||
/// <summary> | ||
/// Represents a definition of a section in configuration which describe AIR aka Animation file. | ||
/// Number of the current action. | ||
/// Action Number are generally next to the Section Name. | ||
/// i.e. [Begin Action 810] where 810 is an Action Number. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationSection : IConfigurationSection | ||
{ | ||
/// <summary> | ||
/// Number of the current action. | ||
/// Action Number are generally next to the Section Name. | ||
/// i.e. [Begin Action 810] where 810 is an Action Number. | ||
/// </summary> | ||
int ActionNumber { get; } | ||
} | ||
int ActionNumber { get; } | ||
} | ||
|
||
/// <summary> | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationSection : ConfigurationSection, IAnimationSection | ||
{ | ||
public int ActionNumber { get; internal set; } | ||
} | ||
/// <summary> | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationSection : ConfigurationSection, IAnimationSection | ||
{ | ||
public int ActionNumber { get; internal set; } | ||
} |
99 changes: 49 additions & 50 deletions
99
Negum.Core/Configurations/Animations/IAnimationSectionEntry.cs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,60 +1,59 @@ | ||
using System.Collections.Generic; | ||
|
||
namespace Negum.Core.Configurations.Animations | ||
namespace Negum.Core.Configurations.Animations; | ||
|
||
/// <summary> | ||
/// Represents a definition of an entry in a section in configuration which describe AIR aka Animation file. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationSectionEntry : IConfigurationSectionEntry | ||
{ | ||
/// <summary> | ||
/// Represents a definition of an entry in a section in configuration which describe AIR aka Animation file. | ||
/// Indicates if this collision box can be described as default. | ||
/// </summary> | ||
bool IsDefault { get; } | ||
|
||
/// <summary> | ||
/// Each sprite entry can have its own collision boxes. | ||
/// Clsn2 refers to a plain collision box and Clsn1 refers to an "attacking" box. | ||
/// You use attacking boxes when making attacking actions such as punching and kicking or special moves. | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public interface IAnimationSectionEntry : IConfigurationSectionEntry | ||
{ | ||
/// <summary> | ||
/// Indicates if this collision box can be described as default. | ||
/// </summary> | ||
bool IsDefault { get; } | ||
|
||
/// <summary> | ||
/// Each sprite entry can have its own collision boxes. | ||
/// Clsn2 refers to a plain collision box and Clsn1 refers to an "attacking" box. | ||
/// You use attacking boxes when making attacking actions such as punching and kicking or special moves. | ||
/// | ||
/// 1 - Attacking Box | ||
/// 2 - Plain Box | ||
/// </summary> | ||
int TypeId { get; } | ||
|
||
/// <summary> | ||
/// Collection of boxes describing current animations. | ||
/// Each box is build out of 4 values which describe x1, y1, x2, y2 values. | ||
/// </summary> | ||
IEnumerable<string> Boxes { get; } | ||
|
||
/// <summary> | ||
/// Animation elements connected with the current entry. | ||
/// </summary> | ||
IEnumerable<IAnimationElement> AnimationElements { get; } | ||
} | ||
/// 1 - Attacking Box | ||
/// 2 - Plain Box | ||
/// </summary> | ||
int TypeId { get; } | ||
|
||
/// <summary> | ||
/// Collection of boxes describing current animations. | ||
/// Each box is build out of 4 values which describe x1, y1, x2, y2 values. | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationSectionEntry : ConfigurationSectionEntry, IAnimationSectionEntry | ||
{ | ||
public bool IsDefault { get; internal set; } | ||
public int TypeId { get; internal set; } | ||
public IEnumerable<string> Boxes { get; } = new List<string>(); | ||
public IEnumerable<IAnimationElement> AnimationElements { get; } = new List<IAnimationElement>(); | ||
|
||
public void AddBox(string box) => | ||
((List<string>) this.Boxes).Add(box); | ||
|
||
public void AddAnimationElement(IAnimationElement element) => | ||
((List<IAnimationElement>) this.AnimationElements).Add(element); | ||
} | ||
IEnumerable<string> Boxes { get; } | ||
|
||
/// <summary> | ||
/// Animation elements connected with the current entry. | ||
/// </summary> | ||
IEnumerable<IAnimationElement> AnimationElements { get; } | ||
} | ||
|
||
/// <summary> | ||
/// </summary> | ||
/// | ||
/// <author> | ||
/// https://github.com/TheNegumProject/Negum.Core | ||
/// </author> | ||
public class AnimationSectionEntry : ConfigurationSectionEntry, IAnimationSectionEntry | ||
{ | ||
public bool IsDefault { get; internal set; } | ||
public int TypeId { get; internal set; } | ||
public IEnumerable<string> Boxes { get; } = new List<string>(); | ||
public IEnumerable<IAnimationElement> AnimationElements { get; } = new List<IAnimationElement>(); | ||
|
||
public void AddBox(string box) => | ||
((List<string>) Boxes).Add(box); | ||
|
||
public void AddAnimationElement(IAnimationElement element) => | ||
((List<IAnimationElement>) AnimationElements).Add(element); | ||
} |
Oops, something went wrong.