mirror of
https://github.com/italicsjenga/agb.git
synced 2024-12-23 08:11:33 +11:00
203 lines
9.5 KiB
Markdown
203 lines
9.5 KiB
Markdown
# Changelog
|
|
|
|
All notable changes to this project will be documented in this file.
|
|
|
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
|
|
## [Unreleased]
|
|
|
|
### Added
|
|
|
|
- New tracker for playing XM files (see the `agb-tracker` crate).
|
|
- You can now declare where looping sound channels should restart.
|
|
|
|
### Changed
|
|
|
|
- Sound channel panning and volume options are now `Num<i16, 8>` rather than `Num<i16, 4>` for improved precision and sound quality.
|
|
|
|
### Fixed
|
|
|
|
- Mono looping samples will now correctly play to the end if it doesn't perfectly align with a buffer boundry and short samples now also loop correctly.
|
|
|
|
## [0.16.0] - 2023/07/18
|
|
|
|
### Added
|
|
|
|
- New `include_palette` macro for including every colour in an image as a `u16` slice.
|
|
- New object based text renderer.
|
|
|
|
### Changed
|
|
|
|
- Changed the default template game.
|
|
- `DynamicSprite` has a new API which changes the constructor and adds a `set_pixel` and `clear` methods.
|
|
- You no longer need to install arm-none-eabi-binutils. In order to write games using `agb`, you now only need to install rust nightly.
|
|
- 10% performance improvement with the software mixer.
|
|
|
|
### Fixed
|
|
|
|
- Compile error if you tried to import a larger sprite which uses more than 15 colours between frames.
|
|
|
|
## [0.15.0] - 2023/04/25
|
|
|
|
### Added
|
|
|
|
- You can now import aseprite files directly (in addition to the already supported png and bmp files) when importing background tiles.
|
|
- New additional unmanaged object API for interacting with a more straightforward manner with the underlying hardware.
|
|
|
|
### Changed
|
|
|
|
- Importing background tiles has been improved. You no longer need to use `include_gfx!` with the toml file. Instead, use `include_background_gfx`. See the documentation for usage.
|
|
- The hashmap implementation is now it its own crate, `agb-hashmap`. There is no change in API, but you can now use this for interop between non-agb code and agb code.
|
|
- Moved the existing object API to be the OamManaged API. The old names persist with deprecated notices on them.
|
|
|
|
## [0.14.0] - 2023/04/11
|
|
|
|
### Added
|
|
|
|
- Added custom `gbafix` implementation which can take the elf file produced by `cargo build` directly, removing the need for the objcopy step.
|
|
|
|
### Changed
|
|
|
|
- Made Vector2D::new a const function.
|
|
- The template now uses rust 2021 edition by default.
|
|
- All objects which should only be created once now have the correct lifetimes to only allow one to exist.
|
|
- Template now uses codegen-units=1 to workaround bug in nightly.
|
|
- Allocator is no longer interrupt safe.
|
|
- Soundness issues with interrupts resolved which makes them unsafe and require the closure to be static (breaking change).
|
|
|
|
### Fixed
|
|
|
|
- Alpha channel is now considered by `include_gfx!()` even when `transparent_colour` is absent.
|
|
- 256 colour backgrounds are now correctly rendered (breaking change).
|
|
- The `#[agb::entry]` macro now reports errors better.
|
|
- Added the shstrtab section to the linker to ensure that agb builds with lld.
|
|
|
|
## [0.13.0] - 2023/01/19
|
|
|
|
### Added
|
|
|
|
- Added missed implementations of `regular()` and `affine()` to `Tiled1` which made `Tiled1` impossible to use.
|
|
|
|
### Changed
|
|
|
|
- Text renderer can now be re-used which is useful for rpg style character/word at a time text boxes.
|
|
- Audio now automatically uses interrupts, so you can remove the `setup_interrupt_handler` or `after_vblank` calls to the mixer.
|
|
- If a vblank happens outside of `wait_for_vblank`, then next call will immediately return.
|
|
|
|
### Fixed
|
|
|
|
- Zero volume now plays no sound.
|
|
- Fixed issue where volume was incorrect for volumes which were powers of 2.
|
|
|
|
## [0.12.2] - 2022/10/22
|
|
|
|
This is a minor release to fix an alignment issue with background tiles.
|
|
|
|
### Fixed
|
|
|
|
- Corrected alignment of background tiles which was causing issues with rendering tiles in some cases.
|
|
|
|
## [0.12.1] - 2022/10/12
|
|
|
|
This is a minor release to fix the build of the docs on [docs.rs/agb](https://docs.rs/agb).
|
|
|
|
### Fixed
|
|
|
|
- Fixed the agb crate's docs.rs build
|
|
|
|
## [0.12.0] - 2022/10/11
|
|
|
|
This version of `agb` has some exciting new features we'd like to highlight and some brand new contributors!
|
|
|
|
1. Save support for multiple cartridge types (contributed by @Lymia)
|
|
2. Affine background support (contributed by @lifning)
|
|
|
|
We also had a contribution by @ijc8. We can't thank you all enough!
|
|
|
|
### Added
|
|
|
|
- Custom allocator support using the `Allocator` trait for `HashMap`. This means the `HashMap` can be used with `InternalAllocator` to allocate to IWRAM or the `ExternalAllocator` to explicitly allocate to EWRAM.
|
|
- Support for using windows on the GBA. Windows are used to selectively enable rendering of certain layers or effects.
|
|
- Support for the blend mode of the GBA. Blending allows for alpha blending between layers and fading to black and white.
|
|
- Added a new agb::sync module that contains GBA-specific synchronization primitives.
|
|
- Added support for save files.
|
|
- Added implementation of `HashMap.retain()`.
|
|
- Added support for affine backgrounds (tiled modes 1 and 2) which allows for scaling, rotating etc of tiled backgrounds.
|
|
- Added support for 256 colour backgrounds (when working with affine ones).
|
|
- Added affine matrix module. This allows for manipulation of affine matricies for use in backgrounds and in the future objects.
|
|
- Added support for dynamic sprites generated at runtime, some parts of this may change significantly so breaking changes are expected here.
|
|
|
|
### Changed
|
|
|
|
- Many of the places that originally disabled IRQs now use the `sync` module, reducing the chance of missed interrupts.
|
|
- HashMap iterators now implement `size_hint` which should result in slightly better generation of code using those iterators.
|
|
- Transparency of backgrounds is now set once in the toml file rather than once for every image.
|
|
- Palette generation now takes into account every single background a toml definition rather than one at a time, you can now find it in the PALETTES constant rather than in every individual image.
|
|
- Sound frequency is no longer a crate feature, instead set when initialising the sound mixer.
|
|
- `testing` is now a default feature, so you no longer need to add a separate `dev-dependencies` line for `agb` in order to enable unit tests for your project.
|
|
|
|
### Fixed
|
|
|
|
- Fixed the fast magnitude function in agb_fixnum. This is also used in fast_normalise. Previously only worked for positive (x, y).
|
|
- Fixed formatting of fixed point numbers in the range (-1, 0), which previously appeared positive.
|
|
|
|
## [0.11.1] - 2022/08/02
|
|
|
|
Version 0.11.1 brings documentation for fixed point numbers. We recommend all users upgrade to this version since it also includes fixes to a few functions in fixnum. See changed section for breaking changes.
|
|
|
|
### Added
|
|
|
|
- Support for sprites that are not square.
|
|
- Docs for fixed point numbers.
|
|
|
|
### Changed
|
|
|
|
- `Rect::contains_point` now considers points on the boundary to be part of the rectangle.
|
|
- Signature of `Rect::overlapping_rect` changed to return an Option. Returns None if rectangles don't overlap.
|
|
|
|
### Fixed
|
|
|
|
- Fixed point sine calculates the sine correctly.
|
|
|
|
## [0.10.0] - 2022/07/31
|
|
|
|
Version 0.10.0 brings about many new features. As with most `agb` upgrades, you will need to update your `gba.ld` and `gba_mb.ld` files which you can find in the [template repo](https://github.com/agbrs/template). We would also recommend copying the `[profile.dev]` and `[profile.release]` sections from `Cargo.toml` if you don't have these values already.
|
|
|
|
### Added
|
|
|
|
- [Hyperspace roll](https://lostimmortal.itch.io/hyperspace-roll), a new game built for the GMTK Game Jam 2022 using `agb`. The source code can be found in the `examples` directory.
|
|
- Started using GitHub discussions as a forum
|
|
- Many functions previously undocumented are now documented
|
|
- Z-Ordering of sprites - you can now change the render order of sprites rather than it just being defined by the order in which they appear in object memory
|
|
- 32kHz audio. Probably the best sound quality you'll get out of the hardware, but uses a lot of ROM space
|
|
- Transparent sprite support with aseprite
|
|
- You can now write tests for projects depending on agb
|
|
- Very basic font rendering - looking for feedback, this API is far from stable
|
|
- Faster implementation of memcpy and memset thanks to the agbabi crate which provide a big performance boost for any project using agb
|
|
- If you wish, you can now optionally do dynamic memory allocation to IWRAM instead of only EWRAM
|
|
- You can now use 64x64px sprites
|
|
- You can now configure the background size for tiled backgrounds
|
|
- It is possible to create 'dynamic tiles' for backgrounds. These are tiles which are defined at runtime
|
|
- Random number generator in agb::rng
|
|
|
|
### Changed
|
|
|
|
- Audio system optimisations - reduced CPU usage by more than 50%
|
|
- Background tiles are now removed from Video RAM during `commit()` if they are no longer used rather than immediately reducing flickering
|
|
- Improved the README for both the main agb crate and the template
|
|
- The template now builds with optimisations in debug mode and debug symbols in release mode
|
|
- Added `#[must_use]` to many of the places it is needed
|
|
- All subcrates get released at once, so versions are kept in lockstep
|
|
- A few methods accepting `Num<..>` have been changed to accept `impl Into<Num<..>>` to make them easier to use
|
|
|
|
### Removed
|
|
|
|
- The ability to use timer0 and timer1 through the `timer` module. This was done in order to fully support 32kHz audio
|
|
|
|
### Fixed
|
|
|
|
- Sprite data is now correctly aligned so fast copies will always work
|
|
- A few methods which should really be internal have had `pub` removed
|
|
- The crate now compiles (but does not run) doctests in CI which pointed out a large number of non-compiling examples
|