Обработка графических данных

Автор: Пользователь скрыл имя, 14 Сентября 2011 в 09:28, реферат

Описание работы

Цель: разработать комплекс программ по обработке графических и символьных данных.
Для реализации поставленной цели необходимо решить следующие задачи:
1 Задан список городов. Присвоить переменной Т название города с максимальным числом букв.
2 Дана последовательность, содержащая от 2 до 10 слов, в каждом из которых от 2 до 6 латинских букв; между соседними словами - не менее одного пробела, за последним словом точка. Напечатать все слова, отличные от последнего слова, предварительно преобразовав каждое из них по следующему правилу: перенести первую букву в конец слова.
3 Разработать программу, которая будет выводить на экран график функции y=cos(x).
4 Разработать программу, которая будет отображать движение многоугольника по экрану по принципу угол падения равен углу отражения.

Содержание

Введение ……………………………………………………… 3
1. Обработка символьных данных………………………………… 4
1. 1. Обработка текста …..…………………………………… 4
1. 2. Работа с файлами …………..……………………………11
2. Обработка графических данных ………...………………………21
2. 1. Графические функции …………………………………… 21
2. 2. Движение рисунка ……………………………………… 30
Заключение ……………………………………………………. 34
Список литературы ………………………………………………35
Приложение ……………………………………………….....… 36

Работа содержит 1 файл

курсовая сережи.doc

— 626.00 Кб (Скачать)

'LAB1.DAT'

'c:\ABC150\pr.txt'

'my_files' 

Турбо Паскаль  поддерживает три файловых типа:

  • текстовые файлы;
  • типизированные файлы;
  • нетипизированные файлы.

Доступ к файлу  в программе происходит с помощью  переменных файлового типа. Переменную файлового типа описывают одним из трех способов:

file of тип - типизированный файл (указан тип компоненты); 
text - текстовый файл; 
file - нетипизированный файл.

Стандартные процедуры и функции

Любые дисковые файлы становятся доступными программе после связывания их с файловой переменной, объявленной в программе. Все операции в программе производятся только с помощью связанной с ним файловой переменной.

Assign (f, FileName)

связывает файловую переменную f с физическим файлом, полное имя которого задано в строке FileName. Установленная связь будет действовать до конца работы программы, или до тех пор, пока не будет сделано переназначение.

После связи  файловой переменной с дисковым именем файла в программе нужно указать  направление передачи данных (открыть файл). В зависимости от этого направления говорят о чтении из файла или записи в файл.

Reset (f)

открывает для  чтения файл, с которым связана  файловая переменная f. После успешного выполнения процедуры Reset файл готов к чтению из него первого элемента. Процедура завершается с сообщением об ошибке, если указанный файл не найден.

Если f - типизированный файл, то процедурой reset он открывается для чтения и записи одновременно.

Rewrite (f)

открывает для  записи файл, с которым связана файловая переменная f. После успешного выполнения этой процедуры файл готов к записи в него первого элемента. Если указанный файл уже существовал, то все данные из него уничтожаются.

Close (f)

закрывает открытый до этого файл с файловой переменной f. Вызов процедуры Close необходим при завершении работы с файлом. Если по какой-то причине процедура Close не будет выполнена, файл все-же будет создан на внешнем устройстве, но содержимое последнего буфера в него не будет перенесено.

EOF (f): boolean

возвращает значение TRUE, когда при чтении достигнут конец файла. Это означает, что уже прочитан последний элемент в файле или файл после открытия оказался пуст.  

Rename (f, NewName)

позволяет переименовать  физический файл на диске, связанный  с файловой переменной f. Переименование возможно после закрытия файла.

Erase (f)

уничтожает физический файл на диске, который был связан с файловой переменной f. Файл к моменту вызова процедуры Erase должен быть закрыт.

IOResult

возвращает целое  число, соответствующее коду последней ошибки ввода - вывода. При нормальном завершении операции функция вернет значение 0. Значение функции IOResult необходимо присваивать какой-либо переменной, так как при каждом вызове функция обнуляет свое значение. Функция IOResult работает только при выключенном режиме проверок ошибок ввода - вывода или с ключом компиляции {$I-}.

Работа  с типизированными  файлами

Типизированный  файл - это последовательность компонент  любого заданного типа (кроме типа "файл"). Доступ к компонентам  файла осуществляется по их порядковым номерам. Компоненты нумеруются, начиная с 0. После открытия файла указатель (номер текущей компоненты) стоит в его начале на нулевом компоненте. После каждого чтения или записи указатель сдвигается к следующему компоненту.

Запись в файл:

Write (f, список переменных);

Процедура записывает в файл f всю информацию из списка переменных.

Чтение из файла:

Read (f, список переменных);

Процедура читает из файла f компоненты в указанные  переменные. Тип файловых компонент  и переменных должны совпадать. Если будет сделана попытка чтения несуществующих компонент, то произойдет ошибочное завершение программы. Необходимо либо точно рассчитывать количество компонент, либо перед каждым чтением данных делать проверку их существования (функция eof, см. выше)

Смещение указателя  файла:

Seek (f, n);

Процедура смещает  указатель файла f на n-ную позицию. Нумерация в файле начинается с 0.

Определение количества компонент:

FileSize (f): longint;

Функция возвращает количество компонент в файле  f.

Определение позиции указателя:

FilePos (f): longint;

Функция возвращает порядковый номер текущего компонента файла f.

Отсечение последних  компонент файла:

Truncate (f);

Процедура отсекает конец файла, начиная с текущей  позиции включительно.  

Работа  с текстовыми файлами

Текстовый файл - это совокупность строк, разделенных  метками конца строки. Сам файл заканчивается меткой конца файла. Доступ к каждой строке возможен лишь последовательно, начиная с первой. Одновременная запись и чтение запрещены.

Чтение из текстового файла:

Read (f, список переменных);

ReadLn (f, список переменных);

Процедуры читают информацию из файла f в переменные. Способ чтения зависит от типа переменных, стоящих в списке. В переменную char помещаются символы из файла. В числовую переменную: пропускаются символы-разделители, начальные пробелы и считывается значение числа до появления следующего разделителя. В переменную типа string помещается количество символов, равное длине строки, но только в том случае, если раньше не встретились символы конца строки или конца файла. Отличие ReadLn от Read в том, что в нем после прочтения данных пропускаются все оставшиеся символы в данной строке, включая метку конца строки. Если список переменных отсутствует, то процедура ReadLn (f) пропускает строку при чтении текстового файла.

Запись в текстовый файл:

Write (f, список переменных);

WriteLn (f, список переменных);

Процедуры записывают информацию в текстовый файл. Способ записи зависит от типа переменных в списке (как и при выводе на экран). Учитывается формат вывода. WriteLn от Write отличается тем, что после записи всех значений из переменных записывает еще и метку конца строки (формируется законченная строка файла).

Добавление информации к концу файла:

Append (f)

Процедура открывает  текстовый файл для добавления информации к его концу. Используйте эту процедуру вместо Rewrite.  

Работа  с нетипизированными файлами

Нетипизированные  файлы - это последовательность компонент  произвольного типа.

Открытие нетипизированного  файла:

Reset (f, BufSize)

Rewrite (f, BufSize)

Параметр  BufSize задает число байтов, считываемых из файла или записываемых в него за одно обращение. Минимальное значение BufSize - 1 байт, максимальное - 64 К байт. Если BufSize не указан, то по умолчанию он принимается равным 128.

Чтение данных из нетипизированного файла:

BlockRead (f, X, Count, QuantBlock);

Эта процедура осуществляет за одно обращение чтение в переменную X количества блоков, заданное параметром Count, при этом длина блока равна длине буфера. Значение Count не может быть меньше 1. За одно обращение нельзя прочесть больше, чем 64 К байтов.

Необязательный  параметр QuantBlock возвращает число блоков, прочитанных текущей операцией BlockRead. В случае успешного завершения операции чтения QuantBlock = Count, в случае аварийной ситуации параметр QuantBlock будет содержать число удачно прочитанных блоков. Отсюда следует, что с помощью параметра QuantBlock можно контролировать правильность выполнения операции чтения.

Запись данных в нетипизированный файл:

BlockWrite (f, X, Count, QuantBlock);

Эта процедура  осуществляет за одно обращение запись из переменной X количества блоков, заданное параметром Count, при этом длина блока равна длине буфера.

Необязательный  параметр QuantBlock возвращает число блоков, записанных успешно текущей операцией BlockWrite.

Для не типизированных файлов можно использовать процедуры Seek, FIlePos и FileSize, аналогично соответствующим процедурам типизированных файлов.

 

 Задание 2: Дана последовательность, содержащая от 2 до 10 слов, в каждом из которых от 2 до 6 латинских букв; между соседними словами - не менее одного пробела, за последним словом точка. Напечатать все слова, отличные от последнего слова, предварительно преобразовав каждое из них по следующему правилу, перенести последнюю букву в начало слова

     Набор тестов к программе

  1. Если значению n присвоить значение больше 0, то программа работает неправильно.
  1. Так же значению i присвоить значение больше 0, то программа работает неправильно.
  1. Если же наоборот, то программа пропускает  две строки и начинает работать правильно.
  1. Если врось i и n водить (i:=2, n:=0), то в программе первое слове удаляет первую букву и переносит последнюю.
  1. Если убрать inc, то программа работает не правильно (inc - процедура, увеличивающая значение)
  1. Если между  словами будет пробел >1, то программа работает неправильно
  1. Если не вычитать в цикле for единицу, то программа будет переносить последнюю букву во всех словах.
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

 

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

 

Код программы:

var s, sub:string;

    i, n, k, j:integer;

    a: array [2..10] of string;

begin

     writeln;

     readln(s);

      i:=0; n:=0;

     repeat

       inc(i); 

       if (s[i]= ' ') and (s[i+1] <> ' ')

       then

          begin

               inc(n); 

               a[n]:=sub;

               sub:='';

          end

       else if (s[i] <> ' ') and (s[i] <> '.')

            then sub:=sub+s[i];

     until i=length(s); 

           if sub <> ''

           then

               begin

     until i=length(s); 

              if sub <>''

              then

                  begin

                       inc(n);

                       a[n]:=sub;

                  end;

                   writeln;

     for i:=1 to n-1 do

Информация о работе Обработка графических данных