Add screenshot feature

This commit is contained in:
Such Meme, Many Skill 2020-05-03 02:00:04 +02:00
parent 6c2d0cf162
commit cb46e4bc40
5 changed files with 86 additions and 9 deletions

View file

@ -3,6 +3,7 @@
#include "../utils/btn.h" #include "../utils/btn.h"
#include "../gfx/gfx.h" #include "../gfx/gfx.h"
#include "../utils/types.h" #include "../utils/types.h"
#include "../tegraexplorer/utils/utils.h"
static Inputs inputs = {0}; static Inputs inputs = {0};
u16 LbaseX = 0, LbaseY = 0, RbaseX = 0, RbaseY = 0; u16 LbaseX = 0, LbaseY = 0, RbaseX = 0, RbaseY = 0;
@ -15,6 +16,10 @@ Inputs *hidRead(){
jc_gamepad_rpt_t *controller = joycon_poll(); jc_gamepad_rpt_t *controller = joycon_poll();
static bool errPrint = false; static bool errPrint = false;
if (controller->cap)
utils_takeScreenshot();
u8 btn = btn_read(); u8 btn = btn_read();
inputs.volp = (btn & BTN_VOL_UP) ? 1 : 0; inputs.volp = (btn & BTN_VOL_UP) ? 1 : 0;
inputs.volm = (btn & BTN_VOL_DOWN) ? 1 : 0; inputs.volm = (btn & BTN_VOL_DOWN) ? 1 : 0;

View file

@ -25,7 +25,7 @@ int delfile(const char *path, const char *filename){
gfx_clearscreen(); gfx_clearscreen();
SWAPCOLOR(COLOR_ORANGE); SWAPCOLOR(COLOR_ORANGE);
gfx_printf("Are you sure you want to delete:\n%s\n\nPress B to cancel\n", filename); gfx_printf("Are you sure you want to delete:\n%s\n\nPress B to cancel\n", filename);
if (gfx_makewaitmenu("Press A to delete", 3)){ if (gfx_makewaitmenu("Press A to delete", 2)){
f_unlink(path); f_unlink(path);
fsreader_readfolder(currentpath); fsreader_readfolder(currentpath);
return 0; return 0;

View file

@ -79,7 +79,7 @@ int foldermenu(){
break; break;
case DIR_DELETEFOLDER: case DIR_DELETEFOLDER:
gfx_clearscreen(); gfx_clearscreen();
if (gfx_defaultWaitMenu("Do you want to delete this folder?\nThe entire folder, with all subcontents will be deleted!!!", 4)){ if (gfx_defaultWaitMenu("Do you want to delete this folder?\nThe entire folder, with all subcontents will be deleted!", 2)){
gfx_clearscreen(); gfx_clearscreen();
gfx_printf("\nDeleting folder, please wait...\n"); gfx_printf("\nDeleting folder, please wait...\n");

View file

@ -6,12 +6,15 @@
#include "../../mem/heap.h" #include "../../mem/heap.h"
#include "../gfx/gfxutils.h" #include "../gfx/gfxutils.h"
#include "../../hid/hid.h" #include "../../hid/hid.h"
/*
#include "../../utils/util.h" #include "../../utils/util.h"
#include "../../utils/sprintf.h" #include "../../utils/sprintf.h"
#include "../../libs/fatfs/ff.h" #include "../../libs/fatfs/ff.h"
#include "../fs/fsutils.h" #include "../fs/fsutils.h"
*/ #include "../../mem/minerva.h"
#include "../../storage/nx_sd.h"
#include "../../gfx/di.h"
extern bool sd_mounted;
int utils_mmcMenu(){ int utils_mmcMenu(){
if (emu_cfg.enabled) if (emu_cfg.enabled)
@ -26,18 +29,66 @@ void utils_copystring(const char *in, char **out){
strcpy(*out, in); strcpy(*out, in);
} }
/*
void utils_takeScreenshot(){ void utils_takeScreenshot(){
static u32 timer = 0;
if (!minerva_cfg || !sd_mounted)
return;
if (timer + 3 < get_tmr_s())
timer = get_tmr_s();
else
return;
char *name, *path; char *name, *path;
char basepath[] = "sd:/tegraexplorer/screenshots"; char basepath[] = "sd:/tegraexplorer/screenshots";
name = malloc(35); name = malloc(40);
sprintf(name, "Screenshot_%d", get_tmr_s()); sprintf(name, "Screenshot_%08X.bmp", get_tmr_us());
f_mkdir("sd:/tegraexplorer"); f_mkdir("sd:/tegraexplorer");
f_mkdir(basepath); f_mkdir(basepath);
path = fsutil_getnextloc(basepath, name); path = fsutil_getnextloc(basepath, name);
free(name);
const u32 file_size = 0x384000 + 0x36;
u8 *bitmap = malloc(file_size);
u32 *fb = malloc(0x384000);
u32 *fb_ptr = gfx_ctxt.fb;
for (int x = 1279; x >= 0; x--)
{
for (int y = 719; y >= 0; y--)
fb[y * 1280 + x] = *fb_ptr++;
}
memcpy(bitmap + 0x36, fb, 0x384000);
bmp_t *bmp = (bmp_t *)bitmap;
bmp->magic = 0x4D42;
bmp->size = file_size;
bmp->rsvd = 0;
bmp->data_off = 0x36;
bmp->hdr_size = 40;
bmp->width = 1280;
bmp->height = 720;
bmp->planes = 1;
bmp->pxl_bits = 32;
bmp->comp = 0;
bmp->img_size = 0x384000;
bmp->res_h = 2834;
bmp->res_v = 2834;
bmp->rsvd2 = 0;
sd_save_to_file(bitmap, file_size, path);
free(bitmap);
free(fb);
display_backlight_brightness(255, 1000);
msleep(100);
display_backlight_brightness(100, 1000);
} }
*/
char *utils_InputText(char *start, int maxLen){ char *utils_InputText(char *start, int maxLen){
if (!hidConnected()) if (!hidConnected())

View file

@ -1,5 +1,26 @@
#pragma once #pragma once
#include "../../utils/types.h"
typedef struct _bmp_t
{
u16 magic;
u32 size;
u32 rsvd;
u32 data_off;
u32 hdr_size;
u32 width;
u32 height;
u16 planes;
u16 pxl_bits;
u32 comp;
u32 img_size;
u32 res_h;
u32 res_v;
u64 rsvd2;
} __attribute__((packed)) bmp_t;
int utils_mmcMenu(); int utils_mmcMenu();
void utils_copystring(const char *in, char **out); void utils_copystring(const char *in, char **out);
char *utils_InputText(char *start, int maxLen); char *utils_InputText(char *start, int maxLen);
void utils_takeScreenshot();