ОО2/Лаб 3 2021

Извор: SI Wiki
< ОО2
Датум измене: 8. јун 2021. у 23:46; аутор: KockaAdmiralac (разговор | доприноси) (Još detalja o sladoledžinici)
Пређи на навигацију Пређи на претрагу

В1

Задатак се појавио на јунској трећој лабораторијској вежби у прве две групе, и поставка основног задатка је доступна на страници предмета.

  • Укус се ствара са задатим називом, ценом по 20ml и бојом (Color). Сви параметри могу да се дохвате. Могуће је упоредити два укуса на једнакост. Два укуса су једнака уколико су им имена једнака. Могуће је саставити текстуални опис укуса у облику [име].
  • Сладолед у чаши се састоји од произвољног броја укуса. За сваки укус се памти и количина у милилитрима. Сладолед се ствара празан са задатом величином чаше у милилитрима. Могуће је додати задату количину задатог укуса. Уколико би се таквим додавањем превазишла величина чаше, додаје се одговарајућа количина до пуне чаше. Додавањем већ постојећег укуса ажурира се само његова количина у сладоледу. Текстуални опис сладоледа је у облику укуси, где су укуси сви садржани укуси и њихове количине, раздвојени размацима, у облику количинаmlукус. Могуће је израчунати цену сладоледа. Могуће је упоредити два сладоледа на једнакост, чиме се пореде сви укуси и њихове количине. Могуће је поставити величину чаше, чиме се и одбацују сви тренутно додати укуси (?).
  • Наруџбина садржи сладолед. (?)
  • Генератор наруџбина има могућност да генерише сладолед насумичне величине, са насумичним бројем укуса и насумичним укусима, тако да збир количина укуса буде једнак величини чаше.
  • Активни списак наруџбина генерише по наруџбину на сваких 4 секунде. Ствара се са максималним бројем наруџбина на списку, и када је списак пун не генеришу се даље наруџбине. Могуће је додати и обрисати наруџбину са списка.
  • Место за точење сладоледа је активно платно (Canvas). Ствара се са задатим апаратом за точење (видети ниже) који је власник места за точење и садржи сладолед који може да се дохвати. Место за точење циклично исцртава прогрес точења укуса у сладолед на сваких 0.5 секунди. У свакој итерацији исцртава се правоугаоник у боји укуса који се тренутно точи у сладолед, додаје се количина од 20ml тог укуса у сладолед и поставља се текст натписа (лабеле) у апарату (видети ниже). Правоугаоници се исцртавају од доње ка горњој ивици платна једни изнад других. Висина правоугаоника се добија као процентуални део висине платна који одговара количини од 20ml у односу на величину чаше. Точење се завршава када се исцрта целокупан прогрес точења до врха и тада се апарату за точење омогућава продаја (видети ниже). Могуће је покренути точење при чему се тада креира сладолед од 200ml. Могуће је привремено зауставити, наставити или завршити точење. Могуће је испитати да ли је точење у току. Могуће је поставити тренутни укус који се точи у сладолед.
  • Апарат за точење је панел који садржи место за точење, панел са произвољним бројем доступних укуса, дугме за продају сладоледа које је иницијално неактивно, дугме за брисање сладоледа које је иницијално неактивно, дугмад за бирање величине сладоледа и лабелу за приказ сладоледа из места за точење, чији је текст могуће поставити. Панел са доступним укусима садржи дугмад у формату решетке. Натпис дугмета одговара тексту укуса. Могуће је додати ново дугме за задати укус у панел са доступним укусима. Грешка је уколико укус већ постоји. Притиском тастера миша на дугме доступног укуса, месту за точење се поставља тренутни укус на основу притиснутог дугмета и покреће точење уколико није покренуто, односно наставља већ започето точење. Отпуштањем тастера миша привремено се зауставља точење. Могуће је омогућити продају сладоледа и тада дугме за продају постаје активно. Притиском на дугме за продају, завршава се точење и брише цртеж на месту за точење (канвасу), сладолед на месту за точење се исписује на стандардном излазу и дугме за продају постаје поново неактивно. Притиском на дугме за брисање сладоледа одбацује се тренутни сладолед на месту за точење. Бирањем величине сладоледа мења се величина чаше тренутног сладоледа у месту.
  • Сладоледџиница је главни прозор апликације (са слике) који садржи апарат за точење, текстуално поље (TextArea) у којем се приказују наруџбине које пристижу, лабела која приказује тренутну количину новца зарађеног од продаје сладоледа која се ажурира при свакој продаји сладоледа, дугме за отварање и затварање сладолеџинице којим се покреће генерисање наруџбина и панел за додавање новог укуса у апарат за точење са задатим називом, бојом и ценом и у коме се такође налази дугме за почетак генерисања наруџбина. Боја укуса који се додаје се задаје у хексадецималном формату. Преласком миша преко дугмета за отварање на њему треба да се повећа величина фонта и врати на претходно стање када миш више не прелази преко дугмета.

В2

Задатак се појавио на јунској трећој лабораторијској вежби у друге две групе, и поставка основног задатка је доступна на страници предмета.

  • Генератор случајних целих бројева генерише случајне целе бројеве на захтев. Могуће је захтевати један случајан цео број или низ од n елемената у задатом опсегу доње и горње границе. Задате границе су инклузивне.
  • Генератор јединствених целих бројева је генератор који генерише низ са јединственим бројевима помоћу хеш сета(HashSet).
  • Поље је платно (Canvas) које се ствара са задатом дводимензионом мрежом (видети ниже) којој припада и задатом целобројном вредношћу (број) која представља натпис (лабелу) на пољу и која може да се дохвати. Поље може имати један од следећих статуса: SLOBODNO, IZABRANO, OZNACENO, POGODJENO и PROMASENO, који се може поставити и дохватити. Подразумевано, поље има статус SLOBODNO, а ширина и висина су му 75 пиксела, боја позадине му је наранџаста, а број је исписан црном бојом на средини поља и заузима једну трећину мање димензије поља (потребно је обезбедити промену величине садржаја поља при промени величине прозора). Поље статуса IZABRANO унутар целог поља исцртава елипсу попуњену плавом бојом, а број је исписан белом бојом. Поље статуса OZNACENO унутар целог поља исцртава елипсу попуњену белом бојом, а број је исписан црном бојом. Поље статуса POGODJENO унутар целог поља исцртава елипсу попуњену зеленом бојом, а број је исписан црном бојом. Поље статуса PROMASENO унутар целог поља исцртава елипсу попуњену црвеном бојом, а број је исписан црном бојом. Кликом левог тастера миша на поље мења се његов статус (уколико је статус поља SLOBODNO оно постаје IZABRANO и обрнуто) и поље прослеђује мрежи информацију да се његов статус променио.
  • Мрежа је панел који садржи правоугаону матрицу поља и листу (ArrayList) поља која имају статус IZABRANO и која може да се дохвати. Ствара се са задатим целобројним димензијама (подразумевано 4 х 5) и игром (видети ниже) којој припада. Приликом стварања мреже, поља се додају у мрежу редом по врстама, при чему се пољима задају сукцесивне целобројне вредности, а нумерација креће од вредности 0. Поља су размакнута једна од других за 3 пиксела, а боја позадине мреже је црна, тако да се постигне ефекат поља распоређених у мрежи. Могуће је дохватити скуп (HashSet) који чине сви цели бројеви поља мреже са статусом IZABRANO. Променом статуса неког њеног поља, мрежа ажурира листу поља са статусом IZABRANO и прослеђује игри информацију да је поље променило статус. Могуће је закључати поља мреже, чиме та поља не реагују на притиске миша. Могуће је променити пољима чији се бројеви налазе у задатој листи статус на IZABRANO, док се осталима мења на SLOBODNO.
  • Активан рулет је класа која анимира избор бројева. Ствара се са задатом мрежом. Садржи низ бројева поља која се анимирају који се насумично генеришу и не морају бити јединствени. Величина низа је случајно генерисана вредност између 30% и 70% величине мреже. Може се дохватити последњи анимирани број, чиме се позивајућа нит блокира уколико рулет није завршио (ово служи само за проверу погодтка броја). Анимација треба бити следећа за сваки члан низа: почиње тако што се поље које представља тај члан низа постави на статус OZNACENO, затим се чека одређено време чекања (иницијално 200ms, а сваке следеће итерације се повећава 10%) и затим вратити претходни статус пољу.
  • Активно извлачење је класа која извлачи број с рулета. Ствара се са задатом игром и бројем рунди. Потребно је имплементирати тако да при покретању ова класа понови исти циклус колико има рунди. Циклус се састоји од тога да покрене рулет, покупи с рулета последњи анимирани број и обавести игру да је извучен број. Ако је број који је извучен би изабран, потребно је поставити статус тог поља на POGODJENO у супротном статус је PROMASENO. Затим треба чекати 1000ms после чега треба повратити стари статус поља. Док траје извлачење, није могуће бирати поља, односно мрежа треба бити онемогућена. Могуће је дохватити тренутни број рунде, као и укупан број рунди.
  • Историја извлачења је панел који садржи листу ставки (видети слику) и ствара се са максималним капацитетом. Ставке су објекти класе TextArea без вертикалног и хоризонталног скрол бара. Могуће је додати ставку. У случају да се додаје ставка која би прешла максимални капацитет, потребно је избацити најранију ставку. Ставка треба да садржи број рунде, извучен број, улог и добитак.
  • Игра је главни прозор апликације (са слике) који садржи једну мрежу подразумеване величине (у центру), која може да се дохвати, један панел за историју извлачења (са леве стране), један панел за управљање (са десне стране) и статусну траку (на дну). Игру је могуће започети само уколико се изабере барем једно поље. Улог има подразумевану вредност 100. Број рунди има подразумевану вредност 4. Избором поља (променом његовог статуса) или изменом вредности улога врши се ажурирање вредности квоте и добитка који се приказују у прозору апликације. Вредност квоте се рачуна као количник укупног броја поља и броја поља са статусом IZABRANO. Вредност добитка се рачуна као производ квоте и улога. Игра се започиње кликом на дугме Igraj након чега се покреће извлачење. Генерисани број исписује се у статусној траци на дну прозора, која се боји зеленом бојом уколико је генерисани број један од бројева на изабраним пољима мреже (број је погођен), односно црвеном бојом у супротном (број је промашен). Уколико је генерисани број погођен, врши се додавање вредности добитка на вредност баланса, док се, уколико је број промашен, врши одузимање вредности улога од вредности баланса. Без обзира на погодак, са баланса се додатно одузима вредност улога. Иницијална вредност баланса је 0. Иницијално, боја статусне траке је тамно-сива. Главни прозор садржи мени са опцијама Par (бира све парне бројеве мреже), Nepar (бира све непарне бројеве мреже), Pola (изабере насумично пола мреже) и опцију Brisi која свим пољима ставља статус SLOBODNO. Треба онемогућити ове опције док траје процес извлачења.

В3