0.9.2 (NVID, SPLASH_IMG_VID, CHANGELOG_IMPL)
This commit is contained in:
parent
67edfa4245
commit
cd677cf3e8
4
.vscode/c_cpp_properties.json
vendored
4
.vscode/c_cpp_properties.json
vendored
@ -7,7 +7,9 @@
|
||||
"C:/devkitpro/libctru/include/**",
|
||||
"C:/devkitpro/devkitARM/include/**",
|
||||
"C:/devkitpro/devkitARM/arm-none-eabi/include/**",
|
||||
"C:/devkitpro/portlibs/3ds/include/**"
|
||||
"C:/devkitpro/portlibs/3ds/include/**",
|
||||
"/opt/devkitpro/libctru/include/**",
|
||||
"/opt/devkitpro/portlibs/**"
|
||||
|
||||
]
|
||||
}
|
||||
|
3185
external/source/jpgd.cpp
vendored
Normal file
3185
external/source/jpgd.cpp
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1246
external/source/jpge.cpp
vendored
Normal file
1246
external/source/jpge.cpp
vendored
Normal file
File diff suppressed because it is too large
Load Diff
@ -28,6 +28,7 @@ public:
|
||||
void LoadPFromBuffer(const std::vector<u8> &buffer);
|
||||
void LoadFromBitmap(BMP bitmap);
|
||||
void LoadJpg(std::string path);
|
||||
void LoadPixels(int w, int h, int bpp, void *buffer);
|
||||
/// Draw the Image directly
|
||||
/// \param x The x position
|
||||
/// \param y the y position
|
||||
|
422
include/renderd7/external/jpgd.h
vendored
Normal file
422
include/renderd7/external/jpgd.h
vendored
Normal file
@ -0,0 +1,422 @@
|
||||
// jpgd.h - C++ class for JPEG decompression.
|
||||
// Richard Geldreich <richgel99@gmail.com>
|
||||
// See jpgd.cpp for license (Public Domain or Apache 2.0).
|
||||
#ifndef JPEG_DECODER_H
|
||||
#define JPEG_DECODER_H
|
||||
|
||||
#include <assert.h>
|
||||
#include <cinttypes>
|
||||
#include <setjmp.h>
|
||||
#include <stdint.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#ifdef _MSC_VER
|
||||
#define JPGD_NORETURN __declspec(noreturn)
|
||||
#elif defined(__GNUC__)
|
||||
#define JPGD_NORETURN __attribute__((noreturn))
|
||||
#else
|
||||
#define JPGD_NORETURN
|
||||
#endif
|
||||
|
||||
#define JPGD_HUFF_TREE_MAX_LENGTH 512
|
||||
#define JPGD_HUFF_CODE_SIZE_MAX_LENGTH 256
|
||||
|
||||
namespace jpgd {
|
||||
typedef unsigned char uint8;
|
||||
typedef signed short int16;
|
||||
typedef unsigned short uint16;
|
||||
typedef unsigned int uint;
|
||||
typedef signed int int32;
|
||||
|
||||
// Loads a JPEG image from a memory buffer or a file.
|
||||
// req_comps can be 1 (grayscale), 3 (RGB), or 4 (RGBA).
|
||||
// On return, width/height will be set to the image's dimensions, and
|
||||
// actual_comps will be set to the either 1 (grayscale) or 3 (RGB). Notes: For
|
||||
// more control over where and how the source data is read, see the
|
||||
// decompress_jpeg_image_from_stream() function below, or call the jpeg_decoder
|
||||
// class directly. Requesting a 8 or 32bpp image is currently a little faster
|
||||
// than 24bpp because the jpeg_decoder class itself currently always unpacks to
|
||||
// either 8 or 32bpp.
|
||||
unsigned char *decompress_jpeg_image_from_memory(const unsigned char *pSrc_data,
|
||||
int src_data_size, int *width,
|
||||
int *height, int *actual_comps,
|
||||
int req_comps,
|
||||
uint32_t flags = 0);
|
||||
unsigned char *decompress_jpeg_image_from_file(const char *pSrc_filename,
|
||||
int *width, int *height,
|
||||
int *actual_comps, int req_comps,
|
||||
uint32_t flags = 0);
|
||||
|
||||
// Success/failure error codes.
|
||||
enum jpgd_status {
|
||||
JPGD_SUCCESS = 0,
|
||||
JPGD_FAILED = -1,
|
||||
JPGD_DONE = 1,
|
||||
JPGD_BAD_DHT_COUNTS = -256,
|
||||
JPGD_BAD_DHT_INDEX,
|
||||
JPGD_BAD_DHT_MARKER,
|
||||
JPGD_BAD_DQT_MARKER,
|
||||
JPGD_BAD_DQT_TABLE,
|
||||
JPGD_BAD_PRECISION,
|
||||
JPGD_BAD_HEIGHT,
|
||||
JPGD_BAD_WIDTH,
|
||||
JPGD_TOO_MANY_COMPONENTS,
|
||||
JPGD_BAD_SOF_LENGTH,
|
||||
JPGD_BAD_VARIABLE_MARKER,
|
||||
JPGD_BAD_DRI_LENGTH,
|
||||
JPGD_BAD_SOS_LENGTH,
|
||||
JPGD_BAD_SOS_COMP_ID,
|
||||
JPGD_W_EXTRA_BYTES_BEFORE_MARKER,
|
||||
JPGD_NO_ARITHMITIC_SUPPORT,
|
||||
JPGD_UNEXPECTED_MARKER,
|
||||
JPGD_NOT_JPEG,
|
||||
JPGD_UNSUPPORTED_MARKER,
|
||||
JPGD_BAD_DQT_LENGTH,
|
||||
JPGD_TOO_MANY_BLOCKS,
|
||||
JPGD_UNDEFINED_QUANT_TABLE,
|
||||
JPGD_UNDEFINED_HUFF_TABLE,
|
||||
JPGD_NOT_SINGLE_SCAN,
|
||||
JPGD_UNSUPPORTED_COLORSPACE,
|
||||
JPGD_UNSUPPORTED_SAMP_FACTORS,
|
||||
JPGD_DECODE_ERROR,
|
||||
JPGD_BAD_RESTART_MARKER,
|
||||
JPGD_BAD_SOS_SPECTRAL,
|
||||
JPGD_BAD_SOS_SUCCESSIVE,
|
||||
JPGD_STREAM_READ,
|
||||
JPGD_NOTENOUGHMEM,
|
||||
JPGD_TOO_MANY_SCANS
|
||||
};
|
||||
|
||||
// Input stream interface.
|
||||
// Derive from this class to read input data from sources other than files or
|
||||
// memory. Set m_eof_flag to true when no more data is available. The decoder is
|
||||
// rather greedy: it will keep on calling this method until its internal input
|
||||
// buffer is full, or until the EOF flag is set. It the input stream contains
|
||||
// data after the JPEG stream's EOI (end of image) marker it will probably be
|
||||
// pulled into the internal buffer. Call the get_total_bytes_read() method to
|
||||
// determine the actual size of the JPEG stream after successful decoding.
|
||||
class jpeg_decoder_stream {
|
||||
public:
|
||||
jpeg_decoder_stream() {}
|
||||
virtual ~jpeg_decoder_stream() {}
|
||||
|
||||
// The read() method is called when the internal input buffer is empty.
|
||||
// Parameters:
|
||||
// pBuf - input buffer
|
||||
// max_bytes_to_read - maximum bytes that can be written to pBuf
|
||||
// pEOF_flag - set this to true if at end of stream (no more bytes remaining)
|
||||
// Returns -1 on error, otherwise return the number of bytes actually written
|
||||
// to the buffer (which may be 0). Notes: This method will be called in a loop
|
||||
// until you set *pEOF_flag to true or the internal buffer is full.
|
||||
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag) = 0;
|
||||
};
|
||||
|
||||
// stdio FILE stream class.
|
||||
class jpeg_decoder_file_stream : public jpeg_decoder_stream {
|
||||
jpeg_decoder_file_stream(const jpeg_decoder_file_stream &);
|
||||
jpeg_decoder_file_stream &operator=(const jpeg_decoder_file_stream &);
|
||||
|
||||
FILE *m_pFile;
|
||||
bool m_eof_flag, m_error_flag;
|
||||
|
||||
public:
|
||||
jpeg_decoder_file_stream();
|
||||
virtual ~jpeg_decoder_file_stream();
|
||||
|
||||
bool open(const char *Pfilename);
|
||||
void close();
|
||||
|
||||
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag);
|
||||
};
|
||||
|
||||
// Memory stream class.
|
||||
class jpeg_decoder_mem_stream : public jpeg_decoder_stream {
|
||||
const uint8 *m_pSrc_data;
|
||||
uint m_ofs, m_size;
|
||||
|
||||
public:
|
||||
jpeg_decoder_mem_stream() : m_pSrc_data(NULL), m_ofs(0), m_size(0) {}
|
||||
jpeg_decoder_mem_stream(const uint8 *pSrc_data, uint size)
|
||||
: m_pSrc_data(pSrc_data), m_ofs(0), m_size(size) {}
|
||||
|
||||
virtual ~jpeg_decoder_mem_stream() {}
|
||||
|
||||
bool open(const uint8 *pSrc_data, uint size);
|
||||
void close() {
|
||||
m_pSrc_data = NULL;
|
||||
m_ofs = 0;
|
||||
m_size = 0;
|
||||
}
|
||||
|
||||
virtual int read(uint8 *pBuf, int max_bytes_to_read, bool *pEOF_flag);
|
||||
};
|
||||
|
||||
// Loads JPEG file from a jpeg_decoder_stream.
|
||||
unsigned char *decompress_jpeg_image_from_stream(jpeg_decoder_stream *pStream,
|
||||
int *width, int *height,
|
||||
int *actual_comps,
|
||||
int req_comps,
|
||||
uint32_t flags = 0);
|
||||
|
||||
enum {
|
||||
JPGD_IN_BUF_SIZE = 8192,
|
||||
JPGD_MAX_BLOCKS_PER_MCU = 10,
|
||||
JPGD_MAX_HUFF_TABLES = 8,
|
||||
JPGD_MAX_QUANT_TABLES = 4,
|
||||
JPGD_MAX_COMPONENTS = 4,
|
||||
JPGD_MAX_COMPS_IN_SCAN = 4,
|
||||
JPGD_MAX_BLOCKS_PER_ROW = 16384,
|
||||
JPGD_MAX_HEIGHT = 32768,
|
||||
JPGD_MAX_WIDTH = 32768
|
||||
};
|
||||
|
||||
typedef int16 jpgd_quant_t;
|
||||
typedef int16 jpgd_block_coeff_t;
|
||||
|
||||
class jpeg_decoder {
|
||||
public:
|
||||
enum { cFlagBoxChromaFiltering = 1, cFlagDisableSIMD = 2 };
|
||||
|
||||
// Call get_error_code() after constructing to determine if the stream is
|
||||
// valid or not. You may call the get_width(), get_height(), etc. methods
|
||||
// after the constructor is called. You may then either destruct the object,
|
||||
// or begin decoding the image by calling begin_decoding(), then decode() on
|
||||
// each scanline.
|
||||
jpeg_decoder(jpeg_decoder_stream *pStream, uint32_t flags = 0);
|
||||
|
||||
~jpeg_decoder();
|
||||
|
||||
// Call this method after constructing the object to begin decompression.
|
||||
// If JPGD_SUCCESS is returned you may then call decode() on each scanline.
|
||||
|
||||
int begin_decoding();
|
||||
|
||||
// Returns the next scan line.
|
||||
// For grayscale images, pScan_line will point to a buffer containing 8-bit
|
||||
// pixels (get_bytes_per_pixel() will return 1). Otherwise, it will always
|
||||
// point to a buffer containing 32-bit RGBA pixels (A will always be 255, and
|
||||
// get_bytes_per_pixel() will return 4). Returns JPGD_SUCCESS if a scan line
|
||||
// has been returned. Returns JPGD_DONE if all scan lines have been returned.
|
||||
// Returns JPGD_FAILED if an error occurred. Call get_error_code() for a more
|
||||
// info.
|
||||
int decode(const void **pScan_line, uint *pScan_line_len);
|
||||
|
||||
inline jpgd_status get_error_code() const { return m_error_code; }
|
||||
|
||||
inline int get_width() const { return m_image_x_size; }
|
||||
inline int get_height() const { return m_image_y_size; }
|
||||
|
||||
inline int get_num_components() const { return m_comps_in_frame; }
|
||||
|
||||
inline int get_bytes_per_pixel() const { return m_dest_bytes_per_pixel; }
|
||||
inline int get_bytes_per_scan_line() const {
|
||||
return m_image_x_size * get_bytes_per_pixel();
|
||||
}
|
||||
|
||||
// Returns the total number of bytes actually consumed by the decoder (which
|
||||
// should equal the actual size of the JPEG file).
|
||||
inline int get_total_bytes_read() const { return m_total_bytes_read; }
|
||||
|
||||
private:
|
||||
jpeg_decoder(const jpeg_decoder &);
|
||||
jpeg_decoder &operator=(const jpeg_decoder &);
|
||||
|
||||
typedef void (*pDecode_block_func)(jpeg_decoder *, int, int, int);
|
||||
|
||||
struct huff_tables {
|
||||
bool ac_table;
|
||||
uint look_up[256];
|
||||
uint look_up2[256];
|
||||
uint8 code_size[JPGD_HUFF_CODE_SIZE_MAX_LENGTH];
|
||||
uint tree[JPGD_HUFF_TREE_MAX_LENGTH];
|
||||
};
|
||||
|
||||
struct coeff_buf {
|
||||
uint8 *pData;
|
||||
int block_num_x, block_num_y;
|
||||
int block_len_x, block_len_y;
|
||||
int block_size;
|
||||
};
|
||||
|
||||
struct mem_block {
|
||||
mem_block *m_pNext;
|
||||
size_t m_used_count;
|
||||
size_t m_size;
|
||||
char m_data[1];
|
||||
};
|
||||
|
||||
jmp_buf m_jmp_state;
|
||||
uint32_t m_flags;
|
||||
mem_block *m_pMem_blocks;
|
||||
int m_image_x_size;
|
||||
int m_image_y_size;
|
||||
jpeg_decoder_stream *m_pStream;
|
||||
|
||||
int m_progressive_flag;
|
||||
|
||||
uint8 m_huff_ac[JPGD_MAX_HUFF_TABLES];
|
||||
uint8 *m_huff_num[JPGD_MAX_HUFF_TABLES]; // pointer to number of Huffman codes
|
||||
// per bit size
|
||||
uint8 *
|
||||
m_huff_val[JPGD_MAX_HUFF_TABLES]; // pointer to Huffman codes per bit size
|
||||
jpgd_quant_t
|
||||
*m_quant[JPGD_MAX_QUANT_TABLES]; // pointer to quantization tables
|
||||
int m_scan_type; // Gray, Yh1v1, Yh1v2, Yh2v1, Yh2v2 (CMYK111, CMYK4114 no
|
||||
// longer supported)
|
||||
int m_comps_in_frame; // # of components in frame
|
||||
int m_comp_h_samp[JPGD_MAX_COMPONENTS]; // component's horizontal sampling
|
||||
// factor
|
||||
int m_comp_v_samp[JPGD_MAX_COMPONENTS]; // component's vertical sampling
|
||||
// factor
|
||||
int m_comp_quant[JPGD_MAX_COMPONENTS]; // component's quantization table
|
||||
// selector
|
||||
int m_comp_ident[JPGD_MAX_COMPONENTS]; // component's ID
|
||||
int m_comp_h_blocks[JPGD_MAX_COMPONENTS];
|
||||
int m_comp_v_blocks[JPGD_MAX_COMPONENTS];
|
||||
int m_comps_in_scan; // # of components in scan
|
||||
int m_comp_list[JPGD_MAX_COMPS_IN_SCAN]; // components in this scan
|
||||
int m_comp_dc_tab[JPGD_MAX_COMPONENTS]; // component's DC Huffman coding table
|
||||
// selector
|
||||
int m_comp_ac_tab[JPGD_MAX_COMPONENTS]; // component's AC Huffman coding table
|
||||
// selector
|
||||
int m_spectral_start; // spectral selection start
|
||||
int m_spectral_end; // spectral selection end
|
||||
int m_successive_low; // successive approximation low
|
||||
int m_successive_high; // successive approximation high
|
||||
int m_max_mcu_x_size; // MCU's max. X size in pixels
|
||||
int m_max_mcu_y_size; // MCU's max. Y size in pixels
|
||||
int m_blocks_per_mcu;
|
||||
int m_max_blocks_per_row;
|
||||
int m_mcus_per_row, m_mcus_per_col;
|
||||
int m_mcu_org[JPGD_MAX_BLOCKS_PER_MCU];
|
||||
int m_total_lines_left; // total # lines left in image
|
||||
int m_mcu_lines_left; // total # lines left in this MCU
|
||||
int m_num_buffered_scanlines;
|
||||
int m_real_dest_bytes_per_scan_line;
|
||||
int m_dest_bytes_per_scan_line; // rounded up
|
||||
int m_dest_bytes_per_pixel; // 4 (RGB) or 1 (Y)
|
||||
huff_tables *m_pHuff_tabs[JPGD_MAX_HUFF_TABLES];
|
||||
coeff_buf *m_dc_coeffs[JPGD_MAX_COMPONENTS];
|
||||
coeff_buf *m_ac_coeffs[JPGD_MAX_COMPONENTS];
|
||||
int m_eob_run;
|
||||
int m_block_y_mcu[JPGD_MAX_COMPONENTS];
|
||||
uint8 *m_pIn_buf_ofs;
|
||||
int m_in_buf_left;
|
||||
int m_tem_flag;
|
||||
|
||||
uint8 m_in_buf_pad_start[64];
|
||||
uint8 m_in_buf[JPGD_IN_BUF_SIZE + 128];
|
||||
uint8 m_in_buf_pad_end[64];
|
||||
|
||||
int m_bits_left;
|
||||
uint m_bit_buf;
|
||||
int m_restart_interval;
|
||||
int m_restarts_left;
|
||||
int m_next_restart_num;
|
||||
int m_max_mcus_per_row;
|
||||
int m_max_blocks_per_mcu;
|
||||
|
||||
int m_max_mcus_per_col;
|
||||
uint m_last_dc_val[JPGD_MAX_COMPONENTS];
|
||||
jpgd_block_coeff_t *m_pMCU_coefficients;
|
||||
int m_mcu_block_max_zag[JPGD_MAX_BLOCKS_PER_MCU];
|
||||
uint8 *m_pSample_buf;
|
||||
uint8 *m_pSample_buf_prev;
|
||||
int m_crr[256];
|
||||
int m_cbb[256];
|
||||
int m_crg[256];
|
||||
int m_cbg[256];
|
||||
uint8 *m_pScan_line_0;
|
||||
uint8 *m_pScan_line_1;
|
||||
jpgd_status m_error_code;
|
||||
int m_total_bytes_read;
|
||||
|
||||
bool m_ready_flag;
|
||||
bool m_eof_flag;
|
||||
bool m_sample_buf_prev_valid;
|
||||
bool m_has_sse2;
|
||||
|
||||
inline int check_sample_buf_ofs(int ofs) const {
|
||||
assert(ofs >= 0);
|
||||
assert(ofs < m_max_blocks_per_row * 64);
|
||||
return ofs;
|
||||
}
|
||||
void free_all_blocks();
|
||||
JPGD_NORETURN void stop_decoding(jpgd_status status);
|
||||
void *alloc(size_t n, bool zero = false);
|
||||
void *alloc_aligned(size_t nSize, uint32_t align = 16, bool zero = false);
|
||||
void word_clear(void *p, uint16 c, uint n);
|
||||
void prep_in_buffer();
|
||||
void read_dht_marker();
|
||||
void read_dqt_marker();
|
||||
void read_sof_marker();
|
||||
void skip_variable_marker();
|
||||
void read_dri_marker();
|
||||
void read_sos_marker();
|
||||
int next_marker();
|
||||
int process_markers();
|
||||
void locate_soi_marker();
|
||||
void locate_sof_marker();
|
||||
int locate_sos_marker();
|
||||
void init(jpeg_decoder_stream *pStream, uint32_t flags);
|
||||
void create_look_ups();
|
||||
void fix_in_buffer();
|
||||
void transform_mcu(int mcu_row);
|
||||
coeff_buf *coeff_buf_open(int block_num_x, int block_num_y, int block_len_x,
|
||||
int block_len_y);
|
||||
inline jpgd_block_coeff_t *coeff_buf_getp(coeff_buf *cb, int block_x,
|
||||
int block_y);
|
||||
void load_next_row();
|
||||
void decode_next_row();
|
||||
void make_huff_table(int index, huff_tables *pH);
|
||||
void check_quant_tables();
|
||||
void check_huff_tables();
|
||||
bool calc_mcu_block_order();
|
||||
int init_scan();
|
||||
void init_frame();
|
||||
void process_restart();
|
||||
void decode_scan(pDecode_block_func decode_block_func);
|
||||
void init_progressive();
|
||||
void init_sequential();
|
||||
void decode_start();
|
||||
void decode_init(jpeg_decoder_stream *pStream, uint32_t flags);
|
||||
void H2V2Convert();
|
||||
uint32_t H2V2ConvertFiltered();
|
||||
void H2V1Convert();
|
||||
void H2V1ConvertFiltered();
|
||||
void H1V2Convert();
|
||||
void H1V2ConvertFiltered();
|
||||
void H1V1Convert();
|
||||
void gray_convert();
|
||||
void find_eoi();
|
||||
inline uint get_char();
|
||||
inline uint get_char(bool *pPadding_flag);
|
||||
inline void stuff_char(uint8 q);
|
||||
inline uint8 get_octet();
|
||||
inline uint get_bits(int num_bits);
|
||||
inline uint get_bits_no_markers(int numbits);
|
||||
inline int huff_decode(huff_tables *pH);
|
||||
inline int huff_decode(huff_tables *pH, int &extrabits);
|
||||
|
||||
// Clamps a value between 0-255.
|
||||
static inline uint8 clamp(int i) {
|
||||
if (static_cast<uint>(i) > 255)
|
||||
i = (((~i) >> 31) & 0xFF);
|
||||
return static_cast<uint8>(i);
|
||||
}
|
||||
int decode_next_mcu_row();
|
||||
|
||||
static void decode_block_dc_first(jpeg_decoder *pD, int component_id,
|
||||
int block_x, int block_y);
|
||||
static void decode_block_dc_refine(jpeg_decoder *pD, int component_id,
|
||||
int block_x, int block_y);
|
||||
static void decode_block_ac_first(jpeg_decoder *pD, int component_id,
|
||||
int block_x, int block_y);
|
||||
static void decode_block_ac_refine(jpeg_decoder *pD, int component_id,
|
||||
int block_x, int block_y);
|
||||
};
|
||||
|
||||
} // namespace jpgd
|
||||
|
||||
#endif // JPEG_DECODER_H
|
478
include/renderd7/external/jpgd_idct.h
vendored
Normal file
478
include/renderd7/external/jpgd_idct.h
vendored
Normal file
@ -0,0 +1,478 @@
|
||||
// Copyright 2009 Intel Corporation
|
||||
// All Rights Reserved
|
||||
//
|
||||
// Permission is granted to use, copy, distribute and prepare derivative works
|
||||
// of this software for any purpose and without fee, provided, that the above
|
||||
// copyright notice and this statement appear in all copies. Intel makes no
|
||||
// representations about the suitability of this software for any purpose. THIS
|
||||
// SOFTWARE IS PROVIDED "AS IS." INTEL SPECIFICALLY DISCLAIMS ALL WARRANTIES,
|
||||
// EXPRESS OR IMPLIED, AND ALL LIABILITY, INCLUDING CONSEQUENTIAL AND OTHER
|
||||
// INDIRECT DAMAGES, FOR THE USE OF THIS SOFTWARE, INCLUDING LIABILITY FOR
|
||||
// INFRINGEMENT OF ANY PROPRIETARY RIGHTS, AND INCLUDING THE WARRANTIES OF
|
||||
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Intel does not assume
|
||||
// any responsibility for any errors which may appear in this software nor any
|
||||
// responsibility to update it.
|
||||
//
|
||||
// From:
|
||||
// https://software.intel.com/sites/default/files/m/d/4/1/d/8/UsingIntelAVXToImplementIDCT-r1_5.pdf
|
||||
// https://software.intel.com/file/29048
|
||||
//
|
||||
// Requires SSE
|
||||
//
|
||||
#ifdef _MSC_VER
|
||||
#include <intrin.h>
|
||||
#endif
|
||||
#include <immintrin.h>
|
||||
|
||||
#ifdef _MSC_VER
|
||||
#define JPGD_SIMD_ALIGN(type, name) __declspec(align(16)) type name
|
||||
#else
|
||||
#define JPGD_SIMD_ALIGN(type, name) type name __attribute__((aligned(16)))
|
||||
#endif
|
||||
|
||||
#include <cinttypes>
|
||||
|
||||
#define BITS_INV_ACC 4
|
||||
#define SHIFT_INV_ROW 16 - BITS_INV_ACC
|
||||
#define SHIFT_INV_COL 1 + BITS_INV_ACC
|
||||
const short IRND_INV_ROW = 1024 * (6 - BITS_INV_ACC); // 1 << (SHIFT_INV_ROW-1)
|
||||
const short IRND_INV_COL = 16 * (BITS_INV_ACC - 3); // 1 << (SHIFT_INV_COL-1)
|
||||
const short IRND_INV_CORR = IRND_INV_COL - 1; // correction -1.0 and round
|
||||
|
||||
JPGD_SIMD_ALIGN(short, shortM128_one_corr[8]) = {1, 1, 1, 1, 1, 1, 1, 1};
|
||||
JPGD_SIMD_ALIGN(short, shortM128_round_inv_row[8]) = {
|
||||
IRND_INV_ROW, 0, IRND_INV_ROW, 0, IRND_INV_ROW, 0, IRND_INV_ROW, 0};
|
||||
JPGD_SIMD_ALIGN(short, shortM128_round_inv_col[8]) = {
|
||||
IRND_INV_COL, IRND_INV_COL, IRND_INV_COL, IRND_INV_COL,
|
||||
IRND_INV_COL, IRND_INV_COL, IRND_INV_COL, IRND_INV_COL};
|
||||
JPGD_SIMD_ALIGN(short, shortM128_round_inv_corr[8]) = {
|
||||
IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR,
|
||||
IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR, IRND_INV_CORR};
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tg_1_16[8]) = {
|
||||
13036, 13036, 13036, 13036,
|
||||
13036, 13036, 13036, 13036}; // tg * (2<<16) + 0.5
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tg_2_16[8]) = {
|
||||
27146, 27146, 27146, 27146,
|
||||
27146, 27146, 27146, 27146}; // tg * (2<<16) + 0.5
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tg_3_16[8]) = {
|
||||
-21746, -21746, -21746, -21746,
|
||||
-21746, -21746, -21746, -21746}; // tg * (2<<16) + 0.5
|
||||
JPGD_SIMD_ALIGN(short, shortM128_cos_4_16[8]) = {
|
||||
-19195, -19195, -19195, -19195,
|
||||
-19195, -19195, -19195, -19195}; // cos * (2<<16) + 0.5
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Table for rows 0,4 - constants are multiplied on cos_4_16
|
||||
// w15 w14 w11 w10 w07 w06 w03 w02
|
||||
// w29 w28 w25 w24 w21 w20 w17 w16
|
||||
// w31 w30 w27 w26 w23 w22 w19 w18
|
||||
// movq -> w05 w04 w01 w00
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tab_i_04[]) = {
|
||||
16384, 21407, 16384, 8867,
|
||||
16384, -8867, 16384, -21407, // w13 w12 w09 w08
|
||||
16384, 8867, -16384, -21407, // w07 w06 w03 w02
|
||||
-16384, 21407, 16384, -8867, // w15 w14 w11 w10
|
||||
22725, 19266, 19266, -4520, // w21 w20 w17 w16
|
||||
12873, -22725, 4520, -12873, // w29 w28 w25 w24
|
||||
12873, 4520, -22725, -12873, // w23 w22 w19 w18
|
||||
4520, 19266, 19266, -22725}; // w31 w30 w27 w26
|
||||
|
||||
// Table for rows 1,7 - constants are multiplied on cos_1_16
|
||||
// movq -> w05 w04 w01 w00
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tab_i_17[]) = {
|
||||
22725, 29692, 22725, 12299,
|
||||
22725, -12299, 22725, -29692, // w13 w12 w09 w08
|
||||
22725, 12299, -22725, -29692, // w07 w06 w03 w02
|
||||
-22725, 29692, 22725, -12299, // w15 w14 w11 w10
|
||||
31521, 26722, 26722, -6270, // w21 w20 w17 w16
|
||||
17855, -31521, 6270, -17855, // w29 w28 w25 w24
|
||||
17855, 6270, -31521, -17855, // w23 w22 w19 w18
|
||||
6270, 26722, 26722, -31521}; // w31 w30 w27 w26
|
||||
|
||||
// Table for rows 2,6 - constants are multiplied on cos_2_16
|
||||
// movq -> w05 w04 w01 w00
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tab_i_26[]) = {
|
||||
21407, 27969, 21407, 11585,
|
||||
21407, -11585, 21407, -27969, // w13 w12 w09 w08
|
||||
21407, 11585, -21407, -27969, // w07 w06 w03 w02
|
||||
-21407, 27969, 21407, -11585, // w15 w14 w11 w10
|
||||
29692, 25172, 25172, -5906, // w21 w20 w17 w16
|
||||
16819, -29692, 5906, -16819, // w29 w28 w25 w24
|
||||
16819, 5906, -29692, -16819, // w23 w22 w19 w18
|
||||
5906, 25172, 25172, -29692}; // w31 w30 w27 w26
|
||||
// Table for rows 3,5 - constants are multiplied on cos_3_16
|
||||
// movq -> w05 w04 w01 w00
|
||||
JPGD_SIMD_ALIGN(short, shortM128_tab_i_35[]) = {
|
||||
19266, 25172, 19266, 10426,
|
||||
19266, -10426, 19266, -25172, // w13 w12 w09 w08
|
||||
19266, 10426, -19266, -25172, // w07 w06 w03 w02
|
||||
-19266, 25172, 19266, -10426, // w15 w14 w11 w10
|
||||
26722, 22654, 22654, -5315, // w21 w20 w17 w16
|
||||
15137, -26722, 5315, -15137, // w29 w28 w25 w24
|
||||
15137, 5315, -26722, -15137, // w23 w22 w19 w18
|
||||
5315, 22654, 22654, -26722}; // w31 w30 w27 w26
|
||||
|
||||
JPGD_SIMD_ALIGN(short, shortM128_128[8]) = {128, 128, 128, 128,
|
||||
128, 128, 128, 128};
|
||||
|
||||
void idctSSEShortU8(const short *pInput, uint8_t *pOutputUB) {
|
||||
__m128i r_xmm0, r_xmm4;
|
||||
__m128i r_xmm1, r_xmm2, r_xmm3, r_xmm5, r_xmm6, r_xmm7;
|
||||
__m128i row0, row1, row2, row3, row4, row5, row6, row7;
|
||||
short *pTab_i_04 = shortM128_tab_i_04;
|
||||
short *pTab_i_26 = shortM128_tab_i_26;
|
||||
|
||||
// Get pointers for this input and output
|
||||
pTab_i_04 = shortM128_tab_i_04;
|
||||
pTab_i_26 = shortM128_tab_i_26;
|
||||
|
||||
// Row 1 and Row 3
|
||||
r_xmm0 = _mm_load_si128((__m128i *)pInput);
|
||||
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[2 * 8]));
|
||||
|
||||
// *** Work on the data in xmm0
|
||||
// low shuffle mask = 0xd8 = 11 01 10 00
|
||||
// get short 2 and short 0 into ls 32-bits
|
||||
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
|
||||
|
||||
// copy short 2 and short 0 to all locations
|
||||
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
|
||||
|
||||
// add to those copies
|
||||
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
|
||||
|
||||
// shuffle mask = 0x55 = 01 01 01 01
|
||||
// copy short 3 and short 1 to all locations
|
||||
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
|
||||
|
||||
// high shuffle mask = 0xd8 = 11 01 10 00
|
||||
// get short 6 and short 4 into bit positions 64-95
|
||||
// get short 7 and short 5 into bit positions 96-127
|
||||
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
|
||||
|
||||
// add to short 3 and short 1
|
||||
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
|
||||
|
||||
// shuffle mask = 0xaa = 10 10 10 10
|
||||
// copy short 6 and short 4 to all locations
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
|
||||
|
||||
// shuffle mask = 0xaa = 11 11 11 11
|
||||
// copy short 7 and short 5 to all locations
|
||||
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
|
||||
|
||||
// add to short 6 and short 4
|
||||
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
|
||||
|
||||
// *** Work on the data in xmm4
|
||||
// high shuffle mask = 0xd8 11 01 10 00
|
||||
// get short 6 and short 4 into bit positions 64-95
|
||||
// get short 7 and short 5 into bit positions 96-127
|
||||
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
|
||||
|
||||
// (xmm0 short 2 and short 0 plus pSi) + some constants
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
|
||||
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
|
||||
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
|
||||
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&shortM128_tab_i_26[0]));
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
|
||||
r_xmm2 = r_xmm1;
|
||||
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
|
||||
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&shortM128_tab_i_26[8]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
|
||||
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
|
||||
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
|
||||
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&shortM128_tab_i_26[16]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
|
||||
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&shortM128_tab_i_26[24]));
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
|
||||
r_xmm6 = r_xmm5;
|
||||
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
|
||||
row0 = _mm_packs_epi32(r_xmm0, r_xmm2);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
|
||||
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
|
||||
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
|
||||
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
|
||||
row2 = _mm_packs_epi32(r_xmm4, r_xmm6);
|
||||
|
||||
// Row 5 and row 7
|
||||
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[4 * 8]));
|
||||
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[6 * 8]));
|
||||
|
||||
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
|
||||
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
|
||||
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
|
||||
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
|
||||
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
|
||||
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
|
||||
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
|
||||
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
|
||||
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
|
||||
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
|
||||
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
|
||||
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&shortM128_tab_i_26[0]));
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
|
||||
r_xmm2 = r_xmm1;
|
||||
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
|
||||
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&shortM128_tab_i_26[8]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
|
||||
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
|
||||
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
|
||||
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&shortM128_tab_i_26[16]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
|
||||
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&shortM128_tab_i_26[24]));
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
|
||||
r_xmm6 = r_xmm5;
|
||||
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
|
||||
row4 = _mm_packs_epi32(r_xmm0, r_xmm2);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
|
||||
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
|
||||
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
|
||||
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
|
||||
row6 = _mm_packs_epi32(r_xmm4, r_xmm6);
|
||||
|
||||
// Row 4 and row 2
|
||||
pTab_i_04 = shortM128_tab_i_35;
|
||||
pTab_i_26 = shortM128_tab_i_17;
|
||||
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[3 * 8]));
|
||||
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[1 * 8]));
|
||||
|
||||
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
|
||||
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
|
||||
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
|
||||
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
|
||||
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
|
||||
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
|
||||
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
|
||||
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
|
||||
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
|
||||
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
|
||||
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
|
||||
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&pTab_i_26[0]));
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
|
||||
r_xmm2 = r_xmm1;
|
||||
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
|
||||
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&pTab_i_26[8]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
|
||||
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
|
||||
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
|
||||
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&pTab_i_26[16]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
|
||||
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&pTab_i_26[24]));
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
|
||||
r_xmm6 = r_xmm5;
|
||||
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
|
||||
row3 = _mm_packs_epi32(r_xmm0, r_xmm2);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
|
||||
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
|
||||
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
|
||||
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
|
||||
row1 = _mm_packs_epi32(r_xmm4, r_xmm6);
|
||||
|
||||
// Row 6 and row 8
|
||||
r_xmm0 = _mm_load_si128((__m128i *)(&pInput[5 * 8]));
|
||||
r_xmm4 = _mm_load_si128((__m128i *)(&pInput[7 * 8]));
|
||||
|
||||
r_xmm0 = _mm_shufflelo_epi16(r_xmm0, 0xd8);
|
||||
r_xmm1 = _mm_shuffle_epi32(r_xmm0, 0);
|
||||
r_xmm1 = _mm_madd_epi16(r_xmm1, *((__m128i *)pTab_i_04));
|
||||
r_xmm3 = _mm_shuffle_epi32(r_xmm0, 0x55);
|
||||
r_xmm0 = _mm_shufflehi_epi16(r_xmm0, 0xd8);
|
||||
r_xmm3 = _mm_madd_epi16(r_xmm3, *((__m128i *)&pTab_i_04[16]));
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm0, 0xaa);
|
||||
r_xmm0 = _mm_shuffle_epi32(r_xmm0, 0xff);
|
||||
r_xmm2 = _mm_madd_epi16(r_xmm2, *((__m128i *)&pTab_i_04[8]));
|
||||
r_xmm4 = _mm_shufflehi_epi16(r_xmm4, 0xd8);
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_shufflelo_epi16(r_xmm4, 0xd8);
|
||||
r_xmm0 = _mm_madd_epi16(r_xmm0, *((__m128i *)&pTab_i_04[24]));
|
||||
r_xmm5 = _mm_shuffle_epi32(r_xmm4, 0);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm4, 0xaa);
|
||||
r_xmm5 = _mm_madd_epi16(r_xmm5, *((__m128i *)&pTab_i_26[0]));
|
||||
r_xmm1 = _mm_add_epi32(r_xmm1, r_xmm2);
|
||||
r_xmm2 = r_xmm1;
|
||||
r_xmm7 = _mm_shuffle_epi32(r_xmm4, 0x55);
|
||||
r_xmm6 = _mm_madd_epi16(r_xmm6, *((__m128i *)&pTab_i_26[8]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm3);
|
||||
r_xmm4 = _mm_shuffle_epi32(r_xmm4, 0xff);
|
||||
r_xmm2 = _mm_sub_epi32(r_xmm2, r_xmm0);
|
||||
r_xmm7 = _mm_madd_epi16(r_xmm7, *((__m128i *)&pTab_i_26[16]));
|
||||
r_xmm0 = _mm_add_epi32(r_xmm0, r_xmm1);
|
||||
r_xmm2 = _mm_srai_epi32(r_xmm2, 12);
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, *((__m128i *)shortM128_round_inv_row));
|
||||
r_xmm4 = _mm_madd_epi16(r_xmm4, *((__m128i *)&pTab_i_26[24]));
|
||||
r_xmm5 = _mm_add_epi32(r_xmm5, r_xmm6);
|
||||
r_xmm6 = r_xmm5;
|
||||
r_xmm0 = _mm_srai_epi32(r_xmm0, 12);
|
||||
r_xmm2 = _mm_shuffle_epi32(r_xmm2, 0x1b);
|
||||
row5 = _mm_packs_epi32(r_xmm0, r_xmm2);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm7);
|
||||
r_xmm6 = _mm_sub_epi32(r_xmm6, r_xmm4);
|
||||
r_xmm4 = _mm_add_epi32(r_xmm4, r_xmm5);
|
||||
r_xmm6 = _mm_srai_epi32(r_xmm6, 12);
|
||||
r_xmm4 = _mm_srai_epi32(r_xmm4, 12);
|
||||
r_xmm6 = _mm_shuffle_epi32(r_xmm6, 0x1b);
|
||||
row7 = _mm_packs_epi32(r_xmm4, r_xmm6);
|
||||
|
||||
r_xmm1 = _mm_load_si128((__m128i *)shortM128_tg_3_16);
|
||||
r_xmm2 = row5;
|
||||
r_xmm3 = row3;
|
||||
r_xmm0 = _mm_mulhi_epi16(row5, r_xmm1);
|
||||
|
||||
r_xmm1 = _mm_mulhi_epi16(r_xmm1, r_xmm3);
|
||||
r_xmm5 = _mm_load_si128((__m128i *)shortM128_tg_1_16);
|
||||
r_xmm6 = row7;
|
||||
r_xmm4 = _mm_mulhi_epi16(row7, r_xmm5);
|
||||
|
||||
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm2);
|
||||
r_xmm5 = _mm_mulhi_epi16(r_xmm5, row1);
|
||||
r_xmm1 = _mm_adds_epi16(r_xmm1, r_xmm3);
|
||||
r_xmm7 = row6;
|
||||
|
||||
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm3);
|
||||
r_xmm3 = _mm_load_si128((__m128i *)shortM128_tg_2_16);
|
||||
r_xmm2 = _mm_subs_epi16(r_xmm2, r_xmm1);
|
||||
r_xmm7 = _mm_mulhi_epi16(r_xmm7, r_xmm3);
|
||||
r_xmm1 = r_xmm0;
|
||||
r_xmm3 = _mm_mulhi_epi16(r_xmm3, row2);
|
||||
r_xmm5 = _mm_subs_epi16(r_xmm5, r_xmm6);
|
||||
r_xmm4 = _mm_adds_epi16(r_xmm4, row1);
|
||||
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm4);
|
||||
r_xmm0 = _mm_adds_epi16(r_xmm0, *((__m128i *)shortM128_one_corr));
|
||||
r_xmm4 = _mm_subs_epi16(r_xmm4, r_xmm1);
|
||||
r_xmm6 = r_xmm5;
|
||||
r_xmm5 = _mm_subs_epi16(r_xmm5, r_xmm2);
|
||||
r_xmm5 = _mm_adds_epi16(r_xmm5, *((__m128i *)shortM128_one_corr));
|
||||
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm2);
|
||||
|
||||
// Intermediate results, needed later
|
||||
__m128i temp3, temp7;
|
||||
temp7 = r_xmm0;
|
||||
|
||||
r_xmm1 = r_xmm4;
|
||||
r_xmm0 = _mm_load_si128((__m128i *)shortM128_cos_4_16);
|
||||
r_xmm4 = _mm_adds_epi16(r_xmm4, r_xmm5);
|
||||
r_xmm2 = _mm_load_si128((__m128i *)shortM128_cos_4_16);
|
||||
r_xmm2 = _mm_mulhi_epi16(r_xmm2, r_xmm4);
|
||||
|
||||
// Intermediate results, needed later
|
||||
temp3 = r_xmm6;
|
||||
|
||||
r_xmm1 = _mm_subs_epi16(r_xmm1, r_xmm5);
|
||||
r_xmm7 = _mm_adds_epi16(r_xmm7, row2);
|
||||
r_xmm3 = _mm_subs_epi16(r_xmm3, row6);
|
||||
r_xmm6 = row0;
|
||||
r_xmm0 = _mm_mulhi_epi16(r_xmm0, r_xmm1);
|
||||
r_xmm5 = row4;
|
||||
r_xmm5 = _mm_adds_epi16(r_xmm5, r_xmm6);
|
||||
r_xmm6 = _mm_subs_epi16(r_xmm6, row4);
|
||||
r_xmm4 = _mm_adds_epi16(r_xmm4, r_xmm2);
|
||||
|
||||
r_xmm4 = _mm_or_si128(r_xmm4, *((__m128i *)shortM128_one_corr));
|
||||
r_xmm0 = _mm_adds_epi16(r_xmm0, r_xmm1);
|
||||
r_xmm0 = _mm_or_si128(r_xmm0, *((__m128i *)shortM128_one_corr));
|
||||
|
||||
r_xmm2 = r_xmm5;
|
||||
r_xmm5 = _mm_adds_epi16(r_xmm5, r_xmm7);
|
||||
r_xmm1 = r_xmm6;
|
||||
r_xmm5 = _mm_adds_epi16(r_xmm5, *((__m128i *)shortM128_round_inv_col));
|
||||
r_xmm2 = _mm_subs_epi16(r_xmm2, r_xmm7);
|
||||
r_xmm7 = temp7;
|
||||
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm3);
|
||||
r_xmm6 = _mm_adds_epi16(r_xmm6, *((__m128i *)shortM128_round_inv_col));
|
||||
r_xmm7 = _mm_adds_epi16(r_xmm7, r_xmm5);
|
||||
r_xmm7 = _mm_srai_epi16(r_xmm7, SHIFT_INV_COL);
|
||||
r_xmm1 = _mm_subs_epi16(r_xmm1, r_xmm3);
|
||||
r_xmm1 = _mm_adds_epi16(r_xmm1, *((__m128i *)shortM128_round_inv_corr));
|
||||
r_xmm3 = r_xmm6;
|
||||
r_xmm2 = _mm_adds_epi16(r_xmm2, *((__m128i *)shortM128_round_inv_corr));
|
||||
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm4);
|
||||
|
||||
// Store results for row 0
|
||||
//_mm_store_si128((__m128i *) pOutput, r_xmm7);
|
||||
__m128i r0 = r_xmm7;
|
||||
|
||||
r_xmm6 = _mm_srai_epi16(r_xmm6, SHIFT_INV_COL);
|
||||
r_xmm7 = r_xmm1;
|
||||
r_xmm1 = _mm_adds_epi16(r_xmm1, r_xmm0);
|
||||
|
||||
// Store results for row 1
|
||||
//_mm_store_si128((__m128i *) (&pOutput[1*8]), r_xmm6);
|
||||
__m128i r1 = r_xmm6;
|
||||
|
||||
r_xmm1 = _mm_srai_epi16(r_xmm1, SHIFT_INV_COL);
|
||||
r_xmm6 = temp3;
|
||||
r_xmm7 = _mm_subs_epi16(r_xmm7, r_xmm0);
|
||||
r_xmm7 = _mm_srai_epi16(r_xmm7, SHIFT_INV_COL);
|
||||
|
||||
// Store results for row 2
|
||||
//_mm_store_si128((__m128i *) (&pOutput[2*8]), r_xmm1);
|
||||
__m128i r2 = r_xmm1;
|
||||
|
||||
r_xmm5 = _mm_subs_epi16(r_xmm5, temp7);
|
||||
r_xmm5 = _mm_srai_epi16(r_xmm5, SHIFT_INV_COL);
|
||||
|
||||
// Store results for row 7
|
||||
//_mm_store_si128((__m128i *) (&pOutput[7*8]), r_xmm5);
|
||||
__m128i r7 = r_xmm5;
|
||||
|
||||
r_xmm3 = _mm_subs_epi16(r_xmm3, r_xmm4);
|
||||
r_xmm6 = _mm_adds_epi16(r_xmm6, r_xmm2);
|
||||
r_xmm2 = _mm_subs_epi16(r_xmm2, temp3);
|
||||
r_xmm6 = _mm_srai_epi16(r_xmm6, SHIFT_INV_COL);
|
||||
r_xmm2 = _mm_srai_epi16(r_xmm2, SHIFT_INV_COL);
|
||||
|
||||
// Store results for row 3
|
||||
//_mm_store_si128((__m128i *) (&pOutput[3*8]), r_xmm6);
|
||||
__m128i r3 = r_xmm6;
|
||||
|
||||
r_xmm3 = _mm_srai_epi16(r_xmm3, SHIFT_INV_COL);
|
||||
|
||||
// Store results for rows 4, 5, and 6
|
||||
//_mm_store_si128((__m128i *) (&pOutput[4*8]), r_xmm2);
|
||||
//_mm_store_si128((__m128i *) (&pOutput[5*8]), r_xmm7);
|
||||
//_mm_store_si128((__m128i *) (&pOutput[6*8]), r_xmm3);
|
||||
|
||||
__m128i r4 = r_xmm2;
|
||||
__m128i r5 = r_xmm7;
|
||||
__m128i r6 = r_xmm3;
|
||||
|
||||
r0 = _mm_add_epi16(*(const __m128i *)shortM128_128, r0);
|
||||
r1 = _mm_add_epi16(*(const __m128i *)shortM128_128, r1);
|
||||
r2 = _mm_add_epi16(*(const __m128i *)shortM128_128, r2);
|
||||
r3 = _mm_add_epi16(*(const __m128i *)shortM128_128, r3);
|
||||
r4 = _mm_add_epi16(*(const __m128i *)shortM128_128, r4);
|
||||
r5 = _mm_add_epi16(*(const __m128i *)shortM128_128, r5);
|
||||
r6 = _mm_add_epi16(*(const __m128i *)shortM128_128, r6);
|
||||
r7 = _mm_add_epi16(*(const __m128i *)shortM128_128, r7);
|
||||
|
||||
((__m128i *)pOutputUB)[0] = _mm_packus_epi16(r0, r1);
|
||||
((__m128i *)pOutputUB)[1] = _mm_packus_epi16(r2, r3);
|
||||
((__m128i *)pOutputUB)[2] = _mm_packus_epi16(r4, r5);
|
||||
((__m128i *)pOutputUB)[3] = _mm_packus_epi16(r6, r7);
|
||||
}
|
186
include/renderd7/external/jpge.h
vendored
Normal file
186
include/renderd7/external/jpge.h
vendored
Normal file
@ -0,0 +1,186 @@
|
||||
// jpge.h - C++ class for JPEG compression.
|
||||
// Public Domain or Apache 2.0, Richard Geldreich <richgel99@gmail.com>
|
||||
// Alex Evans: Added RGBA support, linear memory allocator.
|
||||
#ifndef JPEG_ENCODER_H
|
||||
#define JPEG_ENCODER_H
|
||||
|
||||
namespace jpge {
|
||||
typedef unsigned char uint8;
|
||||
typedef signed short int16;
|
||||
typedef signed int int32;
|
||||
typedef unsigned short uint16;
|
||||
typedef unsigned int uint32;
|
||||
typedef unsigned int uint;
|
||||
|
||||
// JPEG chroma subsampling factors. Y_ONLY (grayscale images) and H2V2 (color
|
||||
// images) are the most common.
|
||||
enum subsampling_t { Y_ONLY = 0, H1V1 = 1, H2V1 = 2, H2V2 = 3 };
|
||||
|
||||
// JPEG compression parameters structure.
|
||||
struct params {
|
||||
inline params()
|
||||
: m_quality(85), m_subsampling(H2V2), m_no_chroma_discrim_flag(false),
|
||||
m_two_pass_flag(false), m_use_std_tables(false) {}
|
||||
|
||||
inline bool check() const {
|
||||
if ((m_quality < 1) || (m_quality > 100))
|
||||
return false;
|
||||
if ((uint)m_subsampling > (uint)H2V2)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
// Quality: 1-100, higher is better. Typical values are around 50-95.
|
||||
int m_quality;
|
||||
|
||||
// m_subsampling:
|
||||
// 0 = Y (grayscale) only
|
||||
// 1 = YCbCr, no subsampling (H1V1, YCbCr 1x1x1, 3 blocks per MCU)
|
||||
// 2 = YCbCr, H2V1 subsampling (YCbCr 2x1x1, 4 blocks per MCU)
|
||||
// 3 = YCbCr, H2V2 subsampling (YCbCr 4x1x1, 6 blocks per MCU-- very common)
|
||||
subsampling_t m_subsampling;
|
||||
|
||||
// Disables CbCr discrimination - only intended for testing.
|
||||
// If true, the Y quantization table is also used for the CbCr channels.
|
||||
bool m_no_chroma_discrim_flag;
|
||||
|
||||
bool m_two_pass_flag;
|
||||
|
||||
// By default we use the same quantization tables as mozjpeg's default.
|
||||
// Set to true to use the traditional tables from JPEG Annex K.
|
||||
bool m_use_std_tables;
|
||||
};
|
||||
|
||||
// Writes JPEG image to a file.
|
||||
// num_channels must be 1 (Y) or 3 (RGB), image pitch must be
|
||||
// width*num_channels.
|
||||
bool compress_image_to_jpeg_file(const char *pFilename, int width, int height,
|
||||
int num_channels, const uint8 *pImage_data,
|
||||
const params &comp_params = params());
|
||||
|
||||
// Writes JPEG image to memory buffer.
|
||||
// On entry, buf_size is the size of the output buffer pointed at by pBuf, which
|
||||
// should be at least ~1024 bytes. If return value is true, buf_size will be set
|
||||
// to the size of the compressed data.
|
||||
bool compress_image_to_jpeg_file_in_memory(
|
||||
void *pBuf, int &buf_size, int width, int height, int num_channels,
|
||||
const uint8 *pImage_data, const params &comp_params = params());
|
||||
|
||||
// Output stream abstract class - used by the jpeg_encoder class to write to the
|
||||
// output stream. put_buf() is generally called with len==JPGE_OUT_BUF_SIZE
|
||||
// bytes, but for headers it'll be called with smaller amounts.
|
||||
class output_stream {
|
||||
public:
|
||||
virtual ~output_stream(){};
|
||||
virtual bool put_buf(const void *Pbuf, int len) = 0;
|
||||
template <class T> inline bool put_obj(const T &obj) {
|
||||
return put_buf(&obj, sizeof(T));
|
||||
}
|
||||
};
|
||||
|
||||
// Lower level jpeg_encoder class - useful if more control is needed than the
|
||||
// above helper functions.
|
||||
class jpeg_encoder {
|
||||
public:
|
||||
jpeg_encoder();
|
||||
~jpeg_encoder();
|
||||
|
||||
// Initializes the compressor.
|
||||
// pStream: The stream object to use for writing compressed data.
|
||||
// params - Compression parameters structure, defined above.
|
||||
// width, height - Image dimensions.
|
||||
// channels - May be 1, or 3. 1 indicates grayscale, 3 indicates RGB source
|
||||
// data. Returns false on out of memory or if a stream write fails.
|
||||
bool init(output_stream *pStream, int width, int height, int src_channels,
|
||||
const params &comp_params = params());
|
||||
|
||||
const params &get_params() const { return m_params; }
|
||||
|
||||
// Deinitializes the compressor, freeing any allocated memory. May be called
|
||||
// at any time.
|
||||
void deinit();
|
||||
|
||||
uint get_total_passes() const { return m_params.m_two_pass_flag ? 2 : 1; }
|
||||
inline uint get_cur_pass() { return m_pass_num; }
|
||||
|
||||
// Call this method with each source scanline.
|
||||
// width * src_channels bytes per scanline is expected (RGB or Y format).
|
||||
// You must call with NULL after all scanlines are processed to finish
|
||||
// compression. Returns false on out of memory or if a stream write fails.
|
||||
bool process_scanline(const void *pScanline);
|
||||
|
||||
private:
|
||||
jpeg_encoder(const jpeg_encoder &);
|
||||
jpeg_encoder &operator=(const jpeg_encoder &);
|
||||
|
||||
typedef int32 sample_array_t;
|
||||
|
||||
output_stream *m_pStream;
|
||||
params m_params;
|
||||
uint8 m_num_components;
|
||||
uint8 m_comp_h_samp[3], m_comp_v_samp[3];
|
||||
int m_image_x, m_image_y, m_image_bpp, m_image_bpl;
|
||||
int m_image_x_mcu, m_image_y_mcu;
|
||||
int m_image_bpl_xlt, m_image_bpl_mcu;
|
||||
int m_mcus_per_row;
|
||||
int m_mcu_x, m_mcu_y;
|
||||
uint8 *m_mcu_lines[16];
|
||||
uint8 m_mcu_y_ofs;
|
||||
sample_array_t m_sample_array[64];
|
||||
int16 m_coefficient_array[64];
|
||||
int32 m_quantization_tables[2][64];
|
||||
uint m_huff_codes[4][256];
|
||||
uint8 m_huff_code_sizes[4][256];
|
||||
uint8 m_huff_bits[4][17];
|
||||
uint8 m_huff_val[4][256];
|
||||
uint32 m_huff_count[4][256];
|
||||
int m_last_dc_val[3];
|
||||
enum { JPGE_OUT_BUF_SIZE = 2048 };
|
||||
uint8 m_out_buf[JPGE_OUT_BUF_SIZE];
|
||||
uint8 *m_pOut_buf;
|
||||
uint m_out_buf_left;
|
||||
uint32 m_bit_buffer;
|
||||
uint m_bits_in;
|
||||
uint8 m_pass_num;
|
||||
bool m_all_stream_writes_succeeded;
|
||||
|
||||
void optimize_huffman_table(int table_num, int table_len);
|
||||
void emit_byte(uint8 i);
|
||||
void emit_word(uint i);
|
||||
void emit_marker(int marker);
|
||||
void emit_jfif_app0();
|
||||
void emit_dqt();
|
||||
void emit_sof();
|
||||
void emit_dht(uint8 *bits, uint8 *val, int index, bool ac_flag);
|
||||
void emit_dhts();
|
||||
void emit_sos();
|
||||
void emit_markers();
|
||||
void compute_huffman_table(uint *codes, uint8 *code_sizes, uint8 *bits,
|
||||
uint8 *val);
|
||||
void compute_quant_table(int32 *dst, int16 *src);
|
||||
void adjust_quant_table(int32 *dst, int32 *src);
|
||||
void first_pass_init();
|
||||
bool second_pass_init();
|
||||
bool jpg_open(int p_x_res, int p_y_res, int src_channels);
|
||||
void load_block_8_8_grey(int x);
|
||||
void load_block_8_8(int x, int y, int c);
|
||||
void load_block_16_8(int x, int c);
|
||||
void load_block_16_8_8(int x, int c);
|
||||
void load_quantized_coefficients(int component_num);
|
||||
void flush_output_buffer();
|
||||
void put_bits(uint bits, uint len);
|
||||
void code_coefficients_pass_one(int component_num);
|
||||
void code_coefficients_pass_two(int component_num);
|
||||
void code_block(int component_num);
|
||||
void process_mcu_row();
|
||||
bool terminate_pass_one();
|
||||
bool terminate_pass_two();
|
||||
bool process_end_of_image();
|
||||
void load_mcu(const void *src);
|
||||
void clear();
|
||||
void init();
|
||||
};
|
||||
|
||||
} // namespace jpge
|
||||
|
||||
#endif // JPEG_ENCODER
|
253
include/renderd7/external/nvid.hpp
vendored
Normal file
253
include/renderd7/external/nvid.hpp
vendored
Normal file
@ -0,0 +1,253 @@
|
||||
#pragma once
|
||||
#include <cstdint>
|
||||
#include <fstream>
|
||||
#include <iostream>
|
||||
#include <memory>
|
||||
#include <renderd7/external/jpgd.h>
|
||||
#include <renderd7/external/jpge.h>
|
||||
#include <sstream>
|
||||
#include <vector>
|
||||
|
||||
struct NVID_Header {
|
||||
char magic[4]; // Magic
|
||||
int framerate; // Only Up to 60
|
||||
int width; // Width
|
||||
int height; // Height
|
||||
uint32_t framecount; // Count of Frames
|
||||
};
|
||||
|
||||
struct NVID_Frame {
|
||||
char magic[4]; // Magic
|
||||
uint32_t framesize; // Size of Frame
|
||||
};
|
||||
|
||||
struct NVID_Image {
|
||||
int framenum; // Register of Frame
|
||||
int w; // Width of Frame
|
||||
int h; // Height of Frame
|
||||
int bpp; // bpp of Frame
|
||||
void *pBuf; // Buffer
|
||||
};
|
||||
|
||||
inline void CreateHeader(NVID_Header &header) {
|
||||
header.magic[0] = 'N';
|
||||
header.magic[1] = 'V';
|
||||
header.magic[2] = 'I';
|
||||
header.magic[3] = 'D';
|
||||
}
|
||||
|
||||
inline void CreateFrame(NVID_Frame &frame) {
|
||||
frame.magic[0] = 'N';
|
||||
frame.magic[1] = 'F';
|
||||
frame.magic[2] = 'R';
|
||||
frame.magic[3] = 'M';
|
||||
}
|
||||
|
||||
inline bool CheckHeader(NVID_Header &header) {
|
||||
if (header.magic[0] == 'N' && header.magic[1] == 'V' &&
|
||||
header.magic[2] == 'I' && header.magic[3] == 'D')
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
inline bool CheckFrame(NVID_Frame &frame) {
|
||||
if (frame.magic[0] == 'N' && frame.magic[1] == 'F' && frame.magic[2] == 'R' &&
|
||||
frame.magic[3] == 'M')
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/*inline std::vector<NVID_Image> LoadNVID(std::string path) {
|
||||
std::vector<NVID_Image> res;
|
||||
NVID_Header t_header;
|
||||
std::ifstream nvid_file2("out.nvid", std::ios::binary | std::ios::in);
|
||||
|
||||
nvid_file2.read((char *)&t_header, sizeof(NVID_Header));
|
||||
if (!CheckHeader(t_header))
|
||||
return res;
|
||||
|
||||
for (int i = 0; i < t_header.framecount; i++) {
|
||||
NVID_Image tmp;
|
||||
NVID_Frame frm;
|
||||
nvid_file2.read((char *)&frm, sizeof(NVID_Frame));
|
||||
if (!CheckFrame(frm)) {
|
||||
return res;
|
||||
}
|
||||
void *pBuf = malloc(frm.framesize);
|
||||
nvid_file2.read((char *)pBuf, frm.framesize);
|
||||
int lw, lh, lc;
|
||||
unsigned char *dat_s = jpgd::decompress_jpeg_image_from_memory(
|
||||
(unsigned char *)pBuf, frm.framesize, &lw, &lh, &lc, 3);
|
||||
tmp.bpp = lc;
|
||||
tmp.w = lw;
|
||||
tmp.h = lh;
|
||||
tmp.framenum = i;
|
||||
tmp.pBuf = dat_s;
|
||||
res.push_back(tmp);
|
||||
}
|
||||
return res;
|
||||
}*/
|
||||
|
||||
inline std::vector<std::unique_ptr<NVID_Image>>
|
||||
LoadNVID(const std::string &path) {
|
||||
std::vector<std::unique_ptr<NVID_Image>> res;
|
||||
std::ifstream nvid_file(path, std::ios::binary | std::ios::in);
|
||||
if (!nvid_file) {
|
||||
std::cerr << "Failed to open NVID file: " << path << std::endl;
|
||||
return res;
|
||||
}
|
||||
|
||||
NVID_Header header;
|
||||
nvid_file.read(reinterpret_cast<char *>(&header), sizeof(header));
|
||||
if (!CheckHeader(header)) {
|
||||
std::cerr << "Invalid NVID header" << std::endl;
|
||||
return res;
|
||||
}
|
||||
|
||||
for (int i = 0; i < (int)header.framecount; i++) {
|
||||
NVID_Frame frame;
|
||||
nvid_file.read(reinterpret_cast<char *>(&frame), sizeof(frame));
|
||||
if (!CheckFrame(frame)) {
|
||||
std::cerr << "Invalid NVID frame" << std::endl;
|
||||
return res;
|
||||
}
|
||||
|
||||
std::vector<uint8_t> compressed_data(frame.framesize);
|
||||
nvid_file.read(reinterpret_cast<char *>(compressed_data.data()),
|
||||
compressed_data.size());
|
||||
|
||||
int width, height, components;
|
||||
unsigned char *decompressed_data = jpgd::decompress_jpeg_image_from_memory(
|
||||
compressed_data.data(), compressed_data.size(), &width, &height,
|
||||
&components, 3);
|
||||
if (!decompressed_data) {
|
||||
std::cerr << "Failed to decompress JPEG data" << std::endl;
|
||||
return res;
|
||||
}
|
||||
|
||||
auto image = std::make_unique<NVID_Image>();
|
||||
image->bpp = components;
|
||||
image->w = width;
|
||||
image->h = height;
|
||||
image->framenum = i;
|
||||
image->pBuf = decompressed_data;
|
||||
|
||||
res.push_back(std::move(image));
|
||||
}
|
||||
|
||||
return res;
|
||||
}
|
||||
|
||||
inline std::vector<std::unique_ptr<NVID_Image>> LoadMemNVID(const void *data,
|
||||
size_t size) {
|
||||
std::vector<std::unique_ptr<NVID_Image>> res;
|
||||
std::istringstream nvid_stream(
|
||||
std::string(reinterpret_cast<const char *>(data), size));
|
||||
NVID_Header header;
|
||||
nvid_stream.read(reinterpret_cast<char *>(&header), sizeof(header));
|
||||
if (!CheckHeader(header)) {
|
||||
std::cerr << "Invalid NVID header" << std::endl;
|
||||
return res;
|
||||
}
|
||||
for (int i = 0; i < (int)header.framecount; i++) {
|
||||
NVID_Frame frame;
|
||||
nvid_stream.read(reinterpret_cast<char *>(&frame), sizeof(frame));
|
||||
if (!CheckFrame(frame)) {
|
||||
std::cerr << "Invalid NVID frame" << std::endl;
|
||||
return res;
|
||||
}
|
||||
std::vector<uint8_t> compressed_data(frame.framesize);
|
||||
nvid_stream.read(reinterpret_cast<char *>(compressed_data.data()),
|
||||
compressed_data.size());
|
||||
int width, height, components;
|
||||
unsigned char *decompressed_data = jpgd::decompress_jpeg_image_from_memory(
|
||||
compressed_data.data(), compressed_data.size(), &width, &height,
|
||||
&components, 3);
|
||||
if (!decompressed_data) {
|
||||
std::cerr << "Failed to decompress JPEG data" << std::endl;
|
||||
return res;
|
||||
}
|
||||
auto image = std::make_unique<NVID_Image>();
|
||||
image->bpp = components;
|
||||
image->w = width;
|
||||
image->h = height;
|
||||
image->framenum = i;
|
||||
image->pBuf = decompressed_data;
|
||||
res.push_back(std::move(image));
|
||||
}
|
||||
return res;
|
||||
}
|
||||
|
||||
class NVID_Stream {
|
||||
public:
|
||||
NVID_Stream() {}
|
||||
~NVID_Stream() {}
|
||||
|
||||
bool Load(const std::string &path) {
|
||||
file.open(path, std::ios::in | std::ios::binary);
|
||||
if (!file) {
|
||||
std::cerr << "Error: failed to open " << path << std::endl;
|
||||
return false;
|
||||
}
|
||||
file.read(reinterpret_cast<char *>(&t_header), sizeof(NVID_Header));
|
||||
if (!CheckHeader(t_header)) {
|
||||
std::cerr << "Error: invalid NVID file header" << std::endl;
|
||||
return false;
|
||||
}
|
||||
currentreg = 0;
|
||||
return true;
|
||||
}
|
||||
|
||||
void Update() {
|
||||
if (!file) {
|
||||
return;
|
||||
}
|
||||
NVID_Frame frm;
|
||||
file.read(reinterpret_cast<char *>(&frm), sizeof(NVID_Frame));
|
||||
if (!CheckFrame(frm)) {
|
||||
return;
|
||||
}
|
||||
if (frm.framesize > buffer.size()) {
|
||||
buffer.resize(frm.framesize);
|
||||
}
|
||||
file.read(reinterpret_cast<char *>(buffer.data()), frm.framesize);
|
||||
int lw, lh, lc;
|
||||
unsigned char *dat_s = jpgd::decompress_jpeg_image_from_memory(
|
||||
buffer.data(), frm.framesize, &lw, &lh, &lc, 3);
|
||||
if (!dat_s) {
|
||||
std::cerr << "Error: failed to decompress JPEG data" << std::endl;
|
||||
return;
|
||||
}
|
||||
current_frame.bpp = lc;
|
||||
current_frame.w = lw;
|
||||
current_frame.h = lh;
|
||||
current_frame.framenum = currentreg;
|
||||
current_frame.pBuf = dat_s;
|
||||
currentreg++;
|
||||
if (currentreg > (int)t_header.framecount) {
|
||||
file.seekg(sizeof(NVID_Header));
|
||||
currentreg = 0;
|
||||
}
|
||||
}
|
||||
|
||||
NVID_Image GetImage() const { return current_frame; }
|
||||
|
||||
private:
|
||||
bool CheckHeader(const NVID_Header &header) const {
|
||||
// TODO: implement header validation logic
|
||||
return true;
|
||||
}
|
||||
|
||||
bool CheckFrame(const NVID_Frame &frame) const {
|
||||
// TODO: implement frame validation logic
|
||||
return true;
|
||||
}
|
||||
|
||||
NVID_Image current_frame;
|
||||
NVID_Header t_header;
|
||||
int currentreg = 0;
|
||||
std::ifstream file;
|
||||
std::vector<unsigned char> buffer;
|
||||
};
|
5
include/renderd7/npi_intro.hpp
Normal file
5
include/renderd7/npi_intro.hpp
Normal file
@ -0,0 +1,5 @@
|
||||
#pragma once
|
||||
#include <cstddef>
|
||||
|
||||
extern unsigned char npi_intro[];
|
||||
extern size_t npi_intro_size;
|
@ -44,14 +44,16 @@
|
||||
#include <renderd7/stringtool.hpp>
|
||||
#include <renderd7/thread.hpp>
|
||||
|
||||
#define RENDERD7VSTRING "0.9.1"
|
||||
#define RENDERD7VSTRING "0.9.2"
|
||||
#define CHANGELOG \
|
||||
"0.9.1: Fix Critical bug in Spritesheet animations\nFix Color " \
|
||||
"0.9.2: Add NpiSplashVideo\nNvid Support(v0.0.1)\nAdd Basic RenderD7 " \
|
||||
"Splash\nFaster Graphics Init\nFade Effects\nFix Screen for this " \
|
||||
"Changelog\n0.9.1: Fix Critical bug in\nSpritesheet animations\nFix Color " \
|
||||
"Conver(Hex)\n0.9.0: Remove Stupid try of Console\nAdd Services list and " \
|
||||
"Clean up " \
|
||||
"Code.\nAlso added Minimal Init for hax2.x\n0.8.5: Fix Deltatime \n0.8.4: " \
|
||||
"A lot of Fixes and new\nFeatures for BitmapPrinter! \n0.8.3: Addet " \
|
||||
"Overlaycount to Info\nand Addet ResultDecoder for errors.\n0.8.2: Fix a " \
|
||||
"Overlaycount to Info\nand Addet ResultDecoder for errors.\n\n0.8.2: Fix a " \
|
||||
"lot of Stuff and\nadd c++17 based filesystem class.\n0.8.1: Add abillity " \
|
||||
"to Get Stdout as string\nto render it to the screen.\n0.8.0: Implement " \
|
||||
"BitmapPrinter\n0.7.3: Implement Over\nRender Overlay Framework\n0.7.2: " \
|
||||
@ -81,6 +83,8 @@ extern touchPosition d7_touch;
|
||||
|
||||
extern std::string dspststus;
|
||||
|
||||
extern bool rd7_do_splash;
|
||||
|
||||
/// RenderD7
|
||||
namespace RenderD7 {
|
||||
float GetDeltaTime();
|
||||
@ -113,10 +117,16 @@ public:
|
||||
|
||||
class RSettings : public RenderD7::Scene {
|
||||
private:
|
||||
void calculate_screens(const std::vector<std::string> &lines,
|
||||
int &screen_index, int &screens);
|
||||
|
||||
enum RState { RSETTINGS, RINFO, RSERVICES, RCLOG };
|
||||
RenderD7::RSettings::RState m_state = RenderD7::RSettings::RState::RSETTINGS;
|
||||
|
||||
mutable float txtposy = 30;
|
||||
int screens = 0;
|
||||
int screen_index = 0;
|
||||
std::vector<std::string> lines;
|
||||
|
||||
std::string rd7srstate = "false";
|
||||
std::string mtovlstate = "false";
|
||||
@ -160,6 +170,14 @@ int GetRandomInt(int b, int e);
|
||||
void DrawMetrikOvl();
|
||||
bool DrawImageFromSheet(RenderD7::Sheet *sheet, size_t index, float x, float y,
|
||||
float scaleX = 1.0, float scaleY = 1.0);
|
||||
void DoNpiIntro();
|
||||
/// @brief Fade In
|
||||
/// @param duration Duration in Frames
|
||||
void FadeIn();
|
||||
/// @brief Fade Out
|
||||
/// @param duration Duration in Frames
|
||||
void FadeOut();
|
||||
void FadeDisplay();
|
||||
namespace Error {
|
||||
void DisplayError(std::string toptext, std::string errortext, int timesec = 3);
|
||||
void DisplayFatalError(std::string toptext, std::string errortext);
|
||||
|
5
include/renderd7/renderd7_logo.hpp
Normal file
5
include/renderd7/renderd7_logo.hpp
Normal file
@ -0,0 +1,5 @@
|
||||
#pragma once
|
||||
#include <cstddef>
|
||||
|
||||
extern unsigned char renderd7_logo[];
|
||||
extern size_t renderd7_logo_size;
|
@ -5,6 +5,20 @@
|
||||
#include <renderd7/external/stb_image.h>
|
||||
extern bool usedbgmsg;
|
||||
|
||||
void convert24to32(unsigned char *inputImage, int width, int height,
|
||||
unsigned char *outputImage) {
|
||||
for (int y = 0; y < height; y++) {
|
||||
for (int x = 0; x < width; x++) {
|
||||
int i = (y * width + x) * 3; // index of current pixel in input image
|
||||
int j = (y * width + x) * 4; // index of current pixel in output image
|
||||
outputImage[j] = inputImage[i]; // copy red channel
|
||||
outputImage[j + 1] = inputImage[i + 1]; // copy green channel
|
||||
outputImage[j + 2] = inputImage[i + 2]; // copy blue channel
|
||||
outputImage[j + 3] = 255; // set alpha channel to 255 (fully opaque)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static u32 GetNextPowerOf2(u32 v) {
|
||||
v--;
|
||||
v |= v >> 1;
|
||||
@ -281,4 +295,46 @@ void Image::LoadJpg(std::string path) {
|
||||
IMG_LoadImageFile(&this->img, path.c_str());
|
||||
loadet = true;
|
||||
}
|
||||
|
||||
void Image::LoadPixels(int w, int h, int bpp, void *buffer) {
|
||||
if (loadet) {
|
||||
C3D_TexDelete(this->img.tex);
|
||||
loadet = false;
|
||||
}
|
||||
unsigned width, height;
|
||||
width = w;
|
||||
height = h;
|
||||
uint8_t *ImageBuffer = new uint8_t[w * h * 4];
|
||||
|
||||
if (bpp == 3)
|
||||
convert24to32((uint8_t *)buffer, width, height, ImageBuffer);
|
||||
|
||||
img.tex = new C3D_Tex;
|
||||
img.subtex =
|
||||
new Tex3DS_SubTexture({(u16)width, (u16)height, 0.0f, 1.0f,
|
||||
width / 512.0f, 1.0f - (height / 512.0f)});
|
||||
|
||||
C3D_TexInit(img.tex, 512, 512, GPU_RGBA8);
|
||||
C3D_TexSetFilter(img.tex, GPU_LINEAR, GPU_LINEAR);
|
||||
img.tex->border = 0xFFFFFFFF;
|
||||
C3D_TexSetWrap(img.tex, GPU_CLAMP_TO_BORDER, GPU_CLAMP_TO_BORDER);
|
||||
|
||||
for (u32 x = 0; x < width && x < 512; x++) {
|
||||
for (u32 y = 0; y < height && y < 512; y++) {
|
||||
const u32 dstPos = ((((y >> 3) * (512 >> 3) + (x >> 3)) << 6) +
|
||||
((x & 1) | ((y & 1) << 1) | ((x & 2) << 1) |
|
||||
((y & 2) << 2) | ((x & 4) << 2) | ((y & 4) << 3))) *
|
||||
4;
|
||||
|
||||
const u32 srcPos = (y * width + x) * 4;
|
||||
((uint8_t *)img.tex->data)[dstPos + 0] = ImageBuffer[srcPos + 3];
|
||||
((uint8_t *)img.tex->data)[dstPos + 1] = ImageBuffer[srcPos + 2];
|
||||
((uint8_t *)img.tex->data)[dstPos + 2] = ImageBuffer[srcPos + 1];
|
||||
((uint8_t *)img.tex->data)[dstPos + 3] = ImageBuffer[srcPos + 0];
|
||||
}
|
||||
}
|
||||
delete[] ImageBuffer;
|
||||
loadet = true;
|
||||
}
|
||||
|
||||
} // namespace RenderD7
|
29960
source/npi_intro.cpp
Normal file
29960
source/npi_intro.cpp
Normal file
File diff suppressed because it is too large
Load Diff
@ -1,6 +1,9 @@
|
||||
#include <regex>
|
||||
#include <renderd7/external/nvid.hpp>
|
||||
#include <renderd7/log.hpp>
|
||||
#include <renderd7/npi_intro.hpp>
|
||||
#include <renderd7/renderd7.hpp>
|
||||
#include <renderd7/renderd7_logo.hpp>
|
||||
|
||||
#define TICKS_PER_MSEC 268111.856
|
||||
|
||||
@ -12,12 +15,14 @@ float animtime;
|
||||
bool isndspinit = false;
|
||||
bool running = true;
|
||||
std::stack<std::unique_ptr<RenderD7::Scene>> RenderD7::Scene::scenes;
|
||||
std::unique_ptr<RenderD7::Scene> tmpFadeS;
|
||||
std::stack<std::unique_ptr<RenderD7::Ovl>> overlays;
|
||||
bool usedbgmsg = false;
|
||||
std::string dspststus = "Not Initialisized!";
|
||||
|
||||
int cobj___;
|
||||
int maxobj__;
|
||||
bool rd7_do_splash = false;
|
||||
|
||||
// INI::INIFile cfgfile;
|
||||
std::unique_ptr<INI::INIFile> cfgfile = nullptr;
|
||||
@ -86,7 +91,9 @@ float dtm;
|
||||
bool fadeout = false, fadein = false, fadeout2 = false, fadein2 = false;
|
||||
int fadealpha = 0;
|
||||
int fadecolor = 0;
|
||||
|
||||
bool waitFade = false;
|
||||
bool FadeExit = false;
|
||||
bool SceneFadeWait = false;
|
||||
// Sercices
|
||||
int sv_gfx = 0;
|
||||
int sv_dsp = 0;
|
||||
@ -94,6 +101,71 @@ int sv_cfgu = 0;
|
||||
int sv_apt = 0;
|
||||
int sv_romfs = 0;
|
||||
|
||||
std::vector<std::string> string_to_lines(std::string input_str) {
|
||||
std::vector<std::string> lines;
|
||||
std::stringstream ss(input_str);
|
||||
std::string line;
|
||||
while (std::getline(ss, line)) {
|
||||
lines.push_back(line);
|
||||
}
|
||||
return lines;
|
||||
}
|
||||
|
||||
void Npifade() {
|
||||
if (fadein) {
|
||||
if (fadealpha < 255) {
|
||||
RenderD7::OnScreen(Top);
|
||||
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
|
||||
((fadealpha << 24) | 0x00000000));
|
||||
RenderD7::OnScreen(Bottom);
|
||||
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
|
||||
fadealpha += 3;
|
||||
} else {
|
||||
fadein = false;
|
||||
}
|
||||
} else if (fadeout) {
|
||||
if (fadealpha > 0) {
|
||||
RenderD7::OnScreen(Top);
|
||||
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
|
||||
((fadealpha << 24) | 0x00000000));
|
||||
RenderD7::OnScreen(Bottom);
|
||||
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
|
||||
fadealpha -= 3;
|
||||
} else {
|
||||
fadeout = false;
|
||||
}
|
||||
} else {
|
||||
if (waitFade)
|
||||
waitFade = false;
|
||||
if (FadeExit)
|
||||
running = false;
|
||||
if (SceneFadeWait) {
|
||||
RenderD7::Scene::scenes.push(std::move(tmpFadeS));
|
||||
SceneFadeWait = false;
|
||||
}
|
||||
// No fade
|
||||
RenderD7::OnScreen(Top);
|
||||
RenderD7::Draw::Rect(0, 0, RenderD7::IsRD7SR() ? 800 : 400, 240,
|
||||
((fadealpha << 24) | 0x00000000));
|
||||
RenderD7::OnScreen(Bottom);
|
||||
RenderD7::Draw::Rect(0, 0, 320, 240, ((fadealpha << 24) | 0x00000000));
|
||||
}
|
||||
}
|
||||
|
||||
void PushSplash() {
|
||||
C2D_SpriteSheet sheet;
|
||||
sheet = C2D_SpriteSheetLoadFromMem((void *)renderd7_logo, renderd7_logo_size);
|
||||
C3D_FrameBegin(C3D_FRAME_SYNCDRAW);
|
||||
C2D_TargetClear(Top, DSEVENBLACK);
|
||||
C2D_TargetClear(Bottom, DSEVENBLACK);
|
||||
RenderD7::ClearTextBufs();
|
||||
RenderD7::OnScreen(Top);
|
||||
C2D_DrawImageAt(C2D_SpriteSheetGetImage(sheet, 0), 400 / 2 - 300 / 2,
|
||||
240 / 2 - 100 / 2, 0.5);
|
||||
C3D_FrameEnd(0);
|
||||
C2D_SpriteSheetFree(sheet);
|
||||
}
|
||||
|
||||
std::string _FMT_(const std::string &fmt_str, ...) {
|
||||
va_list ap;
|
||||
char *fp = NULL;
|
||||
@ -267,7 +339,11 @@ void RenderD7::Scene::doLogic(u32 hDown, u32 hHeld, u32 hUp,
|
||||
}
|
||||
|
||||
void RenderD7::Scene::Load(std::unique_ptr<Scene> scene, bool fade) {
|
||||
Scene::scenes.push(std::move(scene));
|
||||
if (fade) {
|
||||
tmpFadeS = std::move(scene);
|
||||
SceneFadeWait = true;
|
||||
} else
|
||||
Scene::scenes.push(std::move(scene));
|
||||
}
|
||||
|
||||
void RenderD7::Scene::Back() {
|
||||
@ -373,6 +449,20 @@ Result RenderD7::Init::Main(std::string app_name) {
|
||||
sv_apt = R_FAILED(res) ? 1 : 2;
|
||||
res = romfsInit();
|
||||
sv_romfs = R_FAILED(res) ? 1 : 2;
|
||||
|
||||
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
|
||||
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
|
||||
C2D_Prepare();
|
||||
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
|
||||
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
|
||||
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
|
||||
TextBuf = C2D_TextBufNew(4096);
|
||||
Font = C2D_FontLoadSystem(CFG_REGION_USA);
|
||||
printf("Graphical Interface\n");
|
||||
last_tm = svcGetSystemTick();
|
||||
if (rd7_do_splash)
|
||||
PushSplash();
|
||||
|
||||
res = cfguInit();
|
||||
sv_cfgu = R_FAILED(res) ? 1 : 2;
|
||||
printf("stuff\n");
|
||||
@ -465,16 +555,7 @@ Result RenderD7::Init::Main(std::string app_name) {
|
||||
printf("rd7sr\n");
|
||||
// consoleInit(GFX_BOTTOM, NULL);
|
||||
printf("csv\n");
|
||||
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
|
||||
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
|
||||
C2D_Prepare();
|
||||
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
|
||||
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
|
||||
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
|
||||
TextBuf = C2D_TextBufNew(4096);
|
||||
Font = C2D_FontLoadSystem(CFG_REGION_USA);
|
||||
printf("Graphical Interface\n");
|
||||
last_tm = svcGetSystemTick();
|
||||
|
||||
// RenderD7::Msg::Display("RenderD7", "RenderD7 init success!\nWaiting for
|
||||
// MainLoop!", Top);
|
||||
return 0;
|
||||
@ -487,6 +568,19 @@ Result RenderD7::Init::Minimal(std::string app_name) {
|
||||
sv_gfx = 2;
|
||||
res_ = romfsInit();
|
||||
sv_romfs = R_FAILED(res_) ? 1 : 2;
|
||||
|
||||
osSetSpeedupEnable(true);
|
||||
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
|
||||
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
|
||||
C2D_Prepare();
|
||||
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
|
||||
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
|
||||
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
|
||||
TextBuf = C2D_TextBufNew(4096);
|
||||
Font = C2D_FontLoadSystem(CFG_REGION_USA);
|
||||
if (rd7_do_splash)
|
||||
PushSplash();
|
||||
|
||||
// Check if citra
|
||||
s64 citracheck = 0;
|
||||
svcGetSystemInfo(&citracheck, 0x20000, 0);
|
||||
@ -569,16 +663,6 @@ Result RenderD7::Init::Minimal(std::string app_name) {
|
||||
if (consoleModel != 3)
|
||||
gfxSetWide(true);
|
||||
}
|
||||
|
||||
osSetSpeedupEnable(true);
|
||||
C3D_Init(C3D_DEFAULT_CMDBUF_SIZE);
|
||||
C2D_Init(C2D_DEFAULT_MAX_OBJECTS);
|
||||
C2D_Prepare();
|
||||
Top = C2D_CreateScreenTarget(GFX_TOP, GFX_LEFT);
|
||||
TopRight = C2D_CreateScreenTarget(GFX_TOP, GFX_RIGHT);
|
||||
Bottom = C2D_CreateScreenTarget(GFX_BOTTOM, GFX_LEFT);
|
||||
TextBuf = C2D_TextBufNew(4096);
|
||||
Font = C2D_FontLoadSystem(CFG_REGION_USA);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -691,8 +775,12 @@ void RenderD7::DrawTLBtns(std::vector<RenderD7::TLBtn> btns, u32 color,
|
||||
}
|
||||
|
||||
void RenderD7::ExitApp() {
|
||||
if (!rd7settings)
|
||||
running = false;
|
||||
if (!rd7settings) {
|
||||
if (waitFade) {
|
||||
FadeExit = true;
|
||||
} else
|
||||
running = false;
|
||||
}
|
||||
}
|
||||
|
||||
bool RenderD7::touchTObj(touchPosition touch, RenderD7::TObject button) {
|
||||
@ -931,20 +1019,18 @@ void RenderD7::FrameEnd() {
|
||||
RenderD7::DrawMetrikOvl();
|
||||
if (!shouldbe_disabled)
|
||||
OvlHandler();
|
||||
/*if (d7_hHeld & KEY_R && d7_hDown & KEY_SELECT)
|
||||
|
||||
{
|
||||
RenderD7::LoadSettings();
|
||||
}*/
|
||||
lp++;
|
||||
|
||||
Npifade();
|
||||
C3D_FrameEnd(0);
|
||||
}
|
||||
|
||||
RenderD7::RSettings::RSettings() {
|
||||
RenderD7::FadeOut();
|
||||
cfgfile = std::make_unique<INI::INIFile>(cfgpath + "/config.ini");
|
||||
cfgfile->read(cfgstruct);
|
||||
rd7settings = true;
|
||||
lines = string_to_lines(CHANGELOG);
|
||||
calculate_screens(lines, screen_index, screens);
|
||||
}
|
||||
|
||||
RenderD7::RSettings::~RSettings() { cfgfile->write(cfgstruct); }
|
||||
@ -1019,9 +1105,18 @@ void RenderD7::RSettings::Draw(void) const {
|
||||
|
||||
} else if (m_state == RCLOG) {
|
||||
RenderD7::OnScreen(Top);
|
||||
int start_index = screen_index * 9;
|
||||
int end_index = std::min((int)lines.size(), start_index + 9);
|
||||
|
||||
RenderD7::Draw::Rect(0, 21, 400, 220, RenderD7::Color::Hex("#eeeeee"));
|
||||
RenderD7::Draw::Text(5, 30, 0.7f, DSEVENBLACK, std::string(CHANGELOG));
|
||||
for (int i = start_index; i < end_index; i++) {
|
||||
RenderD7::Draw::Text(5, 23 + 20 * (i - start_index), 0.7f, DSEVENBLACK,
|
||||
lines[i]);
|
||||
}
|
||||
RenderD7::Draw::Rect(0, 219, 400, 21, RenderD7::Color::Hex("#111111"));
|
||||
RenderD7::Draw::Text(0, 220, 0.7f, RenderD7::Color::Hex("#ffffff"),
|
||||
"Site: " + std::to_string(screen_index + 1) + "/" +
|
||||
std::to_string(screens + 1));
|
||||
|
||||
RenderD7::Draw::Rect(0, 0, 400, 21, RenderD7::Color::Hex("#111111"));
|
||||
RenderD7::Draw::Text(0, 0, 0.7f, DSEVENWHITE, "RenderD7->Changelog");
|
||||
@ -1140,13 +1235,74 @@ void RenderD7::RSettings::Logic(u32 hDown, u32 hHeld, u32 hUp,
|
||||
if (d7_hDown & KEY_B) {
|
||||
m_state = RSETTINGS;
|
||||
}
|
||||
if (d7_hDown & KEY_R)
|
||||
if (screen_index < screens)
|
||||
screen_index++;
|
||||
if (d7_hDown & KEY_L)
|
||||
if (screen_index > 0)
|
||||
screen_index--;
|
||||
}
|
||||
}
|
||||
|
||||
void RenderD7::RSettings::calculate_screens(
|
||||
const std::vector<std::string> &lines, int &screen_index, int &screens) {
|
||||
int num_lines = lines.size();
|
||||
screens = (num_lines + 8) / 9; // round up to nearest multiple of 9
|
||||
screen_index = 0;
|
||||
screens -= 1;
|
||||
}
|
||||
|
||||
void RenderD7::LoadSettings() {
|
||||
RenderD7::Scene::Load(std::make_unique<RenderD7::RSettings>());
|
||||
}
|
||||
|
||||
void RenderD7::AddOvl(std::unique_ptr<RenderD7::Ovl> overlay) {
|
||||
overlays.push(std::move(overlay));
|
||||
}
|
||||
}
|
||||
|
||||
void RenderD7::DoNpiIntro() {
|
||||
auto images = LoadMemNVID(npi_intro, npi_intro_size);
|
||||
int c = 0;
|
||||
float xc = 0;
|
||||
RenderD7::Image img;
|
||||
uint64_t lastT = osGetTime();
|
||||
while (c < 59) {
|
||||
shouldbe_disabled = true;
|
||||
cnttttt = 0;
|
||||
C3D_FrameBegin(C3D_FRAME_SYNCDRAW);
|
||||
C2D_TargetClear(Top, RenderD7::Color::Hex("#000000"));
|
||||
C2D_TargetClear(Bottom, RenderD7::Color::Hex("#000000"));
|
||||
RenderD7::ClearTextBufs();
|
||||
RenderD7::OnScreen(Top);
|
||||
|
||||
img.LoadPixels(images[c]->w, images[c]->h, images[c]->bpp, images[c]->pBuf);
|
||||
img.Draw(0, 0);
|
||||
xc += osGetTime() - lastT;
|
||||
lastT = osGetTime();
|
||||
if (xc > 24 / 60) {
|
||||
c++;
|
||||
xc = 0;
|
||||
}
|
||||
if (c > (int)(images.size() - 1))
|
||||
c = 0;
|
||||
C3D_FrameEnd(0);
|
||||
}
|
||||
}
|
||||
|
||||
void RenderD7::FadeIn() {
|
||||
if (!waitFade) {
|
||||
fadein = true;
|
||||
fadealpha = 0;
|
||||
waitFade = true;
|
||||
}
|
||||
}
|
||||
|
||||
void RenderD7::FadeOut() {
|
||||
if (!waitFade) {
|
||||
fadeout = true;
|
||||
fadealpha = 255;
|
||||
waitFade = true;
|
||||
}
|
||||
}
|
||||
|
||||
void RenderD7::FadeDisplay() { Npifade(); }
|
399
source/renderd7_logo.cpp
Normal file
399
source/renderd7_logo.cpp
Normal file
@ -0,0 +1,399 @@
|
||||
#include <renderd7/renderd7_logo.hpp>
|
||||
|
||||
unsigned char renderd7_logo[] = {
|
||||
0x1, 0x0, 0x26, 0x0, 0x0, 0x2c, 0x1, 0x64, 0x0, 0x0, 0x0, 0x0,
|
||||
0x4, 0x58, 0x2, 0xe0, 0x0, 0x11, 0x0, 0x0, 0x4, 0x5c, 0x0, 0x19,
|
||||
0x7c, 0xe0, 0x0, 0xff, 0x0, 0xe0, 0x0, 0xc, 0xf0, 0xbf, 0x10, 0xa,
|
||||
0xf0, 0xff, 0xcc, 0xec, 0x2, 0xec, 0xec, 0x4d, 0xae, 0xae, 0xae, 0x72,
|
||||
0xc7, 0x2f, 0x1, 0x9d, 0x9d, 0x9d, 0x1f, 0xac, 0xac, 0xac, 0x1, 0x72,
|
||||
0xbf, 0x0, 0x2a, 0xe4, 0xe4, 0xe4, 0x22, 0xf4, 0xf4, 0xf4, 0x85, 0x73,
|
||||
0x7, 0x2, 0xcb, 0xcb, 0xcc, 0x73, 0x17, 0xaa, 0x20, 0x1b, 0x80, 0x9,
|
||||
0x7f, 0xff, 0x11, 0xa2, 0xa2, 0xa2, 0x2, 0xb9, 0xb9, 0x43, 0xb9, 0x10,
|
||||
0x12, 0x76, 0x3, 0x4, 0x9b, 0x9b, 0x9c, 0x10, 0x1a, 0x35, 0xff, 0x4,
|
||||
0x38, 0xaf, 0x84, 0x10, 0x9, 0xb8, 0xff, 0x1, 0xab, 0xab, 0xac, 0x3f,
|
||||
0xff, 0x16, 0xad, 0x13, 0xad, 0xad, 0x0, 0x11, 0xcc, 0x20, 0x0, 0x20,
|
||||
0xff, 0x50, 0x0, 0x70, 0x7, 0xfd, 0xf0, 0x6, 0x0, 0xf0, 0x1f, 0x2,
|
||||
0xf0, 0x16, 0x6, 0xff, 0xff, 0x4, 0x60, 0xd6, 0x9, 0xc0, 0xff, 0xfc,
|
||||
0xa1, 0xfb, 0x55, 0xf6, 0x22, 0xf, 0xf0, 0x1, 0xa1, 0xeb, 0xe1, 0x22,
|
||||
0x3f, 0xcd, 0xa2, 0x3b, 0x55, 0xb3, 0x22, 0x4f, 0x8b, 0x9, 0xa1, 0xff,
|
||||
0x59, 0x22, 0xff, 0x14, 0x63, 0x3, 0x55, 0xfd, 0xa2, 0x8f, 0xab, 0x23,
|
||||
0x17, 0x28, 0x0, 0x63, 0x13, 0xf7, 0x1, 0xa2, 0xbf, 0x56, 0x61, 0x62,
|
||||
0xe3, 0xfe, 0x23, 0x67, 0x5f, 0x7, 0x22, 0xef, 0x10, 0x94, 0x3f, 0xff,
|
||||
0x44, 0xbb, 0x6d, 0xc7, 0x44, 0x0, 0x6d, 0xdf, 0x0, 0xf0, 0x1f, 0xa,
|
||||
0xfd, 0xff, 0x4, 0xa0, 0x7, 0x0, 0x3e, 0x5f, 0xff, 0x0, 0xb0, 0x1f,
|
||||
0x10, 0x5f, 0xbc, 0xf, 0xb8, 0xf, 0x0, 0x30, 0xb, 0x0, 0x37, 0xab,
|
||||
0x0, 0x77, 0xcf, 0x0, 0x30, 0x4f, 0x0, 0x38, 0x6f, 0xf, 0x1, 0xe3,
|
||||
0xe3, 0xe3, 0x38, 0xb6, 0x70, 0x7, 0xf8, 0xc2, 0x0, 0xf0, 0x1f, 0xff,
|
||||
0x0, 0x70, 0x93, 0x3, 0x38, 0x57, 0x0, 0xb0, 0xc7, 0x3, 0xb0, 0x5f,
|
||||
0xf1, 0x7b, 0x0, 0xb9, 0x1f, 0x2, 0x70, 0x17, 0x0, 0xb1, 0xe7, 0xe0,
|
||||
0x9, 0x30, 0x3, 0x9, 0xb0, 0xab, 0xa, 0xb0, 0xa7, 0x1d, 0x90, 0x90,
|
||||
0x91, 0x1, 0x10, 0xb2, 0xb2, 0xb2, 0x3c, 0x4a, 0x15, 0x9d, 0x9d, 0x9d,
|
||||
0xc0, 0x1, 0x33, 0x13, 0x2, 0x3f, 0xff, 0xb, 0x8a, 0x8a, 0x8a, 0x1,
|
||||
0xc7, 0x38, 0xc7, 0xc8, 0x1, 0xb2, 0xab, 0x0, 0x74, 0xaf, 0xfc, 0xf6,
|
||||
0xa2, 0xe9, 0xe9, 0x61, 0xea, 0x1, 0xf3, 0x7f, 0x6, 0xff, 0xff, 0x38,
|
||||
0xc6, 0xc6, 0xc6, 0x0, 0x7d, 0x1f, 0xb, 0xe, 0xa2, 0xa2, 0xa2, 0xfd,
|
||||
0xaf, 0x2, 0x21, 0xa3, 0x7, 0x3f, 0xff, 0xf, 0x4, 0x9b, 0x9b, 0x9c,
|
||||
0x4d, 0x83, 0x60, 0x7, 0x0, 0xd, 0x9b, 0x0, 0xe0, 0x1f, 0xff, 0x6,
|
||||
0xf0, 0x7f, 0x10, 0x6, 0x70, 0x13, 0x2, 0x3f, 0xff, 0x1, 0xf4, 0x1f,
|
||||
0x0, 0xf7, 0x4b, 0x2, 0x74, 0x3, 0x3, 0xb8, 0x6b, 0x10, 0x5, 0x76,
|
||||
0xd7, 0x87, 0x0, 0x7a, 0x3b, 0x18, 0xad, 0xad, 0xad, 0x3f, 0xff, 0x70,
|
||||
0x7, 0xff, 0xff, 0x86, 0x70, 0x1f, 0x17, 0xac, 0xac, 0xac, 0x4, 0x3f,
|
||||
0xff, 0x70, 0x57, 0x18, 0x84, 0x0, 0x60, 0x5f, 0x16, 0xab, 0xab, 0xab,
|
||||
0x3f, 0xff, 0x3, 0x98, 0x13, 0x98, 0x98, 0x0, 0x11, 0xc4, 0x20, 0x0,
|
||||
0x20, 0xff, 0x50, 0x0, 0x70, 0x7, 0xfb, 0xf0, 0x6, 0x0, 0xf0, 0x1f,
|
||||
0x2, 0xf0, 0x16, 0x6, 0xf0, 0x7f, 0x0, 0xf0, 0xd6, 0x8c, 0x21, 0x1f,
|
||||
0x3f, 0xff, 0xf7, 0x70, 0x7, 0xff, 0xff, 0x0, 0xf1, 0x16, 0x0, 0x3f,
|
||||
0xff, 0x2, 0xa0, 0x4b, 0x0, 0xf0, 0x5f, 0x0, 0xf0, 0x7f, 0xd5, 0x2,
|
||||
0xff, 0xff, 0x0, 0xf1, 0xd6, 0x3, 0x22, 0x1f, 0x7, 0xa0, 0xfb, 0xc,
|
||||
0x22, 0x2f, 0x6a, 0x18, 0xa1, 0xb, 0x0, 0xf2, 0x16, 0x45, 0x22, 0x5f,
|
||||
0x9d, 0xa1, 0x3b, 0xfd, 0xaa, 0x62, 0x6f, 0x4d, 0x22, 0x77, 0xf8, 0x4,
|
||||
0x60, 0xd3, 0x84, 0x61, 0xb3, 0x27, 0xaa, 0x0, 0x61, 0xb3, 0x4, 0x61,
|
||||
0xd3, 0xf, 0x3, 0x62, 0xd3, 0xf6, 0xa3, 0x3b, 0x2a, 0xb5, 0x62, 0x2f,
|
||||
0xb5, 0x62, 0x37, 0x0, 0x33, 0x56, 0x27, 0x63, 0x73, 0x7d, 0x4, 0x63,
|
||||
0x53, 0x56, 0xb4, 0x63, 0xd3, 0xd5, 0x0, 0x63, 0xd3, 0xe3, 0xa0, 0x1f,
|
||||
0x10, 0x9, 0xbf, 0xff, 0x3e, 0xaa, 0x25, 0xab, 0x11, 0x25, 0xaf, 0x91,
|
||||
0x25, 0xb3, 0xec, 0xe4, 0x5f, 0x17, 0xaa, 0x25, 0xc7, 0x63, 0xa4, 0xa3,
|
||||
0xaf, 0x25, 0xd7, 0xd4, 0x25, 0xdb, 0xfb, 0xdb, 0x2, 0x24, 0x9f, 0x6,
|
||||
0x3f, 0xff, 0xec, 0x60, 0xab, 0x7f, 0xff, 0xf1, 0x0, 0xa2, 0xbf, 0x0,
|
||||
0x35, 0x5f, 0x55, 0xa9, 0x26, 0xc7, 0x66, 0xa5, 0xa3, 0x13, 0x0, 0x63,
|
||||
0x7f, 0xf9, 0x26, 0xef, 0x6a, 0x96, 0x8, 0x20, 0xff, 0x0, 0x7f, 0xff,
|
||||
0x14, 0x66, 0x7f, 0xea, 0x27, 0xa7, 0x44, 0xbe, 0xf, 0x63, 0xaf, 0x40,
|
||||
0x67, 0x93, 0x70, 0x7, 0x2, 0xb6, 0xdf, 0x8, 0xff, 0xff, 0xf9, 0x96,
|
||||
0x80, 0xaa, 0x68, 0x8f, 0x80, 0x1, 0x28, 0xf, 0x2e, 0x68, 0xbb, 0x1c,
|
||||
0x29, 0xe3, 0x41, 0xaa, 0x29, 0xe7, 0xed, 0x29, 0xeb, 0xaf, 0x8, 0x63,
|
||||
0xff, 0x89, 0x2a, 0x87, 0xc8, 0xb5, 0xa9, 0x63, 0xee, 0x1, 0x24, 0xbb,
|
||||
0xb9, 0x5f, 0xe8, 0x2a, 0xc7, 0xcf, 0xa9, 0xa3, 0x75, 0x92, 0x2a, 0xd7,
|
||||
0x32, 0x27, 0x9, 0x71, 0xff, 0x1, 0x0, 0x6a, 0x5f, 0xc9, 0x2b, 0x9f,
|
||||
0x55, 0x36, 0x6b, 0xa3, 0xfa, 0xaa, 0x83, 0x51, 0x10, 0x2, 0xa7, 0xbb,
|
||||
0x22, 0x6a, 0x7f, 0x55, 0xf6, 0x7, 0xe8, 0xff, 0x2d, 0xac, 0x63, 0x7f,
|
||||
0x2d, 0x97, 0xc4, 0x0, 0x23, 0xaf, 0xab, 0x0, 0x7c, 0x5f, 0xe0, 0x2d,
|
||||
0xc7, 0xf7, 0xac, 0xa3, 0xeb, 0x63, 0xf, 0x5, 0x34, 0xff, 0xba, 0x76,
|
||||
0x97, 0x44, 0x0, 0x6c, 0xff, 0x0, 0xf0, 0x1f, 0x3f, 0xff, 0x94, 0x2e,
|
||||
0x87, 0x3c, 0xae, 0xad, 0x63, 0x1, 0x0, 0x6b, 0x3f, 0xc3, 0x6b, 0x63,
|
||||
0x77, 0xcb, 0x1, 0x70, 0x7f, 0x5a, 0xdf, 0x67, 0x3f, 0x4, 0x3e, 0xc6,
|
||||
0x4, 0xa0, 0x7, 0x0, 0x3e, 0x1f, 0x0, 0xf0, 0x1f, 0x6, 0xb0, 0x7f,
|
||||
0xe, 0x3b, 0xff, 0xb5, 0x3b, 0x43, 0x3e, 0x6b, 0x43, 0x7, 0xbc, 0xff,
|
||||
0x17, 0xaf, 0xe3, 0x63, 0x67, 0xab, 0x6d, 0x91, 0x0, 0xeb, 0xc3, 0x7f,
|
||||
0xff, 0xd4, 0xe0, 0xcf, 0x3b, 0xf7, 0xf1, 0x9, 0xa6, 0xff, 0xb5, 0x3e,
|
||||
0xab, 0xa9, 0xaf, 0xaf, 0x3b, 0xcb, 0x13, 0x0, 0x6f, 0x9f, 0xf9, 0x1,
|
||||
0xac, 0xbf, 0xbd, 0x3b, 0xeb, 0x14, 0x6f, 0xe7, 0x3b, 0x43, 0xf4, 0xb3,
|
||||
0x10, 0x8, 0xfe, 0xff, 0x80, 0xaa, 0xf7, 0xea, 0x2, 0x3e, 0xbf, 0x0,
|
||||
0x3e, 0xfe, 0x7a, 0x17, 0x40, 0x8, 0xad, 0xff, 0x16, 0x2f, 0xeb, 0x93,
|
||||
0xaa, 0x6f, 0xdf, 0x30, 0x2f, 0xf7, 0x1f, 0x2f, 0xfb, 0xe9, 0x2f, 0xff,
|
||||
0xe8, 0xb5, 0x0, 0x6f, 0xbf, 0xe1, 0xea, 0x1f, 0x37, 0xff, 0xbc, 0x9,
|
||||
0xaa, 0xff, 0x6b, 0x2f, 0xff, 0x5a, 0xd, 0x0, 0x67, 0x3f, 0xea, 0x6f,
|
||||
0xff, 0x3c, 0xbf, 0x22, 0x6f, 0xf3, 0x5, 0x87, 0x3, 0x6f, 0xbb, 0x1,
|
||||
0xe3, 0xe3, 0xe3, 0x3e, 0x23, 0x70, 0x7, 0xfe, 0x2f, 0xf0, 0x0, 0xf0,
|
||||
0x1f, 0x2, 0xf8, 0x52, 0x6, 0xf0, 0x7f, 0x2, 0xf9, 0x12, 0x12, 0x98,
|
||||
0x98, 0x98, 0x87, 0x3f, 0xff, 0x1b, 0xae, 0xae, 0xae, 0x0, 0x3f, 0xff,
|
||||
0x70, 0x17, 0x0, 0x70, 0x1f, 0x87, 0x2, 0xf9, 0x92, 0x1b, 0xaf, 0xaf,
|
||||
0xaf, 0x40, 0x7f, 0x60, 0x7, 0x0, 0x0, 0x7f, 0xc4, 0x0, 0xe0, 0x1f,
|
||||
0x3, 0x4d, 0xbb, 0xea, 0xea, 0xea, 0x8d, 0xc7, 0xdd, 0xdd, 0x4, 0xdd,
|
||||
0x2, 0xc9, 0xc9, 0xc9, 0x9, 0x7d, 0x9b, 0x4, 0xa5, 0x2, 0xa5, 0xa5,
|
||||
0xbd, 0xfd, 0xfd, 0xfd, 0x7f, 0xff, 0x24, 0x10, 0x9f, 0x9f, 0x9f, 0x7f,
|
||||
0x57, 0x1, 0xd2, 0xd2, 0xd2, 0x85, 0x1, 0x75, 0x5f, 0xc, 0x97, 0x97,
|
||||
0x98, 0xbf, 0x93, 0xff, 0xa, 0x6e, 0x9f, 0xc2, 0x0, 0x3d, 0x5f, 0x5,
|
||||
0x33, 0x77, 0x14, 0x9a, 0x9a, 0x9a, 0x0, 0x44, 0x7f, 0xbc, 0x21, 0xbc,
|
||||
0xbc, 0x7d, 0xe7, 0x27, 0x94, 0x94, 0x95, 0x4, 0xf4, 0x3, 0x8, 0x3d,
|
||||
0xb6, 0xb6, 0xb6, 0x8c, 0xb7, 0x9d, 0x9d, 0x9d, 0x85, 0x0, 0x3e, 0x7e,
|
||||
0x55, 0xcb, 0xcb, 0xcb, 0x1, 0xfe, 0x3f, 0x2, 0x4, 0x63, 0xff, 0xc,
|
||||
0x16, 0x9a, 0x9a, 0x9b, 0x0, 0xb2, 0x6f, 0x3f, 0x3e, 0x3, 0xa9, 0x11,
|
||||
0xa9, 0xa9, 0xff, 0x36, 0x5f, 0x93, 0x93, 0x93, 0x3, 0xff, 0xef, 0xf,
|
||||
0x2, 0x9b, 0x9b, 0x9c, 0xbf, 0x87, 0x7, 0xfb, 0x57, 0x1, 0x79, 0x1f,
|
||||
0x2, 0x70, 0xbf, 0xe1, 0x2, 0xf0, 0x3f, 0xb, 0x3e, 0x8f, 0x9, 0xf1,
|
||||
0xff, 0x1, 0xd5, 0xd5, 0xd5, 0x1, 0x31, 0xff, 0x8, 0xac, 0xe6, 0xe6,
|
||||
0xe6, 0xbf, 0xff, 0x7, 0x97, 0x97, 0x4, 0x97, 0xa0, 0xf8, 0xf8, 0xf8,
|
||||
0x3, 0xc8, 0xff, 0xbf, 0xbf, 0x43, 0xbf, 0x3e, 0xde, 0x27, 0x90, 0x90,
|
||||
0x91, 0x2, 0x3e, 0xa7, 0x0, 0x32, 0xbf, 0xfc, 0x2, 0x35, 0xe7, 0x1,
|
||||
0x39, 0xdb, 0x0, 0x36, 0xd7, 0x0, 0xf0, 0x1f, 0x3, 0xf6, 0x8f, 0x87,
|
||||
0x9b, 0xbb, 0xbb, 0x27, 0xbb, 0x0, 0x11, 0xd3, 0x20, 0x0, 0x20, 0xff,
|
||||
0x50, 0x0, 0x70, 0x7, 0xf0, 0x6, 0xef, 0x0, 0xf0, 0x1f, 0x2, 0xf0,
|
||||
0x16, 0x6, 0xf0, 0x7f, 0x8c, 0x20, 0xff, 0x3f, 0xff, 0x70, 0x7, 0xff,
|
||||
0xff, 0xcd, 0x0, 0xf0, 0x1f, 0x2, 0xbf, 0xff, 0x1, 0xff, 0x7, 0x10,
|
||||
0x0, 0x1, 0x7f, 0xff, 0x5, 0x22, 0x27, 0x55, 0xe, 0xa1, 0x23, 0x1c,
|
||||
0x22, 0x37, 0x31, 0x0, 0x61, 0x33, 0x36, 0x61, 0x53, 0x55, 0x9d, 0xa1,
|
||||
0x53, 0x56, 0x22, 0x67, 0xb3, 0x22, 0x6b, 0x5e, 0x22, 0x6f, 0x2a, 0xfe,
|
||||
0xff, 0xc, 0xd0, 0x0, 0xbe, 0x63, 0x53, 0x85, 0x0, 0x63, 0x53, 0x3d,
|
||||
0xb5, 0x23, 0x73, 0xca, 0x62, 0x77, 0x2, 0x33, 0x56, 0xfc, 0x23, 0xb3,
|
||||
0xbc, 0x23, 0xb7, 0x6a, 0x2d, 0xa0, 0xf, 0x33, 0xc6, 0x74, 0x23, 0xcb,
|
||||
0x3c, 0xe2, 0xc7, 0x6c, 0xd5, 0x4, 0x22, 0xb7, 0x1, 0x7f, 0xff, 0x34,
|
||||
0x0, 0x23, 0x53, 0xd, 0x24, 0x6f, 0xdb, 0x24, 0x73, 0x6a, 0x82, 0x1,
|
||||
0xe2, 0x7f, 0x0, 0xbf, 0xff, 0x8, 0x63, 0xc3, 0x60, 0x24, 0xcb, 0xeb,
|
||||
0xaa, 0x0, 0x22, 0xdf, 0xa4, 0x63, 0xe3, 0xdf, 0x0, 0x24, 0xe3, 0x52,
|
||||
0x24, 0xff, 0xf8, 0xaa, 0x25, 0x3, 0xfa, 0x5, 0x23, 0x8b, 0xf3, 0x25,
|
||||
0x6b, 0xf9, 0x25, 0x6f, 0x89, 0xd5, 0xa1, 0xa7, 0x3, 0x35, 0x56, 0x63,
|
||||
0x25, 0xc3, 0xde, 0x25, 0xc7, 0x1, 0x0, 0x24, 0xc3, 0x5a, 0x8d, 0x64,
|
||||
0xdf, 0x5c, 0x0, 0x64, 0xdf, 0x0, 0xf5, 0xd6, 0x2c, 0x26, 0x1f, 0x8,
|
||||
0xad, 0xa5, 0x1b, 0x16, 0x26, 0x2f, 0x5b, 0xa5, 0x2b, 0x0, 0xf6, 0x16,
|
||||
0xdb, 0x66, 0x5f, 0x5a, 0xc, 0x26, 0x67, 0xc1, 0x2, 0xa4, 0x7f, 0x0,
|
||||
0xbf, 0xff, 0x16, 0xa5, 0xbb, 0xec, 0xd5, 0x66, 0xcf, 0x0, 0x72, 0x5f,
|
||||
0x31, 0x66, 0xef, 0x3, 0x26, 0xf7, 0xfb, 0x66, 0xfb, 0x5a, 0xfb, 0xa6,
|
||||
0xfb, 0x54, 0x66, 0xf, 0x32, 0xf, 0x38, 0x0, 0x67, 0x13, 0xde, 0xda,
|
||||
0x1, 0xa5, 0x3f, 0x72, 0x9b, 0x76, 0x2, 0x61, 0x7f, 0x0, 0xf7, 0x76,
|
||||
0xe4, 0x27, 0xbf, 0x4, 0xb5, 0x67, 0xc3, 0x47, 0x0, 0x26, 0xc3, 0x37,
|
||||
0xde, 0x95, 0x67, 0xe3, 0xcf, 0x1, 0x66, 0xc3, 0x7e, 0x40, 0x67, 0x13,
|
||||
0x70, 0x7, 0x0, 0xb0, 0x1f, 0x4, 0x36, 0x7f, 0x5, 0xb0, 0x7f, 0xf8,
|
||||
0xf6, 0x80, 0xb5, 0x29, 0xf, 0x43, 0x29, 0x13, 0x34, 0x33, 0xf0, 0x1,
|
||||
0x28, 0xf3, 0xf7, 0x1, 0x29, 0x17, 0x56, 0xfd, 0x64, 0x63, 0x49, 0x29,
|
||||
0x6b, 0x9b, 0x62, 0x57, 0x1, 0x33, 0x7f, 0xd3, 0xab, 0x0, 0x69, 0x93,
|
||||
0x79, 0x69, 0xb3, 0x4b, 0xa3, 0x8b, 0x1, 0x2, 0x68, 0x9f, 0x0, 0xf9,
|
||||
0xd6, 0x5a, 0xa, 0x2a, 0x1f, 0x11, 0xa9, 0x1b, 0x32, 0x63, 0xc8, 0x69,
|
||||
0x33, 0x7, 0xda, 0x2, 0x27, 0x13, 0x3, 0xf3, 0xff, 0x2a, 0x61, 0x5f,
|
||||
0x3f, 0xff, 0xd0, 0x0, 0x68, 0xdf, 0xa9, 0xad, 0x69, 0xe3, 0x92, 0x1,
|
||||
0x2a, 0xc3, 0xfa, 0x64, 0xf3, 0x3b, 0x16, 0xbb, 0x0, 0x6b, 0x13, 0x55,
|
||||
0xfe, 0x1, 0xa9, 0x3f, 0x1e, 0x6a, 0x5f, 0x69, 0x4, 0x63, 0xff, 0x95,
|
||||
0x6a, 0xbf, 0x55, 0xb0, 0x0, 0x6a, 0xbf, 0xc0, 0x6a, 0xdf, 0xc7, 0x3,
|
||||
0xaa, 0xbf, 0x3, 0x6b, 0x33, 0x55, 0x4f, 0x6b, 0x3b, 0x5a, 0x2c, 0x43,
|
||||
0x29, 0x2c, 0x47, 0xf6, 0xe5, 0x4b, 0xab, 0x3c, 0x5a, 0xce, 0x2, 0x2a,
|
||||
0x7f, 0xb9, 0x2c, 0x93, 0x13, 0x6a, 0x27, 0xff, 0xff, 0x55, 0x4a, 0x6c,
|
||||
0xaf, 0x81, 0x7, 0x2b, 0x3b, 0xe7, 0x1, 0x2d, 0x13, 0xf5, 0x64, 0x53,
|
||||
0x5d, 0x29, 0x6c, 0x67, 0x28, 0xe7, 0x4f, 0x0, 0x34, 0x2b, 0x3b, 0x3f,
|
||||
0x9c, 0x0, 0x2a, 0x1f, 0x5a, 0xf1, 0x2d, 0xab, 0x39, 0x2, 0xe3, 0xef,
|
||||
0x1, 0xf7, 0xff, 0x18, 0x2e, 0x1f, 0x5a, 0xb5, 0xad, 0x1b, 0xd2, 0x6e,
|
||||
0x2f, 0x33, 0xfb, 0xaa, 0x64, 0xdb, 0xa5, 0x3, 0xec, 0x7f, 0x5b, 0x6,
|
||||
0x1, 0xad, 0x6b, 0xd1, 0xa6, 0xfb, 0x0, 0x3e, 0xc2, 0x2, 0x61, 0xa7,
|
||||
0x3f, 0xff, 0x5f, 0xa2, 0x4, 0x6e, 0xc3, 0x4, 0xa0, 0x7, 0x0, 0x39,
|
||||
0x5f, 0x0, 0xf0, 0x1f, 0x6, 0xb0, 0x7f, 0x2, 0x3e, 0xd3, 0x5a, 0xd,
|
||||
0x6f, 0x33, 0x82, 0x6f, 0x3b, 0x3b, 0x43, 0x34, 0x6b, 0x43, 0xf8, 0xd5,
|
||||
0x0, 0x69, 0xff, 0x1, 0x7e, 0x7f, 0x8, 0x6b, 0xc3, 0x60, 0x0, 0x6e,
|
||||
0x9f, 0xa4, 0x6f, 0xff, 0x55, 0xdf, 0x6, 0xaf, 0x3b, 0xf9, 0x6b, 0xcb,
|
||||
0x3c, 0x1, 0x2f, 0xbf, 0x89, 0x6b, 0x43, 0xed, 0xbc, 0xab, 0xba, 0xaf,
|
||||
0xfa, 0x57, 0x63, 0xe7, 0xcf, 0x3f, 0xff, 0x8d, 0x6f, 0xff, 0xdb, 0x0,
|
||||
0x7b, 0xc3, 0x4, 0xb3, 0xff, 0x5b, 0x6d, 0xaf, 0x3f, 0xf7, 0xc, 0xaf,
|
||||
0xb7, 0x0, 0x3b, 0xcb, 0xbb, 0x7b, 0x4b, 0x54, 0xa7, 0x4b, 0x1, 0xf9,
|
||||
0xff, 0x3c, 0x5f, 0xec, 0xe2, 0x5f, 0x0, 0x3b, 0xc3, 0xd5, 0x76, 0x87,
|
||||
0x1, 0x7f, 0xff, 0xfb, 0x0, 0xea, 0x7f, 0x38, 0x0, 0x6f, 0x27, 0xde,
|
||||
0x6c, 0xff, 0xaf, 0x3f, 0xff, 0x76, 0x4, 0x61, 0x7f, 0xe4, 0xe4, 0x4b,
|
||||
0x79, 0x67, 0x0, 0x3e, 0x1f, 0x77, 0xef, 0x5e, 0xcf, 0x3, 0x6f, 0xd7,
|
||||
0x80, 0xaa, 0xf7, 0x0, 0x7b, 0xf, 0x0, 0xb0, 0x1f, 0x0, 0x3f, 0x36,
|
||||
0x44, 0xbb, 0x6f, 0xdb, 0xba, 0x1, 0x6b, 0x6f, 0x3, 0xf0, 0x7f, 0x1,
|
||||
0xbf, 0xca, 0xc8, 0x7, 0x28, 0x47, 0x7a, 0x4f, 0x55, 0x7c, 0x67, 0xf7,
|
||||
0x2e, 0xaf, 0xc7, 0xe2, 0x6d, 0xdf, 0x86, 0x0, 0x6f, 0xbf, 0x55, 0x9,
|
||||
0x2f, 0xff, 0x1b, 0xaf, 0xf7, 0x66, 0x2f, 0xef, 0xda, 0x6f, 0xf3, 0x6b,
|
||||
0x5, 0x1, 0x2f, 0x5f, 0x3f, 0xff, 0x9d, 0x0, 0xae, 0x3f, 0xed, 0x6e,
|
||||
0x5f, 0x78, 0x8f, 0xa8, 0x3, 0xf4, 0x7f, 0x46, 0xa3, 0xcb, 0x0, 0x6,
|
||||
0x20, 0x0, 0x1, 0xe3, 0xe3, 0x7f, 0xe3, 0x3f, 0xfe, 0x70, 0x7, 0xff,
|
||||
0xf2, 0x0, 0xf0, 0x1f, 0x2, 0xff, 0xbf, 0x6, 0xf0, 0x7f, 0x2, 0xff,
|
||||
0xc2, 0xf, 0x1b, 0xaf, 0xaf, 0xaf, 0x3f, 0xc3, 0x70, 0x7, 0xff, 0xcf,
|
||||
0x0, 0xf0, 0x1f, 0xc2, 0x6, 0xf0, 0x7f, 0x10, 0xf, 0x30, 0x13, 0x55,
|
||||
0xfa, 0xfa, 0xfa, 0x3f, 0xc7, 0x2, 0x18, 0xc9, 0xc9, 0xc9, 0x0, 0xfe,
|
||||
0x9f, 0x7f, 0xfa, 0x46, 0xa5, 0xa5, 0x62, 0xa6, 0x3, 0x3e, 0x82, 0xff,
|
||||
0xb3, 0x28, 0xa4, 0xa4, 0x4a, 0xe2, 0x1c, 0x11, 0xad, 0xad, 0xad, 0x0,
|
||||
0x3f, 0x1f, 0x15, 0xa6, 0xa6, 0x40, 0x77, 0x8, 0x10, 0x92, 0x92, 0x92,
|
||||
0x7, 0x74, 0xf, 0x29, 0x9e, 0x9e, 0x62, 0x9e, 0x0, 0xf1, 0x2f, 0x85,
|
||||
0x4f, 0xdf, 0xdf, 0xdf, 0x49, 0xbb, 0xbf, 0x31, 0xbf, 0xbf, 0x3, 0x7c,
|
||||
0xff, 0xcd, 0x8b, 0x95, 0x95, 0x96, 0x3f, 0x67, 0xd, 0xbd, 0xfd, 0xfd,
|
||||
0xfd, 0x0, 0x7e, 0xdf, 0x7f, 0x77, 0x0, 0x10, 0x15, 0xe0, 0x0, 0xe1,
|
||||
0xb2, 0x7b, 0x0, 0x7e, 0xff, 0xbf, 0xbf, 0x4, 0x9f, 0x9f, 0xa0, 0x0,
|
||||
0x3f, 0xaf, 0x0, 0x40, 0xbe, 0xbe, 0xbe, 0x3, 0xa5, 0xa5, 0xa5, 0xe1,
|
||||
0x3, 0xf4, 0x7f, 0xbf, 0x8f, 0x5, 0x3f, 0x5e, 0x1e, 0x8f, 0x8f, 0x8f,
|
||||
0x4, 0x3f, 0xc6, 0x0, 0x2, 0xb2, 0xb2, 0xb2, 0x16, 0x9a, 0x9a, 0x9b,
|
||||
0x80, 0xff, 0x5f, 0x15, 0x9a, 0x9a, 0x9a, 0x1, 0xbc, 0xbc, 0x42, 0xbc,
|
||||
0xfe, 0xff, 0xa, 0x9d, 0x9d, 0x9d, 0x0, 0x74, 0xf, 0x3, 0xa7, 0x25,
|
||||
0x8f, 0x0, 0x11, 0xdc, 0xa0, 0x0, 0x20, 0xff, 0x50, 0x0, 0x70, 0x7,
|
||||
0xf0, 0x6, 0xf7, 0x0, 0xf0, 0x1f, 0x2, 0xf0, 0x16, 0x6, 0xf0, 0x7f,
|
||||
0x0, 0xf0, 0xd6, 0x8c, 0x21, 0x1f, 0x3f, 0xff, 0x70, 0x7, 0x5d, 0x2,
|
||||
0x21, 0x2f, 0xb, 0x60, 0x13, 0x3f, 0xff, 0x0, 0xf1, 0x16, 0x22, 0x21,
|
||||
0x5f, 0x5b, 0x51, 0xa0, 0x2f, 0xb8, 0x61, 0x6f, 0x3f, 0xff, 0x5d, 0x0,
|
||||
0x20, 0x5f, 0xff, 0xff, 0xea, 0x0, 0xf0, 0x1f, 0x2, 0xff, 0xff, 0x1,
|
||||
0x71, 0xd6, 0xfa, 0x1, 0x21, 0xff, 0xfe, 0x22, 0x4b, 0xf7, 0xaa, 0x22,
|
||||
0x4f, 0xc7, 0x22, 0x53, 0x7d, 0x22, 0x57, 0x3, 0x0, 0x62, 0x53, 0xc8,
|
||||
0xad, 0xa2, 0x6b, 0x57, 0xa1, 0xf, 0x8d, 0x0, 0x22, 0x83, 0x3f, 0xff,
|
||||
0x5, 0xa1, 0x6f, 0x55, 0xcd, 0x62, 0xaf, 0x28, 0x22, 0xb7, 0xf6, 0x3,
|
||||
0x22, 0x93, 0x85, 0x22, 0xff, 0x55, 0x29, 0x0, 0xa1, 0x5b, 0x21, 0x61,
|
||||
0xff, 0xe6, 0x23, 0x27, 0x2d, 0x4, 0x21, 0x83, 0xaa, 0x33, 0x7e, 0xef,
|
||||
0xa3, 0x7b, 0x2e, 0x62, 0x6f, 0xe1, 0x23, 0x97, 0x13, 0xb5, 0x0, 0x63,
|
||||
0x93, 0xb3, 0xe1, 0x1f, 0x1, 0x3f, 0xff, 0x65, 0x4, 0x62, 0x3f, 0x14,
|
||||
0x64, 0x3f, 0x56, 0x2a, 0x0, 0x64, 0x3f, 0x3b, 0x64, 0x5f, 0x4b, 0x0,
|
||||
0x64, 0x5f, 0x2, 0xff, 0xff, 0x44, 0xaa, 0x64, 0xbf, 0x34, 0x0, 0x64,
|
||||
0xbf, 0x1f, 0xa3, 0x6f, 0xef, 0x4, 0x24, 0xc3, 0x4a, 0xd5, 0x64, 0x1f,
|
||||
0xf1, 0x8f, 0xff, 0x7, 0x60, 0x0, 0x2f, 0x64, 0xbf, 0x49, 0x0, 0xe4,
|
||||
0x3f, 0xde, 0x2, 0x70, 0xbf, 0x0, 0x30, 0x3f, 0xe7, 0x3, 0xa6, 0x2b,
|
||||
0x2, 0xf4, 0xbf, 0x3, 0x74, 0xff, 0x0, 0xb6, 0xfe, 0xfb, 0xad, 0xa7,
|
||||
0x3b, 0x4, 0x66, 0x2f, 0x23, 0xe2, 0x17, 0x77, 0x5e, 0x3d, 0x66, 0x4f,
|
||||
0x6a, 0x4f, 0x0, 0x60, 0x1f, 0x2, 0xf0, 0xff, 0x58, 0x66, 0xaf, 0x5a,
|
||||
0x2, 0xa6, 0x2f, 0x40, 0xfe, 0x66, 0xf3, 0x70, 0x7, 0x0, 0xb0, 0x1f,
|
||||
0x4, 0x31, 0xdf, 0x5, 0xb0, 0x7f, 0x0, 0x73, 0x33, 0x39, 0x16, 0x1e,
|
||||
0xad, 0x0, 0x69, 0x13, 0x11, 0x69, 0x33, 0xc, 0x3, 0x27, 0x93, 0x0,
|
||||
0x39, 0x76, 0x8, 0xe0, 0x7, 0xd5, 0x0, 0xb0, 0x1f, 0x7, 0x3f, 0xff,
|
||||
0x85, 0x69, 0x23, 0x7e, 0x0, 0x67, 0xbf, 0x7a, 0x69, 0x43, 0x7d, 0x78,
|
||||
0x4, 0x25, 0xff, 0x70, 0x57, 0x0, 0xb0, 0x5f, 0x0, 0xb0, 0x1f, 0x2,
|
||||
0xfa, 0xd6, 0xcb, 0x6a, 0x1f, 0x5b, 0xcc, 0x0, 0x69, 0xbf, 0xcc, 0x0,
|
||||
0xe0, 0x1f, 0x2, 0xfb, 0x56, 0xcc, 0x2, 0xe0, 0x7f, 0xff, 0xff, 0x55,
|
||||
0xa6, 0x6c, 0xf, 0xb7, 0x0, 0x68, 0x5f, 0xc6, 0x6c, 0x2f, 0xcf, 0x4,
|
||||
0x65, 0xdf, 0x55, 0xc2, 0x6c, 0x8f, 0xb1, 0x0, 0x68, 0xdf, 0x9e, 0x6c,
|
||||
0xaf, 0x6f, 0x3, 0xac, 0x8f, 0x5a, 0xc4, 0x6d, 0x3, 0xab, 0x0, 0x2b,
|
||||
0x83, 0x3d, 0x1e, 0x9d, 0x6d, 0x23, 0x9c, 0xaa, 0x4, 0x69, 0xff, 0xa4,
|
||||
0x6d, 0x83, 0xb4, 0x0, 0x60, 0x7f, 0xd3, 0x6d, 0xa3, 0xf8, 0xb5, 0xac,
|
||||
0x77, 0x7, 0x7, 0x63, 0xfb, 0x3f, 0xff, 0x79, 0x6d, 0x23, 0x57, 0x0,
|
||||
0x6b, 0xbf, 0x55, 0x4b, 0x6d, 0x43, 0x3f, 0x4, 0x63, 0xff, 0x47, 0x6d,
|
||||
0xa3, 0x54, 0x0, 0x6c, 0x3f, 0x57, 0x74, 0x6d, 0xc3, 0xa2, 0x4, 0x6e,
|
||||
0xc3, 0x4, 0xe7, 0xfb, 0xfd, 0x5f, 0x0, 0xf0, 0x1f, 0xeb, 0x6, 0xb0,
|
||||
0x7f, 0x7b, 0xc3, 0x3e, 0xe3, 0x2a, 0x0, 0x6d, 0x7f, 0x3b, 0xa1, 0xc7,
|
||||
0x3, 0xff, 0xff, 0xd5, 0x7b, 0xc3, 0x3f, 0x63, 0x34, 0x0, 0x6d, 0xff,
|
||||
0x1f, 0x0, 0x2f, 0x6f, 0xef, 0x3, 0xeb, 0xc3, 0xff, 0x3, 0xba, 0xff,
|
||||
0x3, 0xfb, 0xff, 0x78, 0x8f, 0x0, 0x3b, 0xc3, 0x2, 0xfb, 0x3f, 0x2,
|
||||
0xfb, 0xff, 0x3, 0xbb, 0xeb, 0x7, 0x3b, 0xff, 0x55, 0xfb, 0xa3, 0xcf,
|
||||
0x23, 0x0, 0x6f, 0x7f, 0x3d, 0x6f, 0xaf, 0x4f, 0x4, 0x69, 0xff, 0x55,
|
||||
0x58, 0x6f, 0xf7, 0x5a, 0x5, 0x29, 0xdf, 0x80, 0x6f, 0xbf, 0x80, 0x0,
|
||||
0x6f, 0xbf, 0xda, 0x0, 0xf0, 0x1f, 0x2, 0xbd, 0x2f, 0xea, 0x1, 0x20,
|
||||
0x5f, 0x2, 0x30, 0x7f, 0xdb, 0x6f, 0xff, 0xd1, 0xb5, 0x0, 0x6f, 0xef,
|
||||
0xca, 0x6f, 0xff, 0x38, 0xcb, 0x42, 0x6f, 0xbf, 0x18, 0x0, 0x6f, 0x1f,
|
||||
0x61, 0x1, 0x7, 0xa7, 0x67, 0x10, 0x4, 0x30, 0x87, 0x1, 0xe3, 0xe3,
|
||||
0xe3, 0x3f, 0xff, 0xfa, 0x70, 0x7, 0x5, 0xf4, 0x7f, 0x7f, 0xc3, 0x0,
|
||||
0x70, 0x7f, 0x0, 0xf0, 0x9f, 0xff, 0x6, 0xe5, 0x7f, 0x1b, 0x17, 0xaf,
|
||||
0xaf, 0xaf, 0x3f, 0xc3, 0xd, 0x60, 0x7, 0x3, 0x3e, 0xff, 0x1, 0xbf,
|
||||
0xd6, 0xb, 0x1, 0xae, 0xae, 0xae, 0x3f, 0x83, 0x19, 0x60, 0x7, 0xff,
|
||||
0x8f, 0xe, 0x1a, 0xad, 0xad, 0xad, 0x40, 0xa7, 0x0, 0x60, 0x1f, 0x10,
|
||||
0xf, 0xf0, 0x13, 0x5f, 0x10, 0xf6, 0xf6, 0xf6, 0x3f, 0xff, 0x99, 0xfa,
|
||||
0xfa, 0xfa, 0x84, 0x0, 0x3e, 0xff, 0x30, 0xe8, 0xe8, 0xe8, 0x3f, 0xff,
|
||||
0x12, 0x9e, 0x21, 0x9e, 0x9e, 0x4, 0x3e, 0xff, 0x18, 0xab, 0xab, 0xab,
|
||||
0x3f, 0xff, 0x61, 0x21, 0x60, 0x7, 0xff, 0xd3, 0x2f, 0x9b, 0x9b, 0x9c,
|
||||
0x3f, 0xff, 0xe, 0x30, 0xc1, 0xc1, 0xc2, 0x2, 0x3f, 0x6b, 0xff, 0xd3,
|
||||
0x3, 0xfd, 0x12, 0x10, 0x10, 0x91, 0x91, 0x91, 0x3f, 0xd3, 0x12, 0xa0,
|
||||
0xa0, 0xa0, 0x87, 0x0, 0x3c, 0xdf, 0x8, 0x99, 0x99, 0x9a, 0x0, 0x7c,
|
||||
0xff, 0x0, 0x30, 0x9f, 0x0, 0xff, 0x3b, 0xc2, 0x1, 0xf9, 0x63, 0x7f,
|
||||
0xdf, 0x2, 0xc4, 0xc4, 0xc4, 0x10, 0xf, 0xf4, 0xf, 0x1, 0x1, 0xb9,
|
||||
0xb9, 0xb9, 0x20, 0x93, 0x93, 0x93, 0xfe, 0xff, 0xc, 0xf, 0x9b, 0x9b,
|
||||
0x9b, 0x4, 0x33, 0x2b, 0x4f, 0xbb, 0x88, 0x88, 0x50, 0x89, 0x1, 0xb3,
|
||||
0xb3, 0xff, 0x7, 0xa0, 0x0, 0xe0, 0xfb, 0xfb, 0xfb, 0x80, 0x49, 0x3b,
|
||||
0xb4, 0xb4, 0xb4, 0x1f, 0x94, 0x94, 0x95, 0x84, 0x0, 0x3e, 0x6b, 0x3,
|
||||
0xa6, 0xa6, 0xa6, 0x1, 0xfd, 0xbf, 0x9, 0x8d, 0x22, 0x8d, 0x8e, 0x49,
|
||||
0x93, 0xcf, 0xcf, 0xd0, 0xff, 0xe6, 0x23, 0x20, 0x9a, 0x9a, 0x44, 0x3f,
|
||||
0x5, 0x8e, 0x8e, 0x8e, 0x0, 0x9f, 0x11, 0xe3, 0x20, 0x0, 0x20, 0xff,
|
||||
0x50, 0x0, 0x70, 0x7, 0xf0, 0x6, 0x0, 0xf0, 0x1f, 0x2, 0xf0, 0x16,
|
||||
0xbf, 0x6, 0xf0, 0x7f, 0x8c, 0x20, 0xff, 0x3f, 0xff, 0x70, 0x7, 0xff,
|
||||
0xff, 0x0, 0xf0, 0x1f, 0x2, 0xff, 0xff, 0xd6, 0x6, 0xf0, 0x7f, 0x0,
|
||||
0x3f, 0xff, 0x70, 0x61, 0x13, 0x1, 0x1, 0x20, 0xf3, 0x72, 0x36, 0xc0,
|
||||
0xab, 0x0, 0x62, 0x3f, 0x23, 0x22, 0x5f, 0xf5, 0x61, 0x63, 0x71, 0x0,
|
||||
0x22, 0x63, 0x3, 0x3f, 0xff, 0x55, 0x2, 0xa1, 0xbb, 0xc6, 0x62, 0xcf,
|
||||
0x28, 0x22, 0xd7, 0xf8, 0x0, 0x61, 0xd3, 0x55, 0x79, 0x61, 0xf3, 0x4,
|
||||
0x3, 0x22, 0xd3, 0xf2, 0x23, 0x3f, 0x1e, 0x63, 0x43, 0x6a, 0xb4, 0x0,
|
||||
0x22, 0x43, 0xf3, 0x56, 0x56, 0x62, 0x6f, 0xe6, 0x23, 0x77, 0xe, 0xab,
|
||||
0x1, 0xa3, 0x53, 0xcd, 0x1, 0xa3, 0x7f, 0x93, 0x63, 0xd3, 0xfd, 0x1,
|
||||
0x23, 0xb3, 0x3, 0x3f, 0xff, 0x55, 0xbb, 0x0, 0xe1, 0xdf, 0x16, 0xa3,
|
||||
0x5b, 0xfb, 0x64, 0x6f, 0xa1, 0xe1, 0xff, 0x6a, 0x34, 0x0, 0x63, 0x7f,
|
||||
0x30, 0xf7, 0x3, 0x64, 0xa3, 0x6f, 0x1, 0x23, 0x83, 0x19, 0xda, 0x61,
|
||||
0x93, 0x3f, 0xff, 0x65, 0x1, 0xa2, 0xbf, 0x2, 0x74, 0xde, 0x81, 0x64,
|
||||
0x3f, 0xda, 0xaa, 0x25, 0x47, 0x2, 0x0, 0x61, 0xff, 0x69, 0x65, 0x63,
|
||||
0xf7, 0xa4, 0x63, 0x4e, 0xd5, 0x64, 0x77, 0x0, 0xf5, 0x56, 0x88, 0xa3,
|
||||
0x27, 0x6d, 0xa5, 0xa3, 0xf8, 0x0, 0x65, 0xaf, 0x75, 0xfe, 0xa1, 0x5b,
|
||||
0x1, 0x35, 0xb2, 0x4, 0x7f, 0xff, 0x72, 0x26, 0x57, 0xe4, 0x65, 0x5b,
|
||||
0x55, 0x3, 0x65, 0x63, 0x86, 0x26, 0x6b, 0xda, 0xe6, 0x67, 0x3c, 0xe3,
|
||||
0x7, 0x57, 0xf, 0x26, 0x8f, 0x3b, 0x1, 0xa6, 0x6b, 0xb0, 0x2, 0xe6,
|
||||
0x97, 0x7f, 0xff, 0x34, 0xbf, 0x5a, 0x9d, 0xa6, 0x3, 0x7a, 0x63, 0xab,
|
||||
0x1, 0x73, 0x3f, 0x33, 0x27, 0x47, 0x10, 0xda, 0x0, 0x63, 0xff, 0x75,
|
||||
0x1b, 0x50, 0x1, 0x24, 0x1f, 0xb7, 0x86, 0xf1, 0xe7, 0x93, 0xe6, 0xab,
|
||||
0x64, 0xd3, 0x43, 0x27, 0xb3, 0x38, 0x66, 0xb7, 0xc1, 0x27, 0xbf, 0x35,
|
||||
0xa7, 0x5f, 0x27, 0x3, 0xa6, 0x9f, 0x40, 0x67, 0x13, 0x70, 0x7, 0x0,
|
||||
0xb0, 0x1f, 0x2, 0xf8, 0x16, 0x6, 0xf0, 0x7f, 0xbe, 0x0, 0x38, 0xf6,
|
||||
0x8, 0xe0, 0x7, 0x0, 0xb0, 0x1f, 0x2, 0xff, 0xff, 0x6, 0xf0, 0x7f,
|
||||
0x3, 0x3f, 0xff, 0x78, 0xbd, 0x69, 0x43, 0x78, 0x0, 0x67, 0xdf, 0x0,
|
||||
0xf0, 0x1f, 0x6, 0xb0, 0x7f, 0x2, 0xfa, 0xd6, 0xcc, 0x6a, 0x3f, 0x7a,
|
||||
0xcc, 0x0, 0x6a, 0x3f, 0x0, 0xf0, 0x1f, 0x6, 0xf0, 0x7f, 0xff, 0xff,
|
||||
0x37, 0x6c, 0xf, 0x6, 0xd6, 0xa7, 0x47, 0xff, 0xff, 0x94, 0x6b, 0x33,
|
||||
0x29, 0x4, 0x63, 0xff, 0x1, 0xbf, 0xff, 0x9b, 0xaa, 0x6c, 0xbf, 0xc,
|
||||
0x2c, 0xc7, 0xdd, 0x0, 0x6a, 0x5f, 0x2d, 0xab, 0xdb, 0xe9, 0xdb, 0x6c,
|
||||
0xef, 0x35, 0x2f, 0xe1, 0x0, 0x2c, 0xf3, 0x74, 0xfb, 0xa4, 0x0, 0x67,
|
||||
0x9f, 0x39, 0x53, 0x6a, 0x40, 0xa5, 0x8f, 0x1, 0x7f, 0xff, 0x2f, 0x4,
|
||||
0x61, 0xff, 0xf3, 0x2d, 0xbf, 0x85, 0xad, 0xad, 0xbb, 0x2a, 0x2d, 0xcf,
|
||||
0x9, 0x4, 0xe7, 0xff, 0x31, 0x6b, 0xb, 0x2e, 0x37, 0xd5, 0x39, 0xf7,
|
||||
0x3b, 0x43, 0xea, 0x2e, 0x43, 0x53, 0x0, 0x6e, 0x3f, 0xde, 0x0, 0xee,
|
||||
0x37, 0x55, 0x17, 0x2e, 0x7f, 0x5c, 0xae, 0x7b, 0xda, 0x4, 0x2e, 0x67,
|
||||
0xc8, 0x63, 0xa7, 0x5b, 0x14, 0x2e, 0xeb, 0xc7, 0x0, 0xec, 0xaf, 0x2,
|
||||
0x3e, 0xe6, 0x4, 0xa0, 0x7, 0x0, 0x3d, 0x1f, 0xf6, 0x0, 0xf0, 0x1f,
|
||||
0x6, 0xb0, 0x7f, 0x0, 0x3b, 0xcb, 0x3f, 0xff, 0x71, 0x0, 0x6d, 0x9f,
|
||||
0x3b, 0xcb, 0xfb, 0xaa, 0x6f, 0x33, 0xa1, 0x4, 0x67, 0xff, 0x19, 0x1,
|
||||
0xaf, 0x6b, 0xf2, 0x6f, 0xff, 0x65, 0xeb, 0x0, 0xac, 0xdf, 0x3b, 0x43,
|
||||
0xfe, 0xaf, 0x6d, 0xab, 0x43, 0x81, 0xa2, 0x7b, 0xfe, 0x53, 0xb5, 0xfe,
|
||||
0xd6, 0x69, 0x6f, 0xaf, 0x3b, 0xcb, 0x4e, 0x4, 0x67, 0xff, 0xfe, 0x1,
|
||||
0xae, 0x97, 0x6d, 0xa1, 0x6b, 0x43, 0x7f, 0x87, 0xe, 0x6b, 0x43, 0x3,
|
||||
0x3b, 0xff, 0x72, 0x0, 0x2f, 0xff, 0x57, 0x3, 0x6b, 0xc3, 0x86, 0xef,
|
||||
0xbf, 0xe4, 0x6a, 0xe7, 0x7f, 0xcf, 0x3b, 0x4b, 0x5a, 0x7a, 0x1, 0x2f,
|
||||
0x5f, 0x3b, 0x3, 0x2b, 0xc3, 0x1, 0xff, 0xc6, 0xf8, 0x6b, 0x4b, 0x38,
|
||||
0xd7, 0xaf, 0xaf, 0x3f, 0x97, 0x33, 0xaf, 0xbf, 0x10, 0x0, 0x6d, 0x9f,
|
||||
0x70, 0xe3, 0x0, 0x3b, 0xcb, 0xad, 0x2, 0x79, 0xff, 0xc1, 0x6b, 0xeb,
|
||||
0x27, 0x6b, 0xcb, 0xbf, 0x93, 0x43, 0x4, 0xe9, 0xe3, 0x5d, 0x80, 0x6f,
|
||||
0xb3, 0x80, 0x0, 0x6f, 0x8, 0x0, 0xf0, 0x1f, 0x0, 0x3f, 0x3f, 0xc4,
|
||||
0xe0, 0x7, 0xd0, 0x0, 0xb0, 0x1f, 0x6, 0xf0, 0x7f, 0x0, 0x10, 0xe,
|
||||
0xe0, 0x0, 0x1, 0xe3, 0xe3, 0xe3, 0xfe, 0x3f, 0xe6, 0x70, 0x7, 0xff,
|
||||
0xf2, 0x0, 0xf0, 0x1f, 0x2, 0xff, 0x2, 0x6, 0xf0, 0x7f, 0x2, 0xff,
|
||||
0xc2, 0x1b, 0x1f, 0xaf, 0xaf, 0xaf, 0x3f, 0xc3, 0x70, 0x7, 0xff, 0xcf,
|
||||
0x0, 0xf0, 0x1f, 0x6, 0xf0, 0x7f, 0x84, 0x10, 0xe, 0x33, 0xff, 0x2,
|
||||
0xbb, 0xbb, 0xbb, 0x4a, 0xbf, 0xeb, 0xeb, 0x78, 0xeb, 0x2, 0xf9, 0xb7,
|
||||
0x1, 0xb9, 0xd7, 0x0, 0x7e, 0xff, 0x3f, 0xff, 0x13, 0x9c, 0x9c, 0x70,
|
||||
0x9c, 0x6, 0x33, 0xdf, 0x3, 0x7c, 0x83, 0x3f, 0xff, 0x99, 0xe0, 0xe0,
|
||||
0xe1, 0x8, 0x1, 0xdf, 0xdf, 0xdf, 0xfe, 0xdf, 0x20, 0xa5, 0xa5, 0x42,
|
||||
0xa5, 0x3f, 0xff, 0x6b, 0xfb, 0xfb, 0xfb, 0x4, 0x3c, 0xff, 0x1, 0x1,
|
||||
0xc9, 0xc9, 0xc9, 0x62, 0xd0, 0xd0, 0xd0, 0x0, 0x3f, 0x8b, 0x8, 0x9,
|
||||
0x90, 0x90, 0x91, 0x45, 0xe7, 0xcf, 0xcf, 0xcf, 0x88, 0x10, 0x5, 0xc7,
|
||||
0x57, 0xda, 0xda, 0xda, 0x0, 0x3e, 0x3f, 0x5, 0x8b, 0x8b, 0x43, 0x8c,
|
||||
0x3f, 0xff, 0x19, 0xa2, 0xa2, 0xa2, 0x0, 0xfc, 0x7f, 0x2, 0x3, 0xd7,
|
||||
0x14, 0xc6, 0xc6, 0xc6, 0x0, 0x3e, 0x5f, 0x60, 0x62, 0x77, 0x18, 0xa4,
|
||||
0x3f, 0xa4, 0xa5, 0x0, 0x7e, 0x7f, 0x0, 0xb0, 0xb, 0x0, 0xb0, 0x2f,
|
||||
0x0, 0xf3, 0x47, 0x0, 0xb4, 0x37, 0x4, 0x33, 0xc3, 0xc0, 0x1, 0x3e,
|
||||
0x5f, 0x0, 0x7e, 0x77, 0x26, 0x9b, 0x9b, 0x9b, 0x1, 0xdb, 0x20, 0xdb,
|
||||
0xdb, 0x0, 0x3e, 0x9f, 0x12, 0xa6, 0xa6, 0xa6, 0x1, 0x9, 0xbf, 0xbf,
|
||||
0xbf, 0x0, 0x11, 0xeb, 0xe0, 0x0, 0x20, 0xff, 0x50, 0x0, 0xfd, 0x70,
|
||||
0x7, 0xf0, 0x6, 0x0, 0xff, 0xff, 0x0, 0x60, 0x36, 0x1, 0x80, 0x3f,
|
||||
0x6, 0xff, 0xff, 0x8c, 0x60, 0xe3, 0xd5, 0x70, 0x7, 0x10, 0xd, 0xff,
|
||||
0xff, 0x2e, 0x22, 0xff, 0xfa, 0x62, 0xe7, 0x80, 0xe, 0x22, 0xff, 0xaa,
|
||||
0x33, 0xfe, 0xf2, 0xa3, 0xfb, 0x1b, 0x63, 0xf3, 0xac, 0xe, 0x63, 0xf,
|
||||
0x27, 0xaa, 0x25, 0xf, 0xab, 0x1, 0xa4, 0xb7, 0xfc, 0x65, 0x3f, 0x1a,
|
||||
0x25, 0x47, 0x6b, 0xad, 0xa5, 0x43, 0xa9, 0x25, 0x57, 0xd3, 0x9, 0x61,
|
||||
0xff, 0x36, 0x2, 0xef, 0x26, 0x7, 0x55, 0xfb, 0xa6, 0x3, 0xf9, 0x26,
|
||||
0x17, 0xea, 0x1, 0xa5, 0xff, 0xcf, 0x26, 0x47, 0x55, 0x9f, 0x66, 0x4b,
|
||||
0xf6, 0x26, 0x53, 0x5e, 0x26, 0x57, 0xd, 0x9, 0x65, 0xff, 0x56, 0x10,
|
||||
0xf, 0xe5, 0xfb, 0x40, 0x67, 0xf7, 0x40, 0xd, 0x64, 0xff, 0xf8, 0xfa,
|
||||
0x8, 0xd6, 0xa0, 0x7, 0x10, 0x1, 0x3f, 0xff, 0x78, 0x6a, 0x27, 0x78,
|
||||
0xb, 0x61, 0xff, 0x1, 0xba, 0xff, 0xcc, 0xaa, 0x6b, 0x23, 0xcc, 0xf,
|
||||
0xaa, 0x3f, 0xe, 0x9, 0xab, 0x4b, 0x93, 0x2c, 0xff, 0xfd, 0xaa, 0x6c,
|
||||
0xe7, 0x1f, 0xad, 0x3, 0x77, 0x2d, 0x17, 0xc2, 0x1, 0xac, 0xff, 0xe1,
|
||||
0xd5, 0x67, 0x33, 0x7d, 0x46, 0xec, 0x2d, 0x57, 0xd5, 0x9, 0xa7, 0xff,
|
||||
0xa5, 0x67, 0xb3, 0xad, 0x37, 0xbb, 0x8a, 0x2e, 0x13, 0x13, 0x1, 0x6d,
|
||||
0xbb, 0xf5, 0x23, 0xc0, 0x6e, 0x4f, 0x6a, 0xc0, 0xd, 0x63, 0xff, 0x3f,
|
||||
0x3e, 0x4, 0x6f, 0x43, 0x4, 0xf, 0x6e, 0x43, 0x27, 0xd5, 0x9, 0xaf,
|
||||
0x4b, 0x3b, 0xeb, 0xfc, 0x6f, 0xfb, 0x1a, 0xad, 0xff, 0x6b, 0x6b, 0xc3,
|
||||
0xb6, 0x1, 0x7d, 0xff, 0xd3, 0x6b, 0x43, 0x7e, 0x42, 0xfb, 0x6b, 0x43,
|
||||
0x9, 0x7b, 0xff, 0xea, 0xdd, 0x6b, 0xc3, 0x7f, 0x2, 0x9f, 0x6b, 0xc3,
|
||||
0x0, 0xff, 0xff, 0x3b, 0xeb, 0x8c, 0xab, 0xeb, 0xd6, 0xf, 0xfb, 0x4b,
|
||||
0x8, 0xff, 0xff, 0x80, 0x6f, 0xfb, 0x80, 0x2, 0xa4, 0xff, 0xfc, 0x3,
|
||||
0xc4, 0xa1, 0xa0, 0x7, 0x0, 0x10, 0x18, 0xe0, 0x0, 0x1, 0xe3, 0xe3,
|
||||
0xe3, 0x3e, 0xc3, 0xfe, 0x70, 0x7, 0xfe, 0xcf, 0x0, 0xf0, 0x1f, 0x2,
|
||||
0xf0, 0x13, 0x5, 0x70, 0x7f, 0x2, 0x7f, 0xbf, 0x0, 0xff, 0xdf, 0x1b,
|
||||
0x1f, 0xaf, 0xaf, 0xaf, 0x3f, 0xe3, 0x70, 0x7, 0x0, 0xc, 0xb, 0x0,
|
||||
0x60, 0x17, 0xff, 0x7f, 0xfc, 0x1, 0x7f, 0xab, 0xff, 0xb3, 0x0, 0xf0,
|
||||
0x1f, 0x2, 0xfd, 0xdf, 0x2, 0xf0, 0xb7, 0x0, 0x3e, 0x5f, 0x12, 0x9c,
|
||||
0x38, 0x9c, 0x9c, 0x4, 0x32, 0x4b, 0x3, 0xb2, 0x17, 0x3f, 0xff, 0x3,
|
||||
0xa8, 0xa8, 0x0, 0xa8, 0x1e, 0xac, 0xac, 0xad, 0x31, 0x98, 0x98, 0x40,
|
||||
0x98, 0x0, 0xbf, 0x1f, 0x2, 0xb0, 0xb0, 0xb0, 0x1c, 0x94, 0x23, 0x94,
|
||||
0x95, 0x3f, 0xfe, 0xb2, 0xea, 0xea, 0x38, 0x4a, 0x10, 0x7, 0x40, 0x2,
|
||||
0x8, 0x97, 0x49, 0x49, 0x49, 0xfc, 0xdf, 0x9d, 0x46, 0x46, 0x0, 0x47,
|
||||
0xd, 0x9e, 0x9e, 0x9f, 0x9, 0x97, 0x97, 0x50, 0x98, 0x0, 0x7c, 0xff,
|
||||
0x14, 0x62, 0x9f, 0x1, 0xbe, 0xbe, 0xbe, 0x80, 0xbd, 0x1f, 0xad, 0xe9,
|
||||
0xe9, 0xe9, 0xf, 0xa2, 0xa2, 0x50, 0xa2, 0x3, 0xfe, 0x7f, 0x3, 0x24,
|
||||
0x43, 0x7, 0x92, 0x92, 0x92, 0x84, 0x10, 0xa, 0x78, 0x2b, 0x5d, 0xc6,
|
||||
0xc6, 0xc6, 0x0, 0x7f, 0x4b, 0x2, 0xbf, 0x21, 0xbf, 0xbf, 0x3f, 0x63,
|
||||
0x55, 0xfa, 0xfa, 0xfa, 0x3, 0xb5, 0x7f, 0x84, 0x7f, 0xff, 0x44, 0xf1,
|
||||
0xf1, 0xf1, 0x3f, 0xc3, 0x1d, 0xaa, 0x2c, 0xaa, 0xaa, 0x0, 0x3f, 0xcb,
|
||||
0x31, 0x22, 0xe7, 0x3f, 0xe3, 0x91, 0xde, 0x28, 0xde, 0xde, 0x5, 0xf5,
|
||||
0x73, 0x2c, 0x0, 0x65, 0xe7, 0x11, 0x93, 0x93, 0x44, 0x93, 0x4b, 0x73,
|
||||
0xfc, 0xfc, 0xfc, 0x4, 0x38, 0x53, 0x3, 0xb7, 0x22, 0xb7, 0xb7, 0x48,
|
||||
0xd3, 0xdd, 0xdd, 0xdd, 0x0, 0x7b, 0xd3, 0xa7, 0xb, 0xe2, 0xe2, 0xe3,
|
||||
0x0, 0x13, 0x61, 0xe0, 0x0, 0xff, 0x20, 0x0, 0x70, 0x7, 0xff, 0x70,
|
||||
0x3, 0x0, 0xf0, 0x1f, 0x0, 0xf0, 0xb, 0x0, 0x30, 0x63, 0x0, 0x30,
|
||||
0x17, 0x0, 0xb0, 0x93, 0xb0, 0x87, 0x2, 0x70, 0x3f, 0xc2, 0x6, 0xf0,
|
||||
0x7, 0x10, 0xd, 0x30, 0xff, 0x34, 0x90, 0x90, 0x91, 0x73, 0x3b, 0x11,
|
||||
0x0, 0x9a, 0x9a, 0x9b, 0x3, 0xa6, 0xa6, 0xa6, 0x9c, 0x1, 0xfd, 0xfd,
|
||||
0xfd, 0x5, 0x90, 0x90, 0x90, 0x7f, 0xff, 0x0, 0x3, 0xb3, 0xb3, 0xb4,
|
||||
0x1, 0xd6, 0xd6, 0xd6, 0xc0, 0x5, 0xb3, 0xd3, 0x0, 0x73, 0xaf, 0x10,
|
||||
0xa5, 0xa5, 0xa6, 0xaa, 0xe5, 0x2, 0xe5, 0xe5, 0xe, 0xa1, 0xa1, 0xa1,
|
||||
0x7f, 0xff, 0x1, 0x10, 0xcd, 0xcd, 0xce, 0xbf, 0xff, 0xad, 0xe6, 0xe6,
|
||||
0xe6, 0xb, 0x3, 0x9d, 0x9d, 0x9d, 0x10, 0x1d, 0xbf, 0xff, 0x1, 0x23,
|
||||
0x13, 0x43, 0xb, 0x1c, 0xda, 0xda, 0xda, 0x3, 0x75, 0xf7, 0x2, 0xf3,
|
||||
0xbf, 0x7, 0x76, 0xff, 0x34, 0x93, 0x21, 0x93, 0x93, 0x3f, 0xff, 0x2a,
|
||||
0xa2, 0xa2, 0xa2, 0x0, 0x38, 0xb, 0x8, 0x24, 0xaa, 0xaa, 0xab, 0x3f,
|
||||
0xff, 0x1f, 0xad, 0xad, 0x7c, 0xad, 0x3, 0xb7, 0xbf, 0x84, 0x9f, 0x60,
|
||||
0x57, 0x1f, 0xff, 0xf0, 0x0, 0x19, 0xd0, 0x70, 0x0};
|
||||
|
||||
size_t renderd7_logo_size = 0x1275;
|
Loading…
Reference in New Issue
Block a user