Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 4 229

/ вопрос открыт /

Здравствуйте!
помогите пожалуйста исправить ошибку в нижепредставленном коде. 2 месяца уже не могу понять что не так работает. код предназначен для многошаговой операции отмены действий в текстовом редакторе через сохранение на каждый richedit.modified в TObjectList потока со всеми данными находящимися в Richedit. или подскажите как модифицировать код чтобы сохранялось в список только сделанное действие, а не весь текст.. (listview в коде предназначен для графического отображения текущего состояния элемента в потоке)

Приложение:
  1. var
  2. Form1: TForm1;
  3. UndoList: TObjectList;
  4. i:integer;
  5. L:TListItem;
  6. CurCount: integer;
  7. implementation
  8.  
  9. {$R *.dfm}
  10.  
  11. procedure TForm1.RedoButtonClick(Sender: TObject);
  12. var
  13. S: TMemoryStream;
  14. begin
  15. if CurCount>=0 then begin
  16.  
  17. s:=UndoList[ CurCount + 1 ] as TMemoryStream;
  18. assert(s <> nil);
  19. Richedit.OnChange := nil;
  20. Richedit.lines.LoadFromStream(s);
  21. Richedit.Modified := False;
  22. Richedit.OnChange := RicheditChange;
  23. CurCount:= CurCount+1;
  24. ListView.ItemIndex:=CurCount;
  25. end;
  26. end;
  27.  
  28. procedure TForm1.RichEditChange(Sender: TObject);
  29. var
  30. s:TMemoryStream;
  31. begin
  32. if Richedit.Modified then begin
  33. s:=TMemoryStream.create;
  34. Richedit.Lines.SaveToStream(s);
  35. s.seek(0, soFromBeginning);
  36. UndoList.add(s);
  37. CurCount:= UndoList.Count;
  38. L:= ListView.Items.Add;
  39. L.Caption:=inttostr(CurCount);
  40. ListView.ItemIndex:=CurCount-1;
  41. end;
  42. end;
  43.  
  44. procedure TForm1.FormCreate(Sender: TObject);
  45. begin
  46. UndoList:= TObjectList.Create( True );
  47. end;
  48.  
  49. procedure TForm1.FormDestroy(Sender: TObject);
  50. begin
  51. UndoList.Free;
  52. end;
  53.  
  54. procedure TForm1.UndoButtonClick(Sender: TObject);
  55. var
  56. S: TMemoryStream;
  57. begin
  58. if CurCount >= 0 then begin
  59. s:=UndoList[CurCount - 1 ] as TMemoryStream;
  60. assert(s <> nil);
  61. Richedit.OnChange := nil;
  62. Richedit.lines.LoadFromStream(s);
  63. Richedit.Modified := False;
  64. Richedit.OnChange := RicheditChange;
  65. CurCount:=CurCount-1;
  66. ListView.ItemIndex:=CurCount;
  67. end;
  68. end;
  69. procedure TForm1.sclrbx1Change(Sender: TObject);
  70. begin
  71. Richedit.SelAttributes.Color:=sclrbx1.Selected;
  72. end;
  73.  
  74. end.


DeLF Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: DeLF (статус: Посетитель)
Вопрос отправлен: 25 мая 2010, 23:27
Состояние вопроса: открыт, ответов: 0.


Мини-форум вопроса

Всего сообщений: 4; последнее сообщение — 26 мая 2010, 11:13; участников в обсуждении: 2.
DeLF

DeLF (статус: Посетитель), 25 мая 2010, 23:48 [#1]:

забыл про суть ошибки. при первом нажатии кнопки нечего не происходит, кроме того что курсор из ричедита кудато убирается. после второго нажатия начинает делать откат по списку, но 1 элемент остается лишним, после отката которого вылетает "list out of bounds -1". кнопка redo вобще чистит полностью Ричедит.
min@y™

min@y™ (статус: Доктор наук), 26 мая 2010, 08:16 [#2]:

Цитата (DeLF):

но 1 элемент остается лишним, после отката которого вылетает "list out of bounds -1"

Ну, здесь всё очевидно.
procedure TForm1.UndoButtonClick(Sender: TObject);
var
  S: TMemoryStream;
begin
 if CurCount >= 0 then begin
    s:=UndoList[CurCount - 1 ] as TMemoryStream; // При CurCount = 0: "list out of bounds -1"
    assert(s <> nil);
    Richedit.OnChange := nil;
    Richedit.lines.LoadFromStream(s);
    Richedit.Modified := False;
    Richedit.OnChange := RicheditChange;
    CurCount:=CurCount-1;
    ListView.ItemIndex:=CurCount;
    end;
end;

Для выяснения остального воспользуйся отладчиком. Он для этого и предназначен.
З.Ы. Есть компонент TRxRichEdit, в котором реализованы Undo и Redo. Посмотри его исходник, может пригодиться.
Делаю лабы и курсачи по Delphi и Turbo Pascal. За ПИВО! Пишите в личку, а лучше в аську. А ещё лучше - звоните в скайп!
DeLF

DeLF (статус: Посетитель), 26 мая 2010, 10:57 [#3]:

копался я в его исходнике, но я начинающий, и либо там нечего нету, либо я не знаю где смотреть...
min@y™

min@y™ (статус: Доктор наук), 26 мая 2010, 11:13 [#4]:

Цитата (DeLF):

копался я в его исходнике, но я начинающий, и либо там нечего нету, либо я не знаю где смотреть...

Если ты начинающий, то лучше тогда и не копайся.
Ковыряй свой код в дебаггере, ищи логические ошибки, если что-то работает неверно.
Делаю лабы и курсачи по Delphi и Turbo Pascal. За ПИВО! Пишите в личку, а лучше в аську. А ещё лучше - звоните в скайп!

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 16:49
Выполнено за 0.02 сек.