forked from KolibriOS/kolibrios
TextReader 1.01: better code from Veliant
git-svn-id: svn://kolibrios.org@5923 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
9780bc0c05
commit
09384aab2e
@ -12,6 +12,19 @@
|
|||||||
#include "../lib/patterns/simple_open_dialog.h"
|
#include "../lib/patterns/simple_open_dialog.h"
|
||||||
|
|
||||||
#define TOOLBAR_H 34
|
#define TOOLBAR_H 34
|
||||||
|
#define TOOLBAR_ICON_WIDTH 26
|
||||||
|
#define TOOLBAR_ICON_HEIGHT 24
|
||||||
|
|
||||||
|
#define TOOLBAR_OPEN_FILE_LEFT 8
|
||||||
|
#define TOOLBAR_MAGNIFY_PLUS_LEFT 42
|
||||||
|
#define TOOLBAR_MAGNIFY_MINUS_LEFT 67
|
||||||
|
#define TOOLBAR_CHANGE_ENCODING_LEFT 101
|
||||||
|
#define TOOLBAR_RUN_EDIT_LEFT 135
|
||||||
|
|
||||||
|
#define DEFAULT_FONT "/sys/fonts/Tahoma.kf"
|
||||||
|
#define DEFAULT_EDITOR "/sys/tinypad"
|
||||||
|
|
||||||
|
#define INTRO_TEXT "This is a plain text reader.\nTry to open some text file."
|
||||||
|
|
||||||
char default_dir[] = "/rd/1";
|
char default_dir[] = "/rd/1";
|
||||||
od_filter filter2 = {0,0};
|
od_filter filter2 = {0,0};
|
||||||
@ -29,7 +42,7 @@ dword line_offset;
|
|||||||
#define DWORD 4;
|
#define DWORD 4;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
OPEN_FILE,
|
OPEN_FILE = 10,
|
||||||
MAGNIFY_MINUS,
|
MAGNIFY_MINUS,
|
||||||
MAGNIFY_PLUS,
|
MAGNIFY_PLUS,
|
||||||
CHANGE_ENCODING,
|
CHANGE_ENCODING,
|
||||||
@ -40,66 +53,185 @@ enum {
|
|||||||
#include "ini.h"
|
#include "ini.h"
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
|
|
||||||
|
void InitDlls()
|
||||||
|
{
|
||||||
|
load_dll(boxlib, #box_lib_init, 0);
|
||||||
|
load_dll(libio, #libio_init, 1);
|
||||||
|
load_dll(libimg, #libimg_init, 1);
|
||||||
|
load_dll(libini, #lib_init, 1);
|
||||||
|
load_dll(iconv_lib, #iconv_open, 0);
|
||||||
|
load_dll(Proc_lib, #OpenDialog_init,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventShowInfo()
|
||||||
|
{
|
||||||
|
ShowAbout();
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventOpenFile()
|
||||||
|
{
|
||||||
|
OpenDialog_start stdcall (#o_dialog);
|
||||||
|
OpenFile(#openfile_path);
|
||||||
|
PreparePage();
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventMagnifyPlus()
|
||||||
|
{
|
||||||
|
font.size.text++;
|
||||||
|
if(!font.changeSIZE())
|
||||||
|
font.size.text--;
|
||||||
|
else
|
||||||
|
PreparePage();
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventMagnifyMinus()
|
||||||
|
{
|
||||||
|
font.size.text--;
|
||||||
|
if(!font.changeSIZE())
|
||||||
|
font.size.text++;
|
||||||
|
else
|
||||||
|
PreparePage();
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventRunEdit()
|
||||||
|
{
|
||||||
|
io.run(DEFAULT_EDITOR, #param);
|
||||||
|
}
|
||||||
|
|
||||||
|
void EventChangeEncoding()
|
||||||
|
{
|
||||||
|
CreateThread(#menu_rmb,#stak+4092);
|
||||||
|
}
|
||||||
|
|
||||||
|
void HandleMouseEvent()
|
||||||
|
{
|
||||||
|
mouse.get();
|
||||||
|
list.wheel_size = 7;
|
||||||
|
if (list.MouseScroll(mouse.vert)) {
|
||||||
|
DrawPage();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
scrollbar_v_mouse (#scroll);
|
||||||
|
if (list.first != scroll.position) {
|
||||||
|
list.first = scroll.position;
|
||||||
|
DrawPage();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void HandleKeyEvent()
|
||||||
|
{
|
||||||
|
if (help_opened) {
|
||||||
|
help_opened = false;
|
||||||
|
DrawPage();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
GetKeys();
|
||||||
|
if (key_scancode==059) {
|
||||||
|
EventShowInfo();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (key_modifier & KEY_LCTRL) || (key_modifier & KEY_RCTRL) {
|
||||||
|
switch (key_scancode)
|
||||||
|
{
|
||||||
|
case 024:
|
||||||
|
EventOpenFile();
|
||||||
|
break;
|
||||||
|
case SCAN_CODE_UP:
|
||||||
|
EventMagnifyPlus();
|
||||||
|
break;
|
||||||
|
case SCAN_CODE_DOWN:
|
||||||
|
EventMagnifyMinus();
|
||||||
|
break;
|
||||||
|
case 018:
|
||||||
|
EventRunEdit();
|
||||||
|
break;
|
||||||
|
case SCAN_CODE_TAB:
|
||||||
|
EventChangeEncoding();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (list.ProcessKey(key_scancode))
|
||||||
|
DrawPage();
|
||||||
|
}
|
||||||
|
|
||||||
|
void HandleButtonEvent()
|
||||||
|
{
|
||||||
|
|
||||||
|
byte btn = GetButtonID();
|
||||||
|
if (btn==1) {
|
||||||
|
SaveIniSettings();
|
||||||
|
ExitProcess();
|
||||||
|
}
|
||||||
|
btn-=10;
|
||||||
|
switch(btn)
|
||||||
|
{
|
||||||
|
case OPEN_FILE:
|
||||||
|
EventOpenFile();
|
||||||
|
break;
|
||||||
|
case MAGNIFY_PLUS:
|
||||||
|
EventMagnifyPlus();
|
||||||
|
break;
|
||||||
|
case MAGNIFY_MINUS:
|
||||||
|
EventMagnifyMinus();
|
||||||
|
break;
|
||||||
|
case CHANGE_ENCODING:
|
||||||
|
EventChangeEncoding();
|
||||||
|
break;
|
||||||
|
case RUN_EDIT:
|
||||||
|
EventRunEdit();
|
||||||
|
break;
|
||||||
|
case SHOW_INFO:
|
||||||
|
EventShowInfo();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
byte btn;
|
InitDlls();
|
||||||
load_dll(boxlib, #box_lib_init,0);
|
|
||||||
load_dll(libio, #libio_init,1);
|
|
||||||
load_dll(libimg, #libimg_init,1);
|
|
||||||
load_dll(libini, #lib_init,1);
|
|
||||||
load_dll(iconv_lib, #iconv_open,0);
|
|
||||||
load_dll(Proc_lib, #OpenDialog_init,0);
|
|
||||||
OpenDialog_init stdcall (#o_dialog);
|
OpenDialog_init stdcall (#o_dialog);
|
||||||
font.no_bg_copy = true; font.color = 0; font.bg_color = 0xFFFFFF;
|
|
||||||
font.load("/sys/fonts/Tahoma.kf"); if (!font.data) { io.run("/sys/@notify","'Error: Font is not loaded.' -E"); ExitProcess(); }
|
font.no_bg_copy = true;
|
||||||
|
font.color = 0;
|
||||||
|
font.bg_color = 0xFFFFFF;
|
||||||
|
|
||||||
|
font.load(DEFAULT_FONT);
|
||||||
|
|
||||||
|
if (!font.data) {
|
||||||
|
io.run("/sys/@notify","'Error: Font is not loaded.' -E");
|
||||||
|
ExitProcess();
|
||||||
|
}
|
||||||
|
|
||||||
Libimg_LoadImage(#skin, abspath("toolbar.png"));
|
Libimg_LoadImage(#skin, abspath("toolbar.png"));
|
||||||
|
|
||||||
LoadIniSettings();
|
LoadIniSettings();
|
||||||
|
|
||||||
OpenFile(#param);
|
OpenFile(#param);
|
||||||
list.no_selection = true;
|
list.no_selection = true;
|
||||||
SetEventMask(10000000000000000000000001100111b);
|
SetEventMask(10000000000000000000000001100111b);
|
||||||
loop()
|
loop()
|
||||||
{
|
{
|
||||||
switch(WaitEvent())
|
switch(WaitEvent())
|
||||||
{
|
{
|
||||||
case evMouse:
|
case evMouse:
|
||||||
mouse.get();
|
HandleMouseEvent();
|
||||||
list.wheel_size = 7;
|
|
||||||
if (list.MouseScroll(mouse.vert)) { DrawPage(); break; }
|
|
||||||
scrollbar_v_mouse (#scroll); if (list.first != scroll.position) { list.first = scroll.position; DrawPage(); }
|
|
||||||
break;
|
|
||||||
case evKey:
|
|
||||||
if (help_opened) { help_opened=false; DrawPage(); break; }
|
|
||||||
GetKeys();
|
|
||||||
if (key_scancode==059) goto _SHOW_INFO;
|
|
||||||
if (key_modifier&KEY_LCTRL) || (key_modifier&KEY_RCTRL) {
|
|
||||||
if (key_scancode==024) goto _OPEN_FILE;
|
|
||||||
if (key_scancode==SCAN_CODE_UP) goto _MAGNIFY_PLUS;
|
|
||||||
if (key_scancode==SCAN_CODE_DOWN) goto _MAGNIFY_MINUS;
|
|
||||||
if (key_scancode==018) goto _RUN_EDIT;
|
|
||||||
if (key_scancode==SCAN_CODE_TAB) goto _CHANGE_ENCODING;
|
|
||||||
break;
|
break;
|
||||||
}
|
case evKey:
|
||||||
if (list.ProcessKey(key_scancode)) DrawPage();
|
HandleKeyEvent();
|
||||||
break;
|
break;
|
||||||
case evButton:
|
case evButton:
|
||||||
btn = GetButtonID();
|
HandleButtonEvent();
|
||||||
if (btn==1) { SaveIniSettings(); ExitProcess(); }
|
break;
|
||||||
btn-=10;
|
case evReDraw:
|
||||||
if (btn==OPEN_FILE) { _OPEN_FILE: OpenDialog_start stdcall (#o_dialog); OpenFile(#openfile_path); PreparePage(); }
|
if (action_buf) {
|
||||||
else if (btn==MAGNIFY_PLUS) { _MAGNIFY_PLUS: font.size.text++; if(!font.changeSIZE())font.size.text--; else PreparePage(); }
|
OpenFile(#param);
|
||||||
else if (btn==MAGNIFY_MINUS) { _MAGNIFY_MINUS: font.size.text--; if(!font.changeSIZE())font.size.text++; else PreparePage(); }
|
PreparePage();
|
||||||
else if (btn==CHANGE_ENCODING) { _CHANGE_ENCODING: CreateThread(#menu_rmb,#stak+4092); break; }
|
action_buf = false;
|
||||||
else if (btn==RUN_EDIT) { _RUN_EDIT: io.run("/sys/tinypad",#param); }
|
};
|
||||||
else if (btn==SHOW_INFO) { _SHOW_INFO: ShowAbout(); }
|
draw_window();
|
||||||
break;
|
}
|
||||||
case evReDraw:
|
|
||||||
if (action_buf) {
|
|
||||||
OpenFile(#param);
|
|
||||||
PreparePage();
|
|
||||||
action_buf = false;
|
|
||||||
};
|
|
||||||
draw_window();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -108,17 +240,29 @@ void draw_window()
|
|||||||
DefineAndDrawWindow(Form.left,Form.top,Form.width,Form.height,0x73,0,#title);
|
DefineAndDrawWindow(Form.left,Form.top,Form.width,Form.height,0x73,0,#title);
|
||||||
GetProcessInfo(#Form, SelfInfo);
|
GetProcessInfo(#Form, SelfInfo);
|
||||||
if (Form.status_window>2) return;
|
if (Form.status_window>2) return;
|
||||||
|
|
||||||
if (Form.width < 200) { MoveSize(OLD,OLD,200,OLD); return; }
|
if (Form.width < 200) { MoveSize(OLD,OLD,200,OLD); return; }
|
||||||
if (Form.height < 200) { MoveSize(OLD,OLD,OLD,200); return; }
|
if (Form.height < 200) { MoveSize(OLD,OLD,OLD,200); return; }
|
||||||
|
|
||||||
DrawBar(0, 0, Form.cwidth, TOOLBAR_H - 1, 0xe1e1e1);
|
DrawBar(0, 0, Form.cwidth, TOOLBAR_H - 1, 0xe1e1e1);
|
||||||
DrawBar(0, TOOLBAR_H - 1, Form.cwidth, 1, 0x7F7F7F);
|
DrawBar(0, TOOLBAR_H - 1, Form.cwidth, 1, 0x7F7F7F);
|
||||||
DrawToolbarButton(OPEN_FILE, 8);
|
|
||||||
DrawToolbarButton(MAGNIFY_PLUS, 42);
|
DrawToolbarButton(OPEN_FILE, TOOLBAR_OPEN_FILE_LEFT);
|
||||||
DrawToolbarButton(MAGNIFY_MINUS, 67);
|
DrawToolbarButton(MAGNIFY_PLUS, TOOLBAR_MAGNIFY_PLUS_LEFT);
|
||||||
DrawToolbarButton(CHANGE_ENCODING, 101);
|
DrawToolbarButton(MAGNIFY_MINUS, TOOLBAR_MAGNIFY_MINUS_LEFT);
|
||||||
DrawToolbarButton(RUN_EDIT, 135);
|
DrawToolbarButton(CHANGE_ENCODING, TOOLBAR_CHANGE_ENCODING_LEFT);
|
||||||
DrawToolbarButton(SHOW_INFO, Form.cwidth - 34);
|
DrawToolbarButton(RUN_EDIT, TOOLBAR_RUN_EDIT_LEFT);
|
||||||
if (Form.cwidth-scroll.size_x-1 == list.w) && (Form.cheight-TOOLBAR_H == list.h) && (list.count) DrawPage(); else PreparePage();
|
DrawToolbarButton(SHOW_INFO, Form.cwidth - 34);
|
||||||
|
|
||||||
|
if ((Form.cwidth-scroll.size_x-1 == list.w) &&
|
||||||
|
(Form.cheight-TOOLBAR_H == list.h) &&
|
||||||
|
(list.count)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
DrawPage();
|
||||||
|
} else {
|
||||||
|
PreparePage();
|
||||||
|
}
|
||||||
DrawRectangle(scroll.start_x, scroll.start_y, scroll.size_x, scroll.size_y-1, scroll.bckg_col);
|
DrawRectangle(scroll.start_x, scroll.start_y, scroll.size_x, scroll.size_y-1, scroll.bckg_col);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -138,6 +282,7 @@ void PreparePage()
|
|||||||
dword stroka_y = 5;
|
dword stroka_y = 5;
|
||||||
dword stroka=0;
|
dword stroka=0;
|
||||||
int i, srch_pos;
|
int i, srch_pos;
|
||||||
|
|
||||||
font.changeSIZE();
|
font.changeSIZE();
|
||||||
list.w = Form.cwidth-scroll.size_x-1;
|
list.w = Form.cwidth-scroll.size_x-1;
|
||||||
//get font chars width, need to increase performance
|
//get font chars width, need to increase performance
|
||||||
@ -199,8 +344,8 @@ void PreparePage()
|
|||||||
|
|
||||||
void DrawToolbarButton(char image_id, int x)
|
void DrawToolbarButton(char image_id, int x)
|
||||||
{
|
{
|
||||||
DefineButton(x, 5, 26-1, 24-1, 10+image_id + BT_HIDE, 0);
|
DefineButton(x, 5, TOOLBAR_ICON_WIDTH-1, TOOLBAR_ICON_HEIGHT-1, 10+image_id + BT_HIDE, 0);
|
||||||
img_draw stdcall(skin.image, x, 5, 26, 24, 0, image_id*24);
|
img_draw stdcall(skin.image, x, 5, TOOLBAR_ICON_WIDTH, TOOLBAR_ICON_HEIGHT, 0, image_id*TOOLBAR_ICON_HEIGHT);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawScroller()
|
void DrawScroller()
|
||||||
@ -227,7 +372,7 @@ void OpenFile(dword f_path)
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (list.count) return;
|
if (list.count) return;
|
||||||
io.buffer_data = "This is a plain text reader.\nTry to open some text file.";
|
io.buffer_data = INTRO_TEXT;
|
||||||
strcpy(#title, "Text Reader");
|
strcpy(#title, "Text Reader");
|
||||||
}
|
}
|
||||||
if (encoding!=CH_CP866) ChangeCharset(charsets[encoding], "CP866", io.buffer_data);
|
if (encoding!=CH_CP866) ChangeCharset(charsets[encoding], "CP866", io.buffer_data);
|
||||||
@ -238,9 +383,9 @@ void OpenFile(dword f_path)
|
|||||||
|
|
||||||
|
|
||||||
char *about[] = {
|
char *about[] = {
|
||||||
"Text Reader v1.0",
|
"Text Reader v1.01",
|
||||||
"Idea: Leency, punk_joker",
|
"Idea: Leency, punk_joker",
|
||||||
"Code: Leency, KolibriOS Team",
|
"Code: Leency, Veliant, KolibriOS Team",
|
||||||
" ",
|
" ",
|
||||||
"Hotkeys:",
|
"Hotkeys:",
|
||||||
"Ctrl+O - open file",
|
"Ctrl+O - open file",
|
||||||
@ -259,4 +404,4 @@ ShowAbout() {
|
|||||||
DrawBar(list.x, list.y, list.w, list.h, 0xFFFfff);
|
DrawBar(list.x, list.y, list.w, list.h, 0xFFFfff);
|
||||||
WriteText(list.x + 10, list.y + 10, 10000001b, 0x555555, about[0]);
|
WriteText(list.x + 10, list.y + 10, 10000001b, 0x555555, about[0]);
|
||||||
for (i=1; about[i]; i++) WriteText(list.x + 10, i+1*20 + list.y, 10110000b, 0, about[i]);
|
for (i=1; about[i]; i++) WriteText(list.x + 10, i+1*20 + list.y, 10110000b, 0, about[i]);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user