MTIPLab

Слични документи
Primenjeno programiranje - vezbe GUI i baze podataka

VEŽBA 5: KLASE I OBJEKTI U C# Cilj ove vežbe je upoznavanje sa osnovama rada sa klasama i objektima u programskom jeziku C#. Pored toga, bide demonstr

PowerPoint Presentation

PowerPoint Presentation

Slide 1

Primenjeno programiranje - Vežbe

PowerPoint Presentation

Tutoring System for Distance Learning of Java Programming Language

PowerPoint Presentation

Tutoring System for Distance Learning of Java Programming Language

Programski jezik JAVA PREDAVANJE

ZADACI ZA VEŽBU 1. Realizovati konzolnu aplikaciju koja će računati površinu kvadrata, pravougaonika ili trougla. 2. Preko konzole se unosi ocena od 1

Microsoft PowerPoint - OOPpredavanja05 [Compatibility Mode]

PowerPoint Presentation

UVOD - OD JAVE DO C# ELEMENTARNE RAZLIKE Veliki broj Java/C# razlika su uglavnom preimenovane ključne reči i razlike u konvencijama imenovanja. Neke o

Računarski praktikum I - Vježbe 09 - this, static

Класе комбинација презентације (Хортона) и к о бајаги скрипте (Ово је прича коју врло радо причам) нови тип података: дефинишу могуће вредности подата

Zadatak 011 Razmotrite sljedeći primjer. package hr.fer.oopj.primjeri.p011; public class Main { } public static void main(string[] args) { obrada(2.71

PowerPoint Presentation

Tutoring System for Distance Learning of Java Programming Language

Дистрибуирани софтверски системи Технички факултет "Михајло Пупин" Зрењанин, Универзитет у Новом Саду Практикум за лабораторијске вежбе #04 [нерецензи

PowerPoint Presentation

Microsoft PowerPoint - 6. CMS [Compatibility Mode]

Funkcije predavač: Nadežda Jakšić

Microsoft PowerPoint - 13-Funkcije_2.ppt [Compatibility Mode]

Дистрибуирани софтверски системи Технички факултет "Михајло Пупин" Зрењанин, Универзитет у Новом Саду Практикум за лабораторијске вежбе #07 [нерецензи

Tutoring System for Distance Learning of Java Programming Language

Funkcije predavač: Nadežda Jakšić

Microsoft PowerPoint - 12-Funkcije_1.ppt [Compatibility Mode]

Slide 1

Programski jezici i strukture podataka 2018/2019. Programski jezici i strukture podataka Računarske vežbe vežba 10 Zimski semestar 2018/2019. Studijsk

Projekti šabloni

Microsoft PowerPoint - 07-DinamickeStrukturePodataka

4. Веза између табела практичан рад 1. Повежите табеле Proizvodi и Proizvođači у бази података Prodavnica.accdb везом типа 1:N. 2. Креирајте табелу St

Upute-podesavanj -accounta

Microsoft PowerPoint - JavaP7_2018

Slide 1

Univerzitet u Beogradu Mašinski fakultet Konstrukcija i tehnologija proizvodnje letelica PODEŠAVANJE PROGRAMSKOG PAKETA CATIA V5 Miloš D. Petrašinović

Microsoft PowerPoint - 6. Query Builder.pptx

SELECT statement basic form

Inženjering informacionih sistema

PowerPoint Presentation

Datum: 20

VALIDNOST CERTIFIKATA ZA PRISTUP INTERNET APLIKACIJAMA POREZNE UPRAVE FEDERACIJE BOSNE I HERCEGOVINE (npis I ejs)

Microsoft Word - SYLLABUS -Dinamicki

NACIONALNI REGISTAR IZVORA ZAGAĐIVANJA UPUTSTVO ZA KORIŠĆENJE INFORMACIONOG SISTEMA NACIONALNOG REGISTRA IZVORA ZAGAĐIVANJA Beograd, 2014.

Računarski praktikum I - Vježbe 03 - Implementacija strukture string

Microsoft Word - Java_introduction_NEW_SYLLABUS.doc

Microsoft Word - Uputstvo za upotrebu studentskih servisa.doc

PowerPoint Presentation

Korisničko uputstvo za uslugu ClickPay u Mobilnom bankarstvu BIHAMK 1. OPIS USLUGE Usluga ClickPay omogućava prijem unaprijed popunjenog naloga za pla

Uvod u računarstvo 2+2

Strukture predavač: Nadežda Jakšić

Introduction to Programming

Microsoft PowerPoint - JavaP9_2019

m-intesa ZA KRETANJE BEZ GRANICA... INTESA SANPAOLO BANKA ZA UREĐAJE SVIJET MOGUĆEG.

Fra Serafina Schoena Rijeka MB: MBO: Žiro račun: kod RBA d.d. GSM:

PowerPoint Presentation

Grananje u programu predavač: Nadežda Jakšić

Microsoft Word - Uputstvo za upotrebu studentskih servisa.doc

PowerPoint Presentation

SEMINAR

SVEUČILIŠTE JOSIPA JURJA STROSSMAYERA U OSIJEKU FAKULTET ELEKTROTEHNIKE, RAČUNARSTVA I INFORMACIJSKIH TEHNOLOGIJA Diplomski sveučilišni studij računar

Microsoft PowerPoint - 01 Uvod u operativne sisteme.ppt

Objektno orjentirano programiranje 2P

MIP-heuristike (Matheuristike) Hibridi izmedu metaheurističkih i egzaktnih metoda Tatjana Davidović Matematički institut SANU

PowerPoint Presentation

UPUTSTVO ZA PODEŠAVANJE MOBILNIH UREĐAJA ZA MMS

Microsoft PowerPoint - Programski_Jezik_C_Organizacija_Izvornog_Programa_I_Greske [Compatibility Mode]

UPUTA za uvođenje JOPPD - prva faza

PowerPoint Presentation

sv-lncs

PowerPoint Presentation

User's Manual

O Nanokinetik NeeS TOC Builder-u NeeS TOC Builder je aplikacija koja se koristi za kreiranje Tabele sadržaja (TOC) za elektronske podneske u NeeS form

Projektna dokumentacija Boostowski - mobile

CPHP_19

IEP - Projekat 2018/2019

Mrežno računarstvo

ELEKTROTEHNIČKI FAKULTET, UNIVERZITET U BEOGRADU KATEDRA ZA ELEKTRONIKU UVOD U ELEKTRONIKU - 13E041UE LABORATORIJSKA VEŽBA Primena mikrokontrolera

Android 9, Kotlin i Android Studio 3.2 NEIL SMYTH

Korisničko uputstvo za uslugu ClickPay u Internet bankarstvu KJKP Toplane Sarajevo 1. OPIS USLUGE Usluga ClickPay omogućava prijem unaprijed popunjeno

Studijski primer - Dijagrami toka podataka Softverski inženjering 1

PowerPoint Presentation

3.Kontrlne (upravlja~ke) strukture u Javi

Programiranje 1

1 NOVO U MNG CENTRU!!! OVLADAJTE TEHNOLOGIJOM IZRADE JAVA EE APLIKACIJA KORIŠ C ENJEM ORACLE ADF-A O - Otkrijte brzinu razvoja aplikacija sa ADF-om -

Microsoft Word - 11 Pokazivaci

UPUTSTVO ZA KRETANJE KROZ EON KORISNIČKI INTERFEJS 1

ПРОГРАМИ ЗА ПРАВЉЕЊЕ ПРЕЗЕНТАЦИЈА

PHP proširenja za rad sa bazama podataka Postoje pojedinačna proširenja za različite tipove baza podataka sa svojim bibliotekama funkcija npr. postoji

Дистрибуирани софтверски системи Технички факултет "Михајло Пупин" Зрењанин, Универзитет у Новом Саду Практикум за лабораторијске вежбе #05 [нерецензи

Računarski praktikum I - Vježbe 11 - Funktori

Univerzitet u Novom Sadu Tehnički fakultet Mihajlo Pupin Zrenjanin Seminarski rad Predmet: Konkuretno programiranje doc. dr Dejan Lacmanovic Zorica Br

_Outlook

СТАРТ - СТОП АПЛИКАЦИЈА - КОРИСНИЧКО УПУТСТВО

Korisničko uputstvo mobilne aplikacije Digitalni Kiosk 1

Транскрипт:

MOBILNE TEHNOLOGIJE I PROGRAMIRANJE MTIPLAB05 Vežba 5 Rad sa fragmentima, rasporedima komponenti (layouts) i Android komponentama UVOD U okviru ove vežbe biće dorađena MTIP Studenti Android aplikacija koja je formirana u prethodnoj vežbi (MTIPLab04). Biće oformljeni fragmenti koje će predstavljati odgovarajuće aktivnosti (stranice) spomenute aplikacije, kao i rasporedi komponenti (layouts) koji će biti dinamički i upotrebljeni za formiranje više fragmenata. Cilj ove vežbe je da se pripreme elementi korisničkog interfejsa MTIP Studenti Android aplikacije kako bi se u narednoj vežbi (MTIPLab05) oformila veza spomenute aplikacije sa internetom i RESTFull servisom koji je formiran kroz vežbe MTIPLab01 i MTIPLab02. FRAGMENTI, DEFINISANJE LAYOUTA I KLASA Unutar fajla strings.xml dodate su definicije stringova tj. labela koje se mogu koristiti prilikom definisanja sadržaja određenih elemenata Android aplikacije, tj. u ovom slučaju sadržaja fragmenata koji će biti dodati Android aplikaciji. Sadržaj navedenog fajla prikazan je u listingu koda broj 1. <string name="mtipstudentipregragafragmentnaziv">pretraga studenata</string> <string name="mtipstudentifragmenthintidstudenta">id studeta</string> <string name="mtipstudentifragmenthintprezime">prezime studenta</string> <string name="mtipstudentifragmenthintime">ime studenta</string> <string name="mtipstudentifragmenthintbrojindeksa">broj indeksa</string> <string name="mtipstudentipregragafragmentrezultatipretrage">rezultati pretrage</string> <string name="mtipstudentidodajnovogstudenta">dodaj novog studenta</string> <string name="mtipstudentidetaljiid">id : </string> <string name="mtipstudentidetaljiprezime">prezime : </string> <string name="mtipstudentidetaljiime">ime : </string> <string name="mtipstudentidetaljibrojindeksa">broj indeksa : </string> <string name="mtipstudentidetaljistudijskiprogram">smer : </string> <string name="mtipstudentidetaljiizmenistudenta">izmena</string> <string name="mtipstudentidetaljiobrisistudenta">brisanje</string> <string name="mtipstudentipotvrdi">potvrdi</string> <string name="mtipstudentiodustani">odustani</string> Listing broj 1. Dodati resursi unutar fajla strings.xml 1

Da bi pripremili MTIP Studenti Android za rad sa fragmentima potrebno je modifikovati layout i kod glavne aktivnosti spomenute aplikacije. Modifikacija layouta glavne aktivnosti odnosi se na modifikaciju fajla content_mtipstudenti_main.xml dodavanjem FrameLayout komponente. Navedena komponenta se ponaša kao okvir za fragmente koji nose određeni sadržaj i logiku aplikacije. Sadržaj fajla content_mtipstudenti_main.xml prikazan je u listingu koda broj 2. <?xml version="1.0" encoding="utf-8"?> <android.support.constraint.constraintlayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior" tools:context="rs.tfzr.mtipstudenti.mtipstudentimain" tools:showin="@layout/app_bar_mtipstudenti_main"> <FrameLayout android:id="@+id/frame_container" android:layout_height="match_parent" /> </android.support.constraint.constraintlayout> Listing broj 2. Sadržaj fajla content_mtipstudenti_main.xml Zatim se, radi vizuelnog aspekta aplikacije definiše resurs unutar drawable foldera koji će predstavljati pozadinu određenih elemenata. Navedeni fajl nosi naziv op_background.xml i sadržina istog je prikazana u listingu koda broj 3. <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android"> <solid android:color="#ffffff"/> <stroke android:width="1dip" android:color="#b1bcbe" /> <corners android:radius="10dip"/> <padding android:left="0dip" android:top="0dip" android:right="0dip" android:bottom="0dip" /> </shape> Listing broj 3. Sadržaj fajla op_background.xml U sledećem koraku formira se raspored (layout) layout_studenti_universal.xml unutar layout foldera koji će se koristiti za predstavljanje studenta prilikom prikaza informacija o istom i u administratorskoj sekciji prilikom izmene i brisanja istog. Spomenuti layout poseduje četri labele (TextView-a) koje nose informacije o podatku koji se prikazuje, zatim još četri labele (TextView-a) koji nose podatke koji se prikazuju, i dve kontrole tipa Button za koje će se u narednoj vežbi (MTIPLab05) vezati odgovarajući događaji i pozivi RESTFull servisa. Spomenuti tasteri će se sakrivati (uklanjati) kad se spomenuti layout koristi za prikaz informacije o studentu. Sadržaj navedenog fajla prikazan je u listingu koda broj 4, dok je na slici broj 1 prikazan izgled spomenutog layouta unutar Android Studio razvojnog okruženja. <?xml version="1.0" encoding="utf-8"?> xmlns:android="http://schemas.android.com/apk/res/android" android:layout_height="match_parent" android:orientation="vertical" android:background="@drawable/op_background" 2

android:id="@+id/linearlayoutstudentiuniversalcontainer"> android:id="@+id/linearlayoutprezimestudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewprezimelabel" android:layout_width="15dp" android:layout_weight="0.3" android:gravity="right" android:text="@string/mtipstudentidetaljiprezime" /> android:id="@+id/textviewprezimedata" android:layout_weight="0.7" /> android:id="@+id/linearlayoutimestudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewimelabel" android:layout_width="15dp" android:layout_weight="0.3" android:gravity="right" android:text="@string/mtipstudentidetaljiime" /> android:id="@+id/textviewimedata" android:layout_weight="0.7" /> android:id="@+id/linearlayoutbrojindeksastudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewbrojindeksalabel" android:layout_width="15dp" android:layout_weight="0.3" android:gravity="right" android:text="@string/mtipstudentidetaljibrojindeksa" /> android:id="@+id/textviewbrojindeksadata" 3

android:layout_weight="0.7" /> android:id="@+id/linearlayoutstudijskiprogramstudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewstudijskiprogramlabel" android:layout_width="15dp" android:layout_weight="0.3" android:gravity="right" android:text="@string/mtipstudentidetaljistudijskiprogram" /> android:id="@+id/textviewstudijskiprogramdata" android:layout_weight="0.7" /> android:id="@+id/linearlayouttasteri" android:orientation="horizontal"> <Button android:id="@+id/buttonizmenistudenta" android:layout_weight="1" android:text="@string/mtipstudentidetaljiizmenistudenta" /> <Button android:id="@+id/buttonobrisistudenta" android:layout_weight="1" android:text="@string/mtipstudentidetaljiobrisistudenta" /> Listing broj 4. Sadržaj fajla layout_studenti_universal.xml Naredni korak odnosi se na formiranje layouta koji će se koristiti u fragmentima prilikom dodavanja novog studenta i izmene postojećeg studenta. Naknadno će biti formirane klase koje će na osnovu spomenutog layouta pružati usluge dodavanja novog i izmene postojećeg studenta. Dakle, potrebno je formirati layout fragment_studenti_dodavanje_izmena.xml i smestiti ga u layout folder. Navedeni layout sadrži pet labela (TextView-a) koje nose informacije o podatku koji se prikazuje, četri textbox-a (EditText-a) putem kojih će se unositi podatci i jedan combobox (Spinner kontrola) koja će sadržati dostupne smerove tj. studijski program kojem određeni student pripada. Unutar navedenog layouta postoje i dve kontrole tipa Button koje će se koristiti za potvrđivanje dodavanja novog ili izmene postojećeg studenta, kao i za odustajanje od 4

spomenutih procesa čime se korisnik preusmerava ka nekom drugom fragmentu. Sadržaj spomenutog fajla prikazan je u listingu koda broj 5, dok je na slici broj 2 prikazan izgled spomenutog layouta unutar Android Studio razvojnog okruženja. Slika broj 1. Izgled layout-a layout_studenti_universal.xml <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_height="match_parent" tools:context="rs.tfzr.mtipstudenti.studentidodavanjefragment"> xmlns:android="http://schemas.android.com/apk/res/android" android:layout_height="match_parent" android:orientation="vertical" android:background="@drawable/op_background" android:id="@+id/dodavanjeizmenamainlinearlayout"> android:id="@+id/textviewstudentinazivakcije" android:layout_width="fill_parent" android:gravity="center" android:paddingleft="10dp" android:paddingright="10dp" android:paddingtop="10dp" android:text="@string/mtipcontentdescription" /> android:id="@+id/linearlayoutidstudenta" 5

android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewidstudentalabel" android:layout_width="50dp" android:layout_weight="0.4" android:gravity="right" android:text="@string/mtipstudentidetaljiid" /> <EditText android:id="@+id/edittextidstudentadata" android:ems="10" android:hint="@string/mtipstudentifragmenthintidstudenta" android:inputtype="none" android:focusedbydefault="false" android:layout_weight="0.6"/> android:id="@+id/linearlayoutprezimestudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewprezimelabel" android:layout_width="50dp" android:layout_weight="0.4" android:gravity="right" android:text="@string/mtipstudentidetaljiprezime" /> <EditText android:id="@+id/edittextprezimedata" android:ems="10" android:hint="@string/mtipstudentifragmenthintprezime" android:inputtype="text" android:focusedbydefault="false" android:layout_weight="0.6"/> android:id="@+id/linearlayoutimestudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewimelabel" android:layout_width="50dp" android:layout_weight="0.4" 6

android:gravity="right" android:text="@string/mtipstudentidetaljiime" /> <EditText android:id="@+id/edittextimedata" android:ems="10" android:hint="@string/mtipstudentifragmenthintime" android:inputtype="text" android:focusedbydefault="false" android:layout_weight="0.6"/> android:id="@+id/linearlayoutbrojindeksastudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewbrojindeksalabel" android:layout_width="50dp" android:layout_weight="0.4" android:gravity="right" android:text="@string/mtipstudentidetaljibrojindeksa" /> <EditText android:id="@+id/edittextindeksdata" android:ems="10" android:hint="@string/mtipstudentifragmenthintbrojindeksa" android:inputtype="text" android:focusedbydefault="false" android:layout_weight="0.6"/> android:id="@+id/linearlayoutstudijskiprogramstudenta" android:orientation="horizontal" android:weightsum="1"> android:id="@+id/textviewstudijskiprogramlabel" android:layout_width="150dp" android:layout_weight="0.4" android:gravity="right" android:text="@string/mtipstudentidetaljistudijskiprogram" /> <Spinner android:id="@+id/spinnerstudijskiprograami" android:layout_weight="0.6" /> 7

android:id="@+id/linearlayouttasteripotvrdiodustani" android:orientation="horizontal"> <Button android:id="@+id/buttonpotvrdi" android:layout_weight="1" android:text="@string/mtipstudentipotvrdi" /> <Button android:id="@+id/buttonodustani" android:layout_weight="1" android:text="@string/mtipstudentiodustani" /> </FrameLayout> Listing broj 5. Sadržaj fajla fragment_studenti_dodavanje_izmena.xml Slika broj 2. Izgled layout-a fragment_studenti_dodavanje_izmena.xml Sledeći korak odnosi se na formiranje layouta koji će se koristiti u fragmentima za pretragu (PretragaFragment) i za administraciju studenata (StudentiFragment). Potrebno je formirati layout fajl fragment_pretraga.xml u layout folderu i isti treba da poseduje sadržinu koja je prikazana u listingu koda broj 6 dok je izgled spomenutog layouta prikazan na slici broj 3. Unutar 8

spomenutog layouta nalaze se labele, EditText kontrola i slika (ImageView) koja će se koristiti kao taster za pozivanje pretrage studenata. Takođe, jedna labela je planirana da se koristi za prelazak na fragment za dodavanja novog studenta i nosi tekst Dodaj novog studenta. Unutar spomenutog layouta nalaze se kontole tipa ScrollView i LinearLayout koje će se u narednoj vežbi (MTIPLab06) koristiti kako bi se prikazali podaci o studentima kako na fragmentu za pretragu, tako i na fragmentu za administraciju studenata. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_height="match_parent" tools:context="rs.tfzr.mtipstudenti.pretragafragment"> xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" android:gravity="center_horizontal" android:id="@+id/maincontainerpretraga"> android:id="@+id/textviewpretragastudenata" android:layout_width="fill_parent" android:gravity="center" android:paddingleft="10dp" android:paddingright="10dp" android:paddingtop="10dp" android:text="@string/mtipstudentipregragafragmentnaziv" /> android:focusable="true" android:focusableintouchmode="true" android:layout_width="0px" android:layout_height="0px"/> android:weightsum="1" > <EditText android:id="@+id/edittextprezimepretraga" android:ems="10" android:hint="@string/mtipstudentifragmenthintprezime" android:inputtype="text" android:paddingtop="10dp" android:focusedbydefault="false" android:layout_weight="0.7"> </EditText> <ImageView android:id="@+id/imageviewpretraga" android:src="@drawable/nav_pretraga" android:layout_weight="0.3"/> 9

android:id="@+id/textviewdodajnovogstudenta" android:layout_width="fill_parent" android:gravity="center" android:padding="10dp" android:text="@string/mtipstudentidodajnovogstudenta" /> <ScrollView android:id="@+id/scrollviewrezultatipretrage" android:layout_width="fill_parent" > android:id="@+id/layoutrezultatipretrage" android:orientation="vertical" android:gravity="center" android:paddingleft="5dp" android:paddingright="5dp" android:paddingbottom="5dp"> </ScrollView> </FrameLayout> Listing broj 6. Sadržaj fajla fragment_pretraga.xml Slika broj 3. Izgled layout-a fragment_pretraga.xml 10

Sledeći korak odnosi se na modifikaciju koda klase MTIPStudentiMain koja predstavlja glavnu aktivnost MTIP Studenti Android aplikacije kako bi se dodala podrška za rad sa fragmentima. Za adekvatno funkcionisanje navedene aplikacije, nakon analize koda i prikaza modifikacije koda klase MTIPStudentiMain biće formirane klase čiji se objekti koriste u spomenutoj klasi i sadrže logiku fragmenta (stranica) koje se implementiraju. Sadržaj klase MTIPStudentiMain prikazan je u listingu koda broj 7. package rs.tfzr.mtipstudenti; import android.app.activity; import android.app.alertdialog; import android.app.fragment; import android.app.fragmentmanager; import android.content.context; import android.content.dialoginterface; import android.content.intent; import android.net.uri; import android.os.bundle; import android.view.view; import android.support.design.widget.navigationview; import android.support.v4.view.gravitycompat; import android.support.v4.widget.drawerlayout; import android.support.v7.app.actionbardrawertoggle; import android.support.v7.app.appcompatactivity; import android.support.v7.widget.toolbar; import android.view.menuitem; import android.app.dialog; import android.widget.button; import android.widget.textview; public class MTIPStudentiMain extends AppCompatActivity implements NavigationView.OnNavigationItemSelectedListener, PretragaFragment.OnFragmentInteractionListener, StudentiFragment.OnFragmentInteractionListener, StudentiDodavanjeFragment.OnFragmentInteractionListener, StudentiIzmenaFragment.OnFragmentInteractionListener { public static Activity _activity; protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_mtipstudenti_main); Toolbar toolbar = (Toolbar) findviewbyid(r.id.toolbar); setsupportactionbar(toolbar); DrawerLayout drawer = (DrawerLayout) findviewbyid(r.id.drawer_layout); ActionBarDrawerToggle toggle = new ActionBarDrawerToggle( this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); drawer.adddrawerlistener(toggle); toggle.syncstate(); NavigationView navigationview = (NavigationView) findviewbyid(r.id.nav_view); navigationview.setnavigationitemselectedlistener(this); navigationview.setitemicontintlist(null); displayview(new PretragaFragment(),this); _activity = this; 11

public void onbackpressed() { DrawerLayout drawer = (DrawerLayout) findviewbyid(r.id.drawer_layout); if (drawer.isdraweropen(gravitycompat.start)) { drawer.closedrawer(gravitycompat.start); else { super.onbackpressed(); @SuppressWarnings("StatementWithEmptyBody") public boolean onnavigationitemselected(menuitem item) { // Handle navigation view item clicks here. int id = item.getitemid(); switch (id) { case R.id.navBar_Pretraga: { displayview(new PretragaFragment(),this); break; case R.id.navBar_Studenti: { displayview(new StudentiFragment(),this); break; case R.id.navBar_Studijski_Programi: { AlertDialog.Builder builder = new AlertDialog.Builder(_activity); builder.setmessage("treba kreirati stranicu (Fragmente) za upravljanje Studijskim programima (Smerovima) kao što je urađeno za Studente!").setTitle("MTIP Studenti"); builder.setpositivebutton("ok", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog, int id) { ); AlertDialog dialog = builder.create(); dialog.show(); break; case R.id.navBar_O_Aplikaciji: { DijalogOAplikaciji(); break; DrawerLayout drawer = (DrawerLayout) findviewbyid(r.id.drawer_layout); drawer.closedrawer(gravitycompat.start); return true; public static void displayview(fragment fragment, Activity activity) { // update the main content by replacing fragments if (fragment!= null) { 12

FragmentManager fragmentmanager = activity.getfragmentmanager(); fragmentmanager.begintransaction().replace(r.id.frame_container, fragment).commit(); protected void DijalogOAplikaciji() { final Dialog dialog = new Dialog(this, R.style.AboutDialog ); dialog.setcontentview(r.layout.mtip_about_dialog); dialog.settitle("o Aplikaciji"); TextView txtemail = (TextView) dialog.findviewbyid(r.id.textviewaboutdialogemal); txtemail.setonclicklistener(new View.OnClickListener() { public void onclick(view v) { // TODO Auto-generated method stub try { Intent email = new Intent(Intent.ACTION_SEND); email.putextra(intent.extra_email, new String[]{"mtip.studenti@tfzr.uns.ac.rs"); email.putextra(intent.extra_subject, "sugestija / pitanje / zamerka" ); email.putextra(intent.extra_text, ""); email.settype("message/rfc822"); startactivity(intent.createchooser(email, "Odaberite Vaš e- mail klijent :" )); catch (Exception ex) { ); Button dialogbutton = (Button) dialog.findviewbyid(r.id.dialogbuttonokclose); dialogbutton.setonclicklistener(new View.OnClickListener() { public void onclick(view v) { dialog.dismiss(); ); dialog.show(); public void onfragmentinteraction(uri uri) { Listing broj 6. Sadržaj klase MTIPStudentiMain Analizom listinga koda broj 6 bitno je istaći implementiranje interfejsa OnFragmentInteractionLintener za fragmente (klase) PretragaFragment, StudentiFragment, StudentiDodavanjeFragmet i StudentiIzmenaFragment. Spomenute klase će biti formirane naknadno u nastavku ove vežbe. Zatim, radi lakše manipulacije sa fragmentima (pošto je prilikom promene fragmenta potrebna referenca ka aktivnosti koja sadrži 13

kontejner u kojem će se fragment prikazati) formira se statička referenca ka aktivnosti i na oncreate metodu ista se povezuje sa glavnom aktivnosti linijom koda _activity = this; Napisana je statička metoda displayview koja prima dva argumenta. Jedan argument je sam fragment tj. referenca do instance klase koja predstavlja fragment koji treba da se prikaže, a drugi je referenca do aktivnosti unutar koje treba da se prikaže navedeni fragment. Unutar tela metode koristi se FragmentManager kako bi se unutar predviđanog kontejnera (R.id.frame_container) prikazao odabrani fragment. Unutar metode onnavigationitemselected, unutar switch naredbe, poziva se statička metoda displayview tako što se prosleđuje odabrani fragment pozivom njegovog konstruktora, a kao referenca na aktivnost u kojoj treba da se prikaže spomenuti fragment šalje se referenca this koja u ovom slučaju ukazuje na aktivnost MTIPStudentiMain. Takođe unutar spomenutog bloka formira se i poziva AlertDialog koji treba da obavesti korisnika ta fragment koji treba da omogući upravljanje Studijskim programima nije implementiran (kreiran). Naredni koraci se ogledaju u formiranju klasa koje će predstavljati fragmente i koristiti prethodno kreirane rasporede komponenti (layout-ove) kako bi pružili funkcionalnost aplikaciji. Sve klase nalaze se u paketu rs.tfzr.mtipstudenti. Sadržaj klase PretragaFragment koja predstavlja fragment koji će prikazati klikom na stavku menija Pretraga prikazan je u listingu koda broj 7. package rs.tfzr.mtipstudenti; import android.app.alertdialog; import android.content.context; import android.content.dialoginterface; import android.net.uri; import android.os.bundle; import android.app.fragment; import android.view.layoutinflater; import android.view.view; import android.view.viewgroup; import android.widget.imageview; import android.widget.quickcontactbadge; import android.widget.textview; import org.w3c.dom.text; public class PretragaFragment extends Fragment { // TODO: Rename parameter arguments, choose names that match // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER private static final String ARG_PARAM1 = "param1"; private static final String ARG_PARAM2 = "param2"; // TODO: Rename and change types of parameters private String mparam1; private String mparam2; private OnFragmentInteractionListener mlistener; protected TextView _textviewdodajnovogstudenta; protected ImageView _imageviewpretraga; protected Context _context; public PretragaFragment() { // Required empty public constructor // TODO: Rename and change types and number of parameters public static PretragaFragment newinstance(string param1, String param2) { PretragaFragment fragment = new PretragaFragment(); Bundle args = new Bundle(); 14

args.putstring(arg_param1, param1); args.putstring(arg_param2, param2); fragment.setarguments(args); return fragment; public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); if (getarguments()!= null) { mparam1 = getarguments().getstring(arg_param1); mparam2 = getarguments().getstring(arg_param2); public View oncreateview(layoutinflater inflater, ViewGroup container, Bundle savedinstancestate) { // Inflate the layout for this fragment View rootview = inflater.inflate(r.layout.fragment_pretraga, container, false); this._context = rootview.getcontext(); this._textviewdodajnovogstudenta = (TextView)rootView.findViewById(R.id.textViewDodajNovogStudenta); this._textviewdodajnovogstudenta.setvisibility(view.invisible); this._imageviewpretraga = (ImageView)rootView.findViewById(R.id.imageViewPretraga); this._imageviewpretraga.setonclicklistener(new View.OnClickListener() { public void onclick(view view) { AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); builder.setmessage("treba implementirati pretragu!!").settitle("mtip Studenti"); builder.setpositivebutton("ok", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog, int id) { ); ); AlertDialog dialog = builder.create(); dialog.show(); return rootview; // TODO: Rename method, update argument and hook method into UI event public void onbuttonpressed(uri uri) { if (mlistener!= null) { mlistener.onfragmentinteraction(uri); public void onattach(context context) { super.onattach(context); if (context instanceof OnFragmentInteractionListener) { mlistener = (OnFragmentInteractionListener) context; else { throw new RuntimeException(context.toString() + " must implement OnFragmentInteractionListener"); 15

public void ondetach() { super.ondetach(); mlistener = null; public interface OnFragmentInteractionListener { // TODO: Update argument type and name void onfragmentinteraction(uri uri); Listing broj 7. Sadržaj klase PretragaFragment Analizom listinga koda broj 7 da se zaključiti da se u spomenutom fragmentu formiraju tri bitna objekta: objekat tipa TextView koji će se koristiti kao taster za pokretanje fragmenta StudentiDodavanjeFragment pozivom statičke metode displayview iz klase MTIPStudentiMain, objekat tipa ImageView koji će se ponašati kao taster za aktiviranje pretraga (EditText kontrola za unos prezimena za pretragu će biti formiran u narednoj vežbi MTIPLab06), kao i objekat tipa Context koji se odnosi na fragment tj. aktivnost u kojem se isti poziva. Unutar poziva metode oncreateview vidi se da se koristi layout fragment_pretraga.xml na osnovu indentifikatora R.layout.fragment_pretraga i isti se formira putem inflater-a. Dalje se instanciraju prethodno spomenuti objekti i dodelju se odgovarajući listeneri. Takođe, bitno je napomenuti da se u fragmentu PregragaFragmet sakriva labela putem koje se može pozvati fragment StudentDodavanjeFragment koji služi za dodavanje studenta. Alternativno, navedena komponenta se može ukloniti i navedeno će biti demonstrirano u narednoj vežbi (MTIPLab06). Sadržaj klase StudentFragment koja predstavlja fragment koji će prikazati klikom na stavku menija Studenti prikazan je u listingu koda broj 8. package rs.tfzr.mtipstudenti; import android.app.alertdialog; import android.content.context; import android.content.dialoginterface; import android.net.uri; import android.os.bundle; import android.app.fragment; import android.view.layoutinflater; import android.view.view; import android.view.viewgroup; import android.widget.imageview; import android.widget.textview; public class StudentiFragment extends Fragment { // TODO: Rename parameter arguments, choose names that match // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER private static final String ARG_PARAM1 = "param1"; private static final String ARG_PARAM2 = "param2"; // TODO: Rename and change types of parameters private String mparam1; private String mparam2; private OnFragmentInteractionListener mlistener; protected TextView _textviewdodajnovogstudenta; 16

protected ImageView _imageviewpretraga; protected Context _context; public StudentiFragment() { // Required empty public constructor // TODO: Rename and change types and number of parameters public static StudentiFragment newinstance(string param1, String param2) { StudentiFragment fragment = new StudentiFragment(); Bundle args = new Bundle(); args.putstring(arg_param1, param1); args.putstring(arg_param2, param2); fragment.setarguments(args); return fragment; public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); if (getarguments()!= null) { mparam1 = getarguments().getstring(arg_param1); mparam2 = getarguments().getstring(arg_param2); public View oncreateview(layoutinflater inflater, ViewGroup container, Bundle savedinstancestate) { // Inflate the layout for this fragment View rootview = inflater.inflate(r.layout.fragment_pretraga, container, false); this._context = rootview.getcontext(); this._textviewdodajnovogstudenta = (TextView)rootView.findViewById(R.id.textViewDodajNovogStudenta); this._textviewdodajnovogstudenta.setonclicklistener(new View.OnClickListener() { public void onclick(view view) { MTIPStudentiMain.displayView(new StudentiDodavanjeFragment(),MTIPStudentiMain._activity); ); this._imageviewpretraga = (ImageView)rootView.findViewById(R.id.imageViewPretraga); this._imageviewpretraga.setonclicklistener(new View.OnClickListener() { public void onclick(view view) { AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); builder.setmessage("treba implementirati pretragu!!").settitle("mtip Studenti"); builder.setpositivebutton("ok", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog, int id) { ); ); AlertDialog dialog = builder.create(); dialog.show(); 17

return rootview; // TODO: Rename method, update argument and hook method into UI event public void onbuttonpressed(uri uri) { if (mlistener!= null) { mlistener.onfragmentinteraction(uri); public void onattach(context context) { super.onattach(context); if (context instanceof OnFragmentInteractionListener) { mlistener = (OnFragmentInteractionListener) context; else { throw new RuntimeException(context.toString() + " must implement OnFragmentInteractionListener"); public void ondetach() { super.ondetach(); mlistener = null; public interface OnFragmentInteractionListener { // TODO: Update argument type and name void onfragmentinteraction(uri uri); Listing broj 8. Sadržaj klase StudentiFragment Sadržaj fragmenta StudentiFragment gotovo je identičan sadržaju fragmenta PretragaFragment s time što se labela (taster) za dodavanje studenta ne sakriva već se definiše onclicklistener za istu sa pozivom statičke metode displayview iz klase MTIPStudentiMain uz prosleđivanje reference na instancu klase StudentiDodavanjeFragment. Na navedeni način, klikom na prethodno spomenutu labelu, korisnik se preusmerava na fragment StudentiDodavanjeFragment. Sadržaj fragmenta StudentiDodavanjeFragment prikazan je u listingu koda broj 9. package rs.tfzr.mtipstudenti; import android.content.context; import android.net.uri; import android.os.bundle; import android.app.fragment; import android.view.layoutinflater; import android.view.view; import android.view.viewgroup; import android.widget.button; import android.widget.linearlayout; import android.widget.textview; import org.w3c.dom.text; 18

public class StudentiDodavanjeFragment extends Fragment { // TODO: Rename parameter arguments, choose names that match // the fragment initialization parameters, e.g. ARG_ITEM_NUMBER private static final String ARG_PARAM1 = "param1"; private static final String ARG_PARAM2 = "param2"; // TODO: Rename and change types of parameters private String mparam1; private String mparam2; private OnFragmentInteractionListener mlistener; protected TextView _textviewdodavanjelabela; protected Context _context; protected Button _btnpotvrdi; protected Button _btnodustani; protected LinearLayout _linearlayoutidstudenta; protected LinearLayout _linearlauyoutmain; public StudentiDodavanjeFragment() { // Required empty public constructor // TODO: Rename and change types and number of parameters public static StudentiDodavanjeFragment newinstance(string param1, String param2) { StudentiDodavanjeFragment fragment = new StudentiDodavanjeFragment(); Bundle args = new Bundle(); args.putstring(arg_param1, param1); args.putstring(arg_param2, param2); fragment.setarguments(args); return fragment; public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); if (getarguments()!= null) { mparam1 = getarguments().getstring(arg_param1); mparam2 = getarguments().getstring(arg_param2); public View oncreateview(layoutinflater inflater, ViewGroup container, Bundle savedinstancestate) { // Inflate the layout for this fragment View rootview = inflater.inflate(r.layout.fragment_studenti_dodavanje_izmena, container, false); this._context = rootview.getcontext(); this._textviewdodavanjelabela = (TextView)rootView.findViewById(R.id.textViewStudentiNazivAkcije); this._textviewdodavanjelabela.settext("dodavanje studenta"); this._linearlauyoutmain = (LinearLayout)rootView.findViewById(R.id.dodavanjeIzmenaMainLinearLayout); this._linearlayoutidstudenta = (LinearLayout)rootView.findViewById(R.id.linearLayoutIDStudenta); this._linearlauyoutmain.removeview(this._linearlayoutidstudenta); this._btnpotvrdi = (Button)rootView.findViewById(R.id.buttonPotvrdi); this._btnodustani = (Button)rootView.findViewById(R.id.buttonOdustani); this._btnodustani.setonclicklistener(new View.OnClickListener() { 19

public void onclick(view view) { MTIPStudentiMain.displayView(new StudentiFragment(),MTIPStudentiMain._activity); ); return rootview; // TODO: Rename method, update argument and hook method into UI event public void onbuttonpressed(uri uri) { if (mlistener!= null) { mlistener.onfragmentinteraction(uri); public void onattach(context context) { super.onattach(context); if (context instanceof OnFragmentInteractionListener) { mlistener = (OnFragmentInteractionListener) context; else { throw new RuntimeException(context.toString() + " must implement OnFragmentInteractionListener"); public void ondetach() { super.ondetach(); mlistener = null; public interface OnFragmentInteractionListener { // TODO: Update argument type and name void onfragmentinteraction(uri uri); Listing broj 9. Sadržaj klase StudentDodavanjeFragment Analizom listinga koda broj 9 da se zaključiti da se u spomenutom fragmentu formiraju petoro bitnih objekata: objekat tipa TextView koji će se koristiti kao labela i menjaće se tekst iste kako bi se naznačilo da li se radi o formi za Dodavanje studenta ili Izmenu studenta, objekat tipa Context koji se odnosi na fragment tj. aktivnost u kojem se isti poziva, dva objekta tipa Button koji će se imati ulogu tastera za potvrđivanje akcije (btnpotvrdi) i odustajanje (btnodustani) od iste, dva objekta tipa LinearLayout. Jedan od navedenih LinearLayout objekta će referencirati glavni layout fragmenta koji nosi identifikator R.id.dodavanjeIzmenaMainLinearLayout dok će drugi referencirati LinearLayout sa identifikatorom R.id.linearLatoutIDStudenta kako bi se isti mogao ukloniti pošto je navedeno polje za Dodavanje studenta nepotrebno, ali je za Izmenu studenta potrebno pa se stoga koristi unutar fragmenta StudentiIzmenaFragment. Unutar poziva metode oncreateview vidi se da se koristi layout fragment_studenti_dodavanje_izmena.xml na osnovu indentifikatora R. fragment_studenti_dodavanje_izmena i isti se formira putem inflater-a. Dalje se instanciraju prethodno spomenuti objekti i dodelju se odgovarajući listeneri. Takođe, bitno je napomenuti da se tasteru za odustajanje od akcije dodeljuje onclicklistener i klikom na isti korisnik se preusmerava na fragment StudentiFragment. 20

Slika broj 4. Fragment Pretraga studenata Slika broj 5. Dialog koji ukazuje da pretragu studenata treba implementirati Slika broj 6. Fragment Studenti Slika broj 7. Fragment Dodavanje studenta 21

Slika broj 8. Dialog koji ukazuje da upravljanje Studijskim smerovima treba implementirati Ukoliko su svi koraci ove vežbe adekvatno ispraćeni MTIP Studenti Android aplikacija bi trebala da se bez problema build-uje i pokrene na odabranom emulatoru. Na slikama broj 4, 5, 6, 7 i 8 prikazani su rezultati modifikacije aplikacije iz prethodne vežbe (MTIPLab04). Na slici broj 4 prikazan je izgled fragmenta Pretraga studenta, dok je na slici broj 5 prikazan dijalog koji ukazuje da pretragu studenata treba implementirati. Slika broj 6 prikazuje fragment Studenti dok slika broj 7 prikazuje fragment Dodavanje studenta. Slika broj 8 prikazuje dialog koji ukazuje da upravljanje Studijskim smerovima treba implementirati 22