Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Java/Pascal] Графическая программа 
:(
    Опции темы
DDV
Дата 24.12.2007, 00:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 25.10.2006

Репутация: нет
Всего: нет



Есть программа написанная на поскаль, надо написать программу делающую тоже самое только на Java (точное совпадение не обязательно). Это первое задание за семестр НА ЗАЧЕТ! Буду очень благодарен если кто-нибудь поможет +)

Код
program treugolnik;
uses crt,graph;
var xa,ya,xb,yb,xc,yc,driver,mode: integer;
n: byte;

Procedure EgaDrv; External; 
{$L EGAVGA.OBJ }

procedure tria(xa,ya,xb,yb,xc,yc:integer;n:byte);
var xq,yq,xp,yp,xr,yr:integer;
begin
if n<>0 then begin
xp:=(xb+xc)div 2;
yp:=(yb+yc)div 2;
xq:=(xc+xa)div 2;
yq:=(yc+ya)div 2;
xr:=(xa+xb)div 2;
yr:=(ya+yb)div 2;
tria(xa,ya,xq,yq,xr,yr,n-1);
tria(xq,yq,xc,yc,xp,yp,n-1);
tria(xp,yp,xr,yr,xb,yb,n-1);
line(xq,yq,xp,yp);
line(xp,yp,xr,yr);
line(xq,yq,xr,yr)
end;
begin
if n=0 then setcolor(11);
if n=1 then setcolor(10);
if n=2 then setcolor(12);
if n=3 then setcolor(13);
if n=4 then setcolor(14);
if n=5 then setcolor(15);
if n=6 then setcolor(16);
end;
end;

begin
if RegisterBGIdriver(@EGADrv) < 0 then
halt(3);

driver := Detect;
mode := 0;
initgraph(driver,mode,'');

n:=0;
for n:=0 to 6 do
begin
readkey;

cleardevice;
setcolor(0);
xa:=getmaxx;ya:=getmaxy;
xc:=getmaxx;yc:=0;
xb:=0;yb:=0;
line(xa,ya,xb,yb);
line(xb,yb,xc,yc);
line(xa,ya,xc,yc);
tria(xa,ya,xb,yb,xc,yc,n);
xa:=0; ya:=0;
xc:=0; yc:=getmaxy;
xb:=getmaxx; yb:=getmaxy;
tria(xa,ya,xb,yb,xc,yc,n);
end;
readkey;
readln;
closegraph;
end.program treugolnik;
uses crt,graph;
var xa,ya,xb,yb,xc,yc,driver,mode: integer;
n: byte;

Procedure EgaDrv; External; 
{$L EGAVGA.OBJ }

procedure tria(xa,ya,xb,yb,xc,yc:integer;n:byte);
var xq,yq,xp,yp,xr,yr:integer;
begin
if n<>0 then begin
xp:=(xb+xc)div 2;
yp:=(yb+yc)div 2;
xq:=(xc+xa)div 2;
yq:=(yc+ya)div 2;
xr:=(xa+xb)div 2;
yr:=(ya+yb)div 2;
tria(xa,ya,xq,yq,xr,yr,n-1);
tria(xq,yq,xc,yc,xp,yp,n-1);
tria(xp,yp,xr,yr,xb,yb,n-1);
line(xq,yq,xp,yp);
line(xp,yp,xr,yr);
line(xq,yq,xr,yr)
end;
begin
if n=0 then setcolor(11);
if n=1 then setcolor(10);
if n=2 then setcolor(12);
if n=3 then setcolor(13);
if n=4 then setcolor(14);
if n=5 then setcolor(15);
if n=6 then setcolor(16);
end;
end;

begin
if RegisterBGIdriver(@EGADrv) < 0 then
halt(3);

driver := Detect;
mode := 0;
initgraph(driver,mode,'');

n:=0;
for n:=0 to 6 do
begin
readkey;

cleardevice;
setcolor(0);
xa:=getmaxx;ya:=getmaxy;
xc:=getmaxx;yc:=0;
xb:=0;yb:=0;
line(xa,ya,xb,yb);
line(xb,yb,xc,yc);
line(xa,ya,xc,yc);
tria(xa,ya,xb,yb,xc,yc,n);
xa:=0; ya:=0;
xc:=0; yc:=getmaxy;
xb:=getmaxx; yb:=getmaxy;
tria(xa,ya,xb,yb,xc,yc,n);
end;
readkey;
readln;
closegraph;
end.

PM MAIL   Вверх
LSD
Дата 26.12.2007, 11:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 9
Всего: 538



Еще актуально?


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
DDV
Дата 26.12.2007, 13:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 29
Регистрация: 25.10.2006

Репутация: нет
Всего: нет



Цитата(LSD @ 26.12.2007,  11:47)
Еще актуально?

Да, буду очень благодарен если поможешь.
PM MAIL   Вверх
LSD
Дата 27.12.2007, 13:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 9
Всего: 538



Код

import java.awt.Color;
import java.awt.Dimension;
import java.awt.Graphics;

import javax.swing.JFrame;
import javax.swing.JPanel;

public class Tria extends JPanel
{
  private static final long serialVersionUID = -2625006498681736373L;
  
  public static final int MAX_X = 640;
  public static final int MAX_Y = 480;

  private int xa, ya, xb, yb, xc, yc;

  public Tria()
  {
    setPreferredSize(new Dimension(MAX_X, MAX_Y));
  }

  @Override
  protected void paintComponent(Graphics g)
  {
    xa = getWidth();
    ya = getHeight();
    xc = getWidth();
    yc = 0;
    xb = 0;
    yb = 0;

    for (int n = 0; n < 7; n++)
    {
      g.drawLine(xa, ya, xb, yb);
      g.drawLine(xb, yb, xc, yc);
      g.drawLine(xa, ya, xc, yc);
      tria(g, xa, ya, xb, yb, xc, yc, n);

      xa = 0;
      ya = 0;
      xc = 0;
      yc = getWidth();
      xb = getWidth();
      yb = getHeight();
      tria(g, xa, ya, xb, yb, xc, yc, n);
    }
  }

  private void tria(Graphics g, int xa, int ya, int xb, int yb, int xc, int yc, int n)
  {
    int xq, yq, xp, yp, xr, yr;
    if (n != 0)
    {
      xp = (xb + xc) / 2;
      yp = (yb + yc) / 2;
      xq = (xc + xa) / 2;
      yq = (yc + ya) / 2;
      xr = (xa + xb) / 2;
      yr = (ya + yb) / 2;

      tria(g, xa, ya, xq, yq, xr, yr, n - 1);
      tria(g, xq, yq, xc, yc, xp, yp, n - 1);
      tria(g, xp, yp, xr, yr, xb, yb, n - 1);

      g.drawLine(xq, yq, xp, yp);
      g.drawLine(xp, yp, xr, yr);
      g.drawLine(xq, yq, xr, yr);
    }
    if (n == 0)
      g.setColor(Color.RED);
    if (n == 1)
      g.setColor(Color.BLUE);
    if (n == 2)
      g.setColor(Color.BLACK);
    // ToDo add other colours
  }

  public static void main(String[] args)
  {
    Tria tria = new Tria();

    JFrame frame = new JFrame();
    frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
    frame.getContentPane().add(tria);
    frame.pack();
    frame.setLocationRelativeTo(null);
    frame.setVisible(true);
  }
}

там где написано ToDo add other colours надо добавить оставшиеся цвета (и возможно подкорректировать текущие).


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0701 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.