AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Multimedia Delphi Problem bei Supersampling (Verkleinern einer TBitmap)
Thema durchsuchen
Ansicht
Themen-Optionen

Problem bei Supersampling (Verkleinern einer TBitmap)

Ein Thema von hellboyPS · begonnen am 28. Dez 2009 · letzter Beitrag vom 29. Dez 2009
Antwort Antwort
Benutzerbild von igel457
igel457

Registriert seit: 31. Aug 2005
1.622 Beiträge
 
FreePascal / Lazarus
 
#1

Re: Problem bei Supersampling (Verkleinern einer TBitmap)

  Alt 29. Dez 2009, 00:07
Meiner Weisheit letzter Schluss ist folgender Code, welcher wunderbar Super-gesampelte Bilder erzeugt. Leider ergeben sich helle Striche links und Rechts am Rand, aber ich weiß nicht woher die kommen, und habe jetzt keine Lust mehr danach zu suchen.
Delphi-Quellcode:
const
  ssv = 8; //8-Faches Super-Sampling

type
  TFC = packed record
    r,g,b: Single;
  end;
  PFC = ^TFC;

procedure TForm1.Button1Click(Sender: TObject);
function Cut(ain: single): single;
begin
  result := ain;
  if result > 255 then
    result := 255
  else if result < 0 then
    result := 0;
end;

var
  bitmap: TBitmap;
  re, im, rez, imz, rezold, col: Single;
  a: boolean;
  i, x, y: integer;
  pmem: PFC;
  ps: PFC;
  pi: PInteger;
const
  iterations = 100;
  colchangevar = 1;
begin
  bitmap := TBitmap.Create;
  bitmap.PixelFormat := pf32bit;
  bitmap.Width := Image1.Width;
  bitmap.Height := Image1.Height;

  GetMem(pmem, bitmap.Width * bitmap.Height * SizeOf(TFC));
  ZeroMemory(pmem, bitmap.Width * bitmap.Height * SizeOf(TFC));
  
  for y := 0 to (bitmap.height - 1) * ssv do
  begin
    for x := 0 to (bitmap.width - 1) * ssv do
    begin
      re := (x/bitmap.width/ssv)*4-2; // mit Startwerten zoom = 4, move = -2
      im := (y/bitmap.height/ssv)*4-2;
      rez := 0;
      imz := 0;
      a := true;
      for i := 0 to iterations do
      begin
       if a then
       begin
        rezold := rez;
        rez := rez*rez-imz*imz+re;
        imz := 2*rezold*imz+im;
        if rez*rez+imz*imz > 4 then
         a := false;
       end;
      end;
      if not a then
      begin
       ps := pmem;
       inc(ps, (bitmap.Height) * trunc(y / ssv) + trunc(x/ssv));
       col := (rez*rez+imz*imz)/4*colchangevar;
       col := col+256*col+256*256+col;
       ps^.r := ps^.r + GetRValue(Round(col));
       ps^.g := ps^.g + GetGValue(Round(col));
       ps^.b := ps^.b + GetBValue(Round(col));
      end;
    end;
  end;

  for y := 0 to (bitmap.height - 1) do
  begin
    pi := bitmap.ScanLine[y];
    for x := 0 to (bitmap.width - 1) do
    begin
      inc(pi);
      ps := pmem;
      inc(ps, (bitmap.Height) * y + x);
      pi^ := RGB(
        Round(Cut(ps^.b / (ssv*ssv))),
        Round(Cut(ps^.g / (ssv*ssv))),
        Round(Cut(ps^.r / (ssv*ssv))));
    end;
  end;

  Image1.Picture.Bitmap := bitmap;
end;
Angehängte Grafiken
Dateityp: png mit_341.png (258,2 KB, 24x aufgerufen)
Dateityp: png ohne_150.png (222,5 KB, 18x aufgerufen)
Andreas
"Sollen sich auch alle schämen, die gedankenlos sich der Wunder der Wissenschaft und Technik bedienen, und nicht mehr davon geistig erfasst haben als die Kuh von der Botanik der Pflanzen, die sie mit Wohlbehagen frisst." - Albert Einstein
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:55 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz