vb@rchiv
VB Classic
VB.NET
ADO.NET
VBA
C#
TOP-Angebot: 17 bzw. 24 Entwickler-Vollversionen zum unschlagbaren Preis!  
 vb@rchiv Quick-Search: Suche startenErweiterte Suche starten   Impressum  | Datenschutz  | vb@rchiv CD Vol.6  | Shop Copyright ©2000-2024
 
zurück

 Sie sind aktuell nicht angemeldet.Funktionen: Einloggen  |  Neu registrieren  |  Suchen

Fortgeschrittene Programmierung
Re: [VB6] RTF Control und Sonderzeichen (128 bis 160) 
Autor: ManiB
Datum: 11.08.07 17:20

Hallo zusammen,

ich hab's jetzt gelöst.
Es liegt an der Codepage, die zu meinem Font eingestellt werden muss. Wenn man die nicht explizit angibt, erscheinen andere Zeichen!

Für alle die es interessiert, hier meine Lösung:

'------------------------------------------------------
' Wandelt String in RTF-Sequenz
'------------------------------------------------------
Function RtfContent(strFileContent As String) As String
 
    Dim strTxt As String
    Dim strRtf As String
    Dim i As Integer
    Dim ch As String
    Dim CharCode As Integer
 
    strTxt = strFileContent
    If CBool(InStr(strTxt, "\")) Then _
        strTxt = Replace(strTxt, "\", "\\") 'RTF-Steuerzeichen \ ersetzen
    If CBool(InStr(strTxt, "{")) Then _
        strTxt = Replace(strTxt, "{", "\{") 'RTF-Steuerzeichen { ersetzen
    If CBool(InStr(strTxt, "}")) Then _
        strTxt = Replace(strTxt, "}", "\}") 'RTF-Steuerzeichen } ersetzen
 
    strRtf = "{\rtf1\ansi\ansicpg1252{" 'RTF-Start, Codepage 1252 einstellen
    For i = 1 To Len(strTxt)
        ch = Mid(strTxt, i, 1) 'Zeichen
        CharCode = Asc(ch) 'Zeichencode (0 bis 255)
        If CharCode < 32 Then
            'Steuerzeichen
            strRtf = strRtf & Chr$(CharCode)
            If CharCode = 10 Then strRtf = strRtf & "\par " 'Zeilenumbruch
        ElseIf CharCode < 128 Then
            'Standardzeichen
            strRtf = strRtf & ch
        Else
            'Sonderzeichen
            strRtf = strRtf & "\'" & Right("00" & Hex(CharCode), 2)
        End If
    Next i
    strRtf = strRtf & "}}" 'RTF-Abschluss
 
    RtfContent = strRtf
 
End Function
 
 
Sub OpenFile(PathAndFilename As String)
 
    Dim strFileContent As String
    Dim strRtfContent As String
    Dim FileNr1 As Long
 
    FileNr1 = FreeFile
    Open PathAndFilename For Input As #FileNr1
 
    strFileContent = Input(LOF(FileNr1), FileNr1)
    strRtfContent = RtfContent(strFileContent)
    RichTextBox1.TextRTF = strRtfContent
 
End Sub

Ciao,
Manfred Becker

alle Nachrichten anzeigenGesamtübersicht  |  Zum Thema  |  Suchen

 ThemaViews  AutorDatum
[VB6] RTF Control und Sonderzeichen (128 bis 160)1.356ManiB09.08.07 18:52
Re: [VB6] RTF Control und Sonderzeichen (128 bis 160)1.104ManiB11.08.07 17:20

Sie sind nicht angemeldet!
Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.

Einloggen  |  Neu registrieren

Funktionen:  Zum Thema  |  GesamtübersichtSuchen 

nach obenzurück
 
   

Copyright ©2000-2024 vb@rchiv Dieter Otter
Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.

Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel