123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- #pragma once
-
- #include "log.h"
- #include "common.h"
-
- #include <SDL2/SDL.h>
- #include <optional>
-
- namespace Swan {
-
- class Win {
- public:
- Win(SDL_Window *window, SDL_Renderer *renderer): window_(window), renderer_(renderer) {
- if (SDL_GetRendererInfo(renderer_, &rinfo_) < 0) {
- panic << "GetRenedrerInfo failed: " << SDL_GetError();
- abort();
- }
-
- info << "Using renderer: " << rinfo_.name;
- }
-
- Vec2 getSize() {
- int w, h;
- SDL_GetWindowSize(window_, &w, &h);
- return Vec2(((float)w / scale_) / TILE_SIZE, ((float)h / scale_) / TILE_SIZE);
- }
-
- SDL_Rect createDestRect(Vec2 pos, Vec2 pixsize) {
- return SDL_Rect{
- (int)((pos.x - cam_.x) * TILE_SIZE * scale_),
- (int)((pos.y - cam_.y) * TILE_SIZE * scale_),
- (int)(pixsize.x * scale_), (int)(pixsize.y * scale_),
- };
- }
-
- struct ShowTextureArgs {
- SDL_RendererFlip flip = SDL_FLIP_NONE;
- double hscale = 1;
- double vscale = 1;
- double angle = 0;
- std::optional<SDL_Point> center = std::nullopt;
- };
-
- void showTexture(
- const Vec2 &pos, SDL_Texture *tex, SDL_Rect *srcrect,
- ShowTextureArgs args) {
-
- SDL_Point *center = args.center ? &*args.center : nullptr;
- SDL_Rect destrect = createDestRect(pos, Vec2(srcrect->w * args.hscale, srcrect->h * args.hscale));
- if (SDL_RenderCopyEx(renderer_, tex, srcrect, &destrect, args.angle, center, args.flip) < 0)
- warn << "RenderCopyEx failed: " << SDL_GetError();
- }
-
- // We want an overload which uses RenderCopy instead of RenderCopyEx,
- // because RenderCopy might be faster
- void showTexture(const Vec2 &pos, SDL_Texture *tex, SDL_Rect *srcrect) {
- SDL_Rect destrect = createDestRect(pos, Vec2(srcrect->w, srcrect->h));
- if (SDL_RenderCopy(renderer_, tex, srcrect, &destrect) < 0)
- warn << "RenderCopy failed: " << SDL_GetError();
- }
-
- void drawRect(const Vec2 &pos, const Vec2 &size) {
- SDL_Rect destrect = createDestRect(pos, size * TILE_SIZE);
- if (SDL_RenderDrawRect(renderer_, &destrect) < 0)
- warn << "RenderDrawRect failed: " << SDL_GetError();
- }
-
- float scale_ = 2;
- Vec2 cam_;
- SDL_Window *window_;
- SDL_Renderer *renderer_;
- SDL_RendererInfo rinfo_;
- };
-
- }
|