Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Содержание сайт... 65535
Вызов хранимых ... 65535
Эмулятор микроп... 65535
Приложение «Про... 64233
Организация зап... 62819
Оператор выбора... 62675
Invision Power ... 62219
Подключение Mic... 61038
Модуль Forms 59935
Создание отчето... 59864
ТЕХНОЛОГИИ ДОСТ... 56078
Программируемая... 55600
Пример работы с... 53188
Имитационное мо... 51450
21 ошибка прогр... 46437
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

Пользователей: 13,057
новичок: Aidar
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Программа тестирования и обучающая программа по математике на Turbo Pasc...
Моделирование круглосуточного интернет кафе на GPSS + Отчет
Моделирование работы крупного аэропорта на GPSS + Пояснительная записка

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Чтение структуры PCX файла
procedure TForm1.ReadPicture(Header:HeaderType; Palette:Palette256; FileName: string);
var f:file; Rep,Desc,p:byte; i,x,y:word;
begin
AssignFile(f,FileName);
reset(f,1);
// seek(F,129);
if Header.BitPerPixel=8 then seek(F,129);
if Header.BitPerPixel=4 then seek(F,128);
blockread(f,Rep,1);
x:=0;
y:=0;
repeat //for i:=1 to Header.Xend do
if Rep>=192 then
begin
Rep:=Rep-192;
if Header.BitPerPixel=4 then Rep:=Rep*2;
//if Header.BitPerPixel=4 then Rep:=(Rep-192)*2
// else if Header.BitPerPixel=8 then Rep:=Rep-192; blockread(f,Desc,1);
//Rep:=Rep-192;
blockread(f,Desc,1);

for i:=1 to Rep do
begin
//Image1.Canvas.Pixels[x,y]:=Header.Palette[Desc];
if Header.BitPerPixel=4 then
begin
Desc:=Desc and $0F;
Image1.Canvas.Pixels[x,y]:=Header.Palette[1,Desc]
+(integer(Header.Palette[2,Desc]) shl 8)+
+(integer(Header.Palette[3,Desc]) shl 16)
end
else
if Header.BitPerPixel=8 then
Image1.Canvas.Pixels[x,y]:=Palette.Colors[1,Desc]
+(integer(Palette.Colors[2,Desc]) shl 8)+
+(integer(Palette.Colors[3,Desc]) shl 16);
if x>=Header.Xend then begin
y:=y+1;
x:=0
end
else x:=x+1;

end;
blockread(f,Rep,1);
end
else
begin
//Image1.Canvas.Pixels[x,y]:=//Header.Palette[Desc];
if Header.BitPerPixel=4 then p:=2
else if Header.BitPerPixel=8 then p:=1;
for i:=1 to p do
begin
if Header.BitPerPixel=4 then
begin
Rep:=Rep and $0F;
Image1.Canvas.Pixels[x,y]:=Header.Palette[1,Rep]
+(integer(Header.Palette[2,Rep]) shl 8)+
+(integer(Header.Palette[3,Rep]) shl 16)
end
else
if Header.BitPerPixel=8 then
Image1.Canvas.Pixels[x,y]:=Palette.Colors[1,Rep]
+(integer(Palette.Colors[2,Rep]) shl 8)+
+(integer(Palette.Colors[3,Rep]) shl 16);
if x>=Header.Xend then begin
y:=y+1;
x:=0
end
else x:=x+1;
end;
blockread(f,Rep,1);
end
until (Filepos(f)>=Filesize(F)-769){or((x>=Header.Xend)and(y>=Header.Yend))};
CloseFile(F);
end;




Чтение заголовка:

procedure TForm1.HeaderRead(var Header: HeaderType; var Palette:Palette256; FileName: string);
var f:file; i,j:byte;
begin
Label1.Caption:='Identifier'+#13+'Version'+#13+'Encoding'+#13+'BitPerPixel'
+#13+'Xstart'+#13+'Ystart'+#13+'Xend'+#13+'Yend'+#13+'HorizRez'+#13+
'VertRez'+#13+'Palette'+#13+#13+#13+'VideoMode'+#13+'NumBitPlanes'+#13+'BytesPerLine'
+#13+'PaletteType'+#13+'HorizScrSize'+#13+'VertScrSize'+#13+'Palette';


AssignFile(f,FileName);
reset(f,1);
blockread(f,Header.Identifier,1);
if Header.Identifier<>10 then begin
showmessage('Неверное изображение');
exit
end;
blockread(f,Header.Version,1);
blockread(f,Header.Encoding,1);
blockread(f,Header.BitPerPixel,1);
blockread(f,Header.Xstart,2);
blockread(f,Header.Ystart,2);
blockread(f,Header.Xend,2);
blockread(f,Header.Yend,2);
blockread(f,Header.HorizRez,2);
blockread(f,Header.VertRez,2);
for j:=0 to 15 do
begin
for i:=1 to 3 do
begin
blockread(f,Header.Palette[i,j],1);
//Header.Palette[i,j]:=Header.Palette[i,j] shr 3;
end;
end;
{for j:=1 to 16 do
begin
blockread(f,Header.Palette[j],3);
end;}
blockread(f,Header.VideoMode,1);
blockread(f,Header.NumBitPlanes,1);
blockread(f,Header.BytesPerLine,2);
blockread(f,Header.PaletteType,2);
blockread(f,Header.HorizScrSize,2);
blockread(f,Header.VertScrSize,2);
seek(F,Filesize(F)-769);
blockread(f,Palette.PaletteType,1);
{for i:=1 to 3 do
begin
for j:=0 to 255 do
begin
blockread(f,Palette.Colors[i,j],1);
//Palette.Colors[i,j]:=Palette.Colors[i,j] or $3F;
end;
end;}
for j:=0 to 255 do
begin
for i:=1 to 3 do
begin
blockread(f,Palette.Colors[i,j],1);
//Palette.Colors[i,j]:=Palette.Colors[i,j] div 4;
end;
end;
CloseFile(F);
Form1.Label2.Caption:='';
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Identifier)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Version)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Encoding)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.BitPerPixel)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Xstart)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Ystart)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Xend)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.Yend)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.HorizRez)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.VertRez);
for i:=1 to 3 do
begin
Form1.Label2.Caption:=Form1.Label2.Caption+#13;
for j:=0 to 15 do
begin
Form1.Label2.Caption:=Form1.Label2.Caption
+inttohex(Header.Palette[i,j],2)+' ';
end;
end;
{for j:=1 to 16 do
begin
Form3.Label2.Caption:=Form3.Label2.Caption
+inttostr(Header.Palette[j])+' ';
end;}
Form1.Label2.Caption:=Form1.Label2.Caption+#13+inttostr(Header.VideoMode)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.NumBitPlanes)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.BytesPerLine)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.PaletteType)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.HorizScrSize)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Header.VertScrSize)+#13;
Form1.Label2.Caption:=Form1.Label2.Caption+inttostr(Palette.PaletteType)+#13;
for i:=1 to 3 do
begin
for j:=0 to 255 do
begin
Form1.Label2.Caption:=Form1.Label2.Caption
+inttohex(Palette.Colors[i,j],2)+' ';
end;
Form1.Label2.Caption:=Form1.Label2.Caption+#13;
end;
end;





http://www.ekbforex.ru/publ/strategii_foreks/13
Опубликовал Kest January 26 2009 14:31:17 · 0 Комментариев · 10612 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Керниган Б.В., Ри...
DeleteEdit
SODA [Исходник на...
XPButtons
Plasma
ShadelLabel
Краснов М. - Open...
Реализация ЭЦП по...
TmxOutlookBarPro
Adapter (пример D...
Print Grid
Популярные загрузки
Delphi. Готовые а...
Редактор анимаций
База каталогов ( ...
ProLIB18
Основы Delphi. Пр...
Прграммирование в...
С. Г. Горнаков - ...
Billenium Effects...

Топ загрузок
Приложение Клие... 100366
Delphi 7 Enterp... 82180
Converter AMR<-... 20046
Borland C++Buil... 11050
GPSS World Stud... 10421
Borland Delphi ... 8035
Turbo Pascal fo... 6959
Visual Studio 2... 4961
Калькулятор [Ис... 4259
FreeSMS v1.3.1 3508
Случайные статьи
Добавление медиако...
Как писать правиль...
Работа с сообщением
Переключитесь в ре...
Заблуждения и недо...
Особенности функци...
Еще один образец п...
Формирование прогр...
Сейчас в Интернете...
Как узнать - прису...
ВОСХОДЯЩАЯ РЕКУРСИЯ
Скорость процессора
Сортировка простым...
дня использовать в...
Обход дерева
Модуль Hypertext
5.1. От псевдокода...
Поток без синхрони...
Установка модуля A...
Списки
TABULATE (ЗАНЕСТИ ...
Параметры восстано...
Массивы и классы, ...
Сколько по времени...
ЖК-дисплей фотоапп...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?