AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Image auf Kreisbahn bewegen

Ein Thema von Christian18 · begonnen am 14. Feb 2007 · letzter Beitrag vom 14. Feb 2007
Antwort Antwort
Christian18

Registriert seit: 9. Dez 2003
Ort: Hamburg
1.279 Beiträge
 
#1

Image auf Kreisbahn bewegen

  Alt 14. Feb 2007, 18:41
Hallo,

ich will ein Image auf einer Form bewegen. Das Image soll sich in Kreis bewegen.

Ich habe jetzt spontan keine Idee wie ich das machen könnte.

Der Mittelpunkt des Images soll sich auf dieser Kreisbahn bewegen. Wie kann ich das Problem lösen???

MFG Christian18
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.611 Beiträge
 
#2

Re: Image auf Kreisbahn bewegen

  Alt 14. Feb 2007, 18:44
Du musst die Kreispunkte berechnen (geht aus Mittelpunkt und Radius via Bresenham-Algorithmus). Dann den Offset des Bildes zu seinem Mittelpunkt (- 1/2x höhe, -1/2x breite), und dann schiebst Du diesen Offset einfach auf den Kreispunktenentlang.
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Benutzerbild von Khabarakh
Khabarakh

Registriert seit: 18. Aug 2004
Ort: Brackenheim VS08 Pro
2.876 Beiträge
 
#3

Re: Image auf Kreisbahn bewegen

  Alt 14. Feb 2007, 18:47
Da das Image wohl nicht jeden Pixel eines Kreises einzeln abfahren soll, würde ich lieber zu Sinus & Kosinus in Abhängigkeit von der Zeit greifen .
Sebastian
Moderator in der EE
  Mit Zitat antworten Zitat
benst

Registriert seit: 20. Jun 2004
155 Beiträge
 
Delphi 5 Standard
 
#4

Re: Image auf Kreisbahn bewegen

  Alt 14. Feb 2007, 18:53
Hier mein Vorschlag...
(i ist ein globale Variable)
Delphi-Quellcode:
procedure TForm1.Timer1Timer(Sender: TObject);
var xoffset, yoffset, xradius, yradius, aufloesung: Integer;
begin
  xoffset:=100;
  yoffset:=100;
  xradius:=100;
  yradius:=100;
  aufloesung:=20;

  i:=(i+1) mod round(2*pi*aufloesung);
  Image1.Top:=yoffset+(xradius div 2)+round(xradius*sin(i/aufloesung))-(Image1.height div 2);
  Image1.Left:=xoffset+(yradius div 2)+round(yradius*cos(i/aufloesung))-(Image1.width div 2);
end;
Gruß
Ben
  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 21:16 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz