![]() |
AW: Noten als enum auslegen
Zitat:
Siehe shot oben A ,B genau das was erwartet wird.
Delphi-Quellcode:
Keine Ahnung was du willst?
for k = 0 to xx do
begin end Result := bla; // und hier das result. dort wird ausgewertet wenn die schleife beendet wird auf welchen weg auch immer. Zitat:
Zitat:
Wie ich schon sagte 1 zeile tiefer.
Delphi-Quellcode:
EIne Zeile tiefer vergleiche es!
function TransposeChord(sChord: string; Pitch: Integer): string;
var sResult: string; K, MaxK, Found: Integer; begin sResult := sChord; MaxK := 12; for K := 0 to (MaxK - 1) do begin if cTranspose[TTranspose(K)] = sChord then begin Found := (K + Pitch) mod MaxK; if Found < 0 then inc(Found, MaxK); sResult := cTranspose[TTranspose(Found)]; break; end; end; Result := sResult; end; Vorher stand es über den End nun drunter. gruss |
AW: Noten als enum auslegen
ot
Hör auf so viele geniale Bilder zu Zaigen, da werd ich blass vor Neid! (soll ein Kompliment sein) /ot |
AW: Noten als enum auslegen
Zitat:
In der stand das
Delphi-Quellcode:
innerhalb der For-Schleife, wurde also nicht ausgeführt, wenn die For-Schleife mit Break verlassen wird.
Result:=sResult;
Ich hatte dann u.A. vorgeschlagen das
Delphi-Quellcode:
2 Zeilen nach unten, also hinter die For-Schleife zu verschieben.
Result:=sResult;
Zu diesem Vorschlag hattest du in #19 gesagt Zitat:
Hierzu sagst du Zitat:
Und ja klar bringt die von dir jetzt gezeigte Funktion richtige Ergebnisse, denn sie enthält ja auch die von mir vorgeschlagenen Korrekturen, insbesondere die, das
Delphi-Quellcode:
hinter die For-Schleife zu verschieben.
Result:=sResult;
Mein Einwand bezog sich aber auf deinen Kommentar, dass auch dann wenn man das
Delphi-Quellcode:
so belässt (also innerhalb der For-Schleife), die richtigen Werte übergeben werden.
Result:=sResult;
|
AW: Noten als enum auslegen
Zitat:
Na ok dann habe ich dich falsch verstanden. Entschuldige bitte. Danke! ;) Zitat:
gruss |
AW: Noten als enum auslegen
Delphi-Quellcode:
c_, c, c¯, c⌂, cʭ, c败
Ob auch sowas als Bezeichner erlaubt ist, hab ich jetzt nicht getestet. [edit] Die ersten 4 sind erlaubt, seit 2009. :stupid: ♬ ♮ ♫ ♯ ♮ ![]() ![]() |
AW: Noten als enum auslegen
Zitat:
gruss |
AW: Noten als enum auslegen
Zitat:
Weder direkt per Copy&Paste noch Caption := #$1D120; funktioniert. Ich bekomme da nur Kästchen. Hab auch ein paar gängige Schriftarten ausprobiert :| |
AW: Noten als enum auslegen
Das hat mit den Noten jetzt aber weniger zutun.
|
AW: Noten als enum auslegen
Ja, nicht alle Zeichen sind überall (gut) sichtbar.
Bei ♬ ♮ ♫ ♯ ♮ sehe ich im XE den Letzten auch nur als Kästchen, weil es in der Schrift dieses Zeichen nicht gibt und keine Umleitung zu einer anderen Schrift für dieses Zeichen registriert wurde. Und dazu kommt dann noch, dass bei der gleichbreiten rechteckigen kleinen Schrift im Editor vieles nicht erkennbar ist. Aber grundsätzlich ging es ja nur darum "Noten" als Bezeichner zu verwenden, was prinzipiell geht. Bezeichner unterliegen einer gewissen Syntax (vor dem Unicode-Compiler war sie noch recht simpel, aber inzwischen ist wesentlich mehr erlaubt) Als RegEx
Delphi-Quellcode:
für Delphi 7
^[A-Za-z_][A-Za-z_0-9]*$
und für ab D2009
Delphi-Quellcode:
.
^([[:alnum:]]|_)([[:alnum:]]|_)*$
Delphi-Quellcode:
Aus SysUtils des XE, aber groß wird sich daran nicht viel gändert haben.
function IsValidIdent(const Ident: string; AllowDots: Boolean): Boolean; {$IFNDEF UNICODE} const Alpha = ['A'..'Z', 'a'..'z', '_']; AlphaNumeric = Alpha + ['0'..'9']; AlphaNumericDot = AlphaNumeric + ['.']; var I: Integer; begin Result := False; if (Length(Ident) = 0) or not (Ident[1] in Alpha) then Exit; if AllowDots then for I := 2 to Length(Ident) do begin if not (Ident[I] in AlphaNumericDot) then Exit end else for I := 2 to Length(Ident) do if not (Ident[I] in AlphaNumeric) then Exit; Result := True; end; {$ELSE UNICODE} function Alpha(C: Char): Boolean; inline; begin Result := TCharacter.IsLetter(C) or (C = '_'); end; function AlphaNumeric(C: Char): Boolean; inline; begin Result := TCharacter.IsLetterOrDigit(C) or (C = '_'); end; function AlphaNumericDot(C: Char): Boolean; inline; begin Result := TCharacter.IsLetterOrDigit(C) or (C = '_') or (C = '.'); end; var I: Integer; begin Result := False; if (Length(Ident) = 0) or not Alpha(Ident[1]) then Exit; if AllowDots then for I := 2 to Length(Ident) do begin if not AlphaNumericDot(Ident[I]) then Exit end else for I := 2 to Length(Ident) do if not AlphaNumeric(Ident[I]) then Exit; Result := True; end; {$ENDIF UNICODE} |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:34 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