IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Преобразование цвета битмапа в оттенки серого
сообщение
Сообщение #1





Группа: Пользователи
Сообщений: 3
Пол: Мужской

Репутация: -  0  +


Есть необработанный файл (массив данных). Все это выводится на экран посредством битмапа. Не могу вывести это в оттенках серого. Мучался с палитрой, не вышло. Как?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #2


Гуру
*****

Группа: Пользователи
Сообщений: 1 220
Пол: Мужской

Репутация: -  16  +


Код
Gray := Round((0.30 * GetRValue(RGBColor)) +
                (0.59 * GetGValue(RGBColor)) +
                (0.11 * GetBValue(RGBColor )));
  Result := RGB(Gray, Gray, Gray);
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Ищущий истину
******

Группа: Пользователи
Сообщений: 4 825
Пол: Мужской
Реальное имя: Олег

Репутация: -  45  +


Цитата
Не могу вывести это в оттенках серого.

надеюсь 256 палитра ?
Есть один способ.
заметь, что через каждые 16, в палитре начинается цветвой "блок", там цвета начинаются от светлого к темному (или наоборот - не важно).
а http://forum.pascal.net.ru/index.php?showtopic=9037&hl= вот тут я указывал, что от 16 до 32 идет ч\б палитра.
Попробуй сопоставить каждому цвету , цвет из этого интервала.

Это вариант преобразования без смены палитры.
Есть конечно вариант со сменой палитры.

вот пример для следующих режимов: VGA, VESA и еще какого-то нестандартного режима,
Инициализация режимов (на всякий случай)...

asm
{$IFDEF VGA}
mov ax,13h { for VGA adapter: 320x200x256 }
{$ENDIF}
{$IFDEF CIRRUS}
mov ax,5Fh { for Cirrus Logic adapter: 640x480x256 }
{$ENDIF}
{$IFDEF VESA}
mov ax,4F02h { for VESA-compatible adapter: 640x480x256 }
mov bx,101h
{$ENDIF}
int 10h
end;

а вот смена палитры:
procedure SetPalette; assembler;		{ гбв ­®ўЄ  Ї «Ёвал }
asm
mov si,word ptr BufPal
mov bx,0
mov dh,63
mov ch,dh
mov cl,dh
mov ax,1010h
int 10h
@1:
mov dl,[si]
@2:
add dh,[si+1]
add ch,[si+2]
add cl,[si+3]
inc bx
mov ax,1010h
int 10h
dec dl
jnz @2
add si,4
cmp byte ptr [si],0
jne @1
end;

если теперь строки

  add	dh,[si+1]
add ch,[si+2]
add cl,[si+3]


заменить на
  add	dh,[si+1]
add ch,[si+1]
add cl,[si+1]


то получим генерацию ч\б палитры.
т.е. вот так:
procedure SetPalette; assembler;		{ гбв ­®ўЄ  Ї «Ёвал }
asm
mov si,word ptr BufPal
mov bx,0
mov dh,63
mov ch,dh
mov cl,dh
mov ax,1010h
int 10h
@1:
mov dl,[si]
@2:
add dh,[si+1]
add ch,[si+1]
add cl,[si+1]
inc bx
mov ax,1010h
int 10h
dec dl
jnz @2
add si,4
cmp byte ptr [si],0
jne @1
end;

Вот тебе полезный модуль:
unit Global;

interface

{$DEFINE VESA}

const
MaxX = 640; { а §аҐиҐ­ЁҐ Ї® Ј®аЁ§®­в «Ё }
MaxY = 480; { а §аҐиҐ­ЁҐ Ї® ўҐавЁЄ «Ё }
NumPal = 256 * 3 - 1;


type
Line = array[0..MaxX] of byte;
PLine = ^Line;
BlockPal = array[0..NumPal] of byte;
PBlockPal = ^BlockPal;

function GetPixel( X, Y: word ): byte;
{inline( $5A/ { pop dx }
{ $59/ { pop cx }
{ $B4/$0D/ { mov ah,0Dh }
{ $B7/$00/ { mov bh,0 }
{ $CD/$10 ); { int 10h }

procedure SetPixel( X, Y: word; Color: byte );
{inline( $58/ { pop ax }
{ $5A/ { pop dx }
{ $59/ { pop cx }
{ $B4/$0C/ { mov ah,0Ch }
{ $B7/$00/ { mov bh,0 }
{ $CD/$10 ); { int 10h }

procedure GetPalette( Buffer: PBlockPal );

procedure SetPalette( BufPal: pointer );

procedure SetAllPalette( Buffer: PBlockPal );

procedure GetLine( Buffer: PLine; NumLine: word );

procedure SetLine( Buffer: PLine; NumLine: word );


implementation

procedure SetPixel; assembler; { ®ваЁб®ўЄ в®зЄЁ }
asm
mov ax,MaxX
mul Y
add ax,X
mov di,ax
{$IFNDEF VGA}
adc dl,0
mov ah,dl
{$ENDIF}
{$IFDEF CIRRUS}
shl ah,4
mov al,9
mov dx,$3CE
out dx,ax
{$ENDIF}
{$IFDEF VESA}
mov ax,$4F05
push ax
push dx
xor bx,bx
int 10h
pop dx
pop ax
inc bx
int 10h
{$ENDIF}
mov ax,$A000
mov es,ax
mov al,Color
stosb
end;

function GetPixel; assembler; { Ї®«г祭ЁҐ 梥в в®зЄЁ }
asm
mov ax,MaxX
mul Y
add ax,X
mov di,ax
{$IFNDEF VGA}
adc dl,0
mov ah,dl
{$ENDIF}
{$IFDEF CIRRUS}
shl ah,4
mov al,9
mov dx,$3CE
out dx,ax
{$ENDIF}
{$IFDEF VESA}
mov ax,$4F05
push ax
push dx
xor bx,bx
int 10h
pop dx
pop ax
inc bx
int 10h
{$ENDIF}
mov ax,$A000
mov es,ax
mov al,es:[di]
end;

procedure GetPalette; assembler; { Ї®«г祭ЁҐ ⥪г饩 Ї «Ёвал }
asm
mov ax,1017h
les dx,Buffer
mov bx,0
mov cx,256
int 10h
end;

procedure SetPalette; assembler; { гбв ­®ўЄ Ї «Ёвал }
asm
mov si,word ptr BufPal
mov bx,0
mov dh,63
mov ch,dh
mov cl,dh
mov ax,1010h
int 10h
@1:
mov dl,[si]
@2:
add dh,[si+1]
add ch,[si+2]
add cl,[si+3]
inc bx
mov ax,1010h
int 10h
dec dl
jnz @2
add si,4
cmp byte ptr [si],0
jne @1
end;

procedure SetAllPalette; assembler;
asm
les dx,Buffer
mov ax,1012h
mov bx,0
mov cx,256
int 10h
end;

procedure GetLine;
var
Cnt: word;
begin
for Cnt := 0 to MaxX - 1 do Buffer^[Cnt] := GetPixel( Cnt, NumLine )
end;

procedure SetLine;
var
Cnt: word;
begin
for Cnt := 0 to MaxX - 1 do SetPixel( Cnt, NumLine, Buffer^[Cnt] )
end;

end.

а вот пример его использования:
uses 
crt, Global;


const
MaxIter = 1000; { ¬ ЄбЁ¬ «м­®Ґ зЁб«® ЁвҐа жЁ© }
MaxColor = 250; { зЁб«® 梥⮢ }

const { Ї «Ёвал }
Palette1: array[1..37] of shortint = ( 21,-3,0,0,31,2,-2,0,31,0,2,-2,31,-2,
0,2,21,0,-3,0,31,2,0,-2,31,-2,2,0,31,0,-2,2,21,0,0,-3,0 );
Palette2: array[1..37] of shortint = ( 21,-3,0,0,31,1,-2,-1,31,1,1,-1,31,-2,
1,2,21,0,-3,0,31,2,1,-1,31,-1,1,-1,31,-1,-2,2,21,0,0,-3,0 );
Palette3: array[1..37] of shortint = ( 21,-3,0,0,31,1,-2,-1,31,1,1,-1,31,-2,
1,2,21,0,-3,0,31,1,2,-2,31,1,-1,1,31,-2,-1,1,21,0,0,-3,0 );
Palette4: array[1..37] of shortint = ( 21,0,0,-3,31,-2,0,2,31,2,-2,0,31,0,
2,-2,21,-3,0,0,31,0,-2,2,31,2,0,-2,31,-2,2,0,21,0,-3,0,0 );
Palette5: array[1..45] of shortint = ( 15,-4,0,0,1,-3,0,0,31,1,-2,0,31,1,1,-2,
31,-2,1,1,31,1,-2,1,31,1,1,-2,31,-2,1,1,31,0,-2,1,1,0,0,-3,15,0,0,-4,0 );
Palette6: array[1..69] of shortint = ( 9,-7,0,0,21,3,0,-3,9,0,-7,0,21,-3,0,3,
9,7,0,0,21,0,3,-3,9,-7,0,0,21,3,0,3,9,0,-7,0,21,-3,3,0,9,0,0,-7,
21,3,-3,0,21,0,3,3,9,0,0,-7,21,-3,0,3,9,0,0,-7,9,0,-7,0,0 );


{$DEFINE VESA}
begin
{init graph mode}
asm
{$IFDEF VGA}
mov ax,13h { for VGA adapter: 320x200x256 }
{$ENDIF}
{$IFDEF CIRRUS}
mov ax,5Fh { for Cirrus Logic adapter: 640x480x256 }
{$ENDIF}
{$IFDEF VESA}
mov ax,4F02h { for VESA-compatible adapter: 640x480x256 }
mov bx,101h
{$ENDIF}
int 10h
end;
SetPalette( @Palette1 ); { Ї® 㬮«з ­Ёо 1-п Ї «Ёва }


{что-то вывели }

case ReadKey of
'1': SetPalette( @Palette1 ); { жЁдал ®в 1 ¤® 6 ¬Ґ­пов Ї «Ёваг }
'2': SetPalette( @Palette2 );
'3': SetPalette( @Palette3 );
'4': SetPalette( @Palette4 );
'5': SetPalette( @Palette5 );
'6': SetPalette( @Palette6 )
end;
{в текст mode}
asm
mov ax,3 { гбв ­®ўЁвм ⥪бв®ўл© аҐ¦Ё¬ 80е25 }
int 10h
end
end.


--------------------
Помогая друг другу, мы справимся с любыми трудностями!
"Не опускать крылья!" (С)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4





Группа: Пользователи
Сообщений: 3
Пол: Мужской

Репутация: -  0  +


То Altair: спасибо, этот модуль пригодится. Но хотелось бы под виндовс подкопаться без ассемблера. Скорее нужно рыть в сторону заголовка. У меня не проходит следующий код:
Код


var
  LogPalette: PLogPalette;
  I: Integer;
  begin  

  GetMem(LogPalette,  SizeOf(TLogPalette) + (NumShades-1)*SizeOf(TPaletteEntry));
   LogPalette.palVersion := $300;
   LogPalette.palNumEntries := 256;
   for I := 0 to 256 do
     begin
       LogPalette.palPalEntry[I].peRed  := I;
       LogPalette.palPalEntry[I].peGreen := I;
       LogPalette.palPaLEntry[I].peBlue := I;
       LogPalette.palPalEntry[I].peFlags := 0;
      end;

     Result := CreatePalette(LogPalette^);
     FreeMem(LogPalette)



В общем result напрямую присваиваю в один из параметров структуры HBitmap. Не проходит.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #5





Группа: Пользователи
Сообщений: 3
Пол: Мужской

Репутация: -  0  +


Все. Тема закрыта. Спасибо за ответы.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #6


Ищущий истину
******

Группа: Пользователи
Сообщений: 4 825
Пол: Мужской
Реальное имя: Олег

Репутация: -  45  +


Цитата
Но хотелось бы под виндовс подкопаться без ассемблера

Так надо было сразу скзаать, что ты в 32 бита пишешь. Есть ведь специальный форум для этого.
Цитата
Все. Тема закрыта. Спасибо за ответы.

Жалко конечно, что ты не сказал как решил проблемму.

Заходи на форум еще !


--------------------
Помогая друг другу, мы справимся с любыми трудностями!
"Не опускать крылья!" (С)
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 11.01.2025 5:24
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name