/* ************************************************************************** */
/*                                                                            */
/*                                                        :::      ::::::::   */
/*   ft_key_loop.c                                      :+:      :+:    :+:   */
/*                                                    +:+ +:+         +:+     */
/*   By: rbousset <marvin@42.fr>                    +#+  +:+       +#+        */
/*                                                +#+#+#+#+#+   +#+           */
/*   Created: 2020/02/17 20:06:26 by rbousset          #+#    #+#             */
/*   Updated: 2020/02/17 20:06:29 by rbousset         ###   ########lyon.fr   */
/*                                                                            */
/* ************************************************************************** */

#include <libft.h>
#include <cub3d.h>
#include <mlx.h>
#include <stdint.h>

static void
	ft_get_damaged(uint16_t dmg, t_cub *cl)
{
	cl->plist.life -= dmg;
	if (cl->plist.life <= 0)
	{
		cl->isdead = 1;
		cl->sfx[0].sfx_play(cl->sfx);
		ft_death_screen(cl);
	}
	else
	{
		cl->sfx[3].sfx_play(cl->sfx);
	}
}

void
	ft_linux_suffer_animation(uint16_t dmg, t_cub *cl)
{
	int32_t	x;
	int32_t	y;

	y = -1;
	cl->img.img = mlx_new_image(cl->wlist.wlx,
		cl->wlist.x_size, cl->wlist.y_size);
	cl->img.ptr = mlx_get_data_addr(cl->img.img, &cl->img.bpp,
		&cl->img.sizeline, &cl->img.endian);
	while (++y < (int32_t)cl->wlist.y_size)
	{
		x = -1;
		while (++x < (int32_t)cl->wlist.x_size)
			*(int*)(cl->img.ptr +
				(x * 4 + (y * cl->img.sizeline))) = 0x00880404;
	}
	mlx_put_image_to_window(cl->wlist.wlx,
		cl->wlist.winptr, cl->img.img, 0, 0);
	mlx_destroy_image(cl->wlist.wlx, cl->img.img);
	ft_get_damaged(dmg, cl);
}

void
	ft_macos_suffer_animation(uint16_t dmg, t_cub *cl)
{
	int32_t	x;
	int32_t	y;
	t_rgb	rgb;

	y = -1;
	while (++y < (int32_t)cl->wlist.y_size)
	{
		x = -1;
		while (++x < (int32_t)cl->wlist.x_size)
		{
			rgb = ft_hex_to_og_rgb(*(int*)(cl->img.ptr +
				(x * 4 + (y * cl->img.sizeline))));
			rgb.r += 150;
			rgb.g += 20;
			rgb.b += 20;
			*(int*)(cl->img.ptr +
				(x * 4 + (y * cl->img.sizeline))) = ft_rgb_to_hex(0, rgb, cl);
		}
	}
	ft_get_damaged(dmg, cl);
	cl->doicast = 0;
}