JavaFx – TextFinder

Merhaba arkadaşlar bu haftaki projemiz; kendimize bir textFinder yapmak olacak. Bir metin girilip daha sonra içerisinde kelime aratacağız, veya aradığımız kelime içinde hiç geçiyor mu, geçiyorsa kaç defa geçiyor gibi ufak bilgileri gösterecek.

Ekran görüntüsü;
1

Tasarımı ben yukarıdaki gibi düşündüm tabi ki siz kendinize göre yapabilirsiniz.
Koda geçersek;

@FXML
    private TextArea textArea;
    @FXML
    private TextField textField;
    @FXML
    private Label lbl_count;
    int position,startFrom=0;
    String historyText="";

Bu tanımlamalar dan üçü JavaFx’in kendi tanımlamaları diğerleri ise bizim aşağıda işe yarayacak olarak tanımlamalarımız.

@FXML
    private void actFind(ActionEvent event) {
        int counter=0;
        if(textArea.getText().equals("")||textField.getText().equals("")){
            Alert alert = new Alert(AlertType.INFORMATION);
            alert.setTitle("Uyarı!");
            alert.setHeaderText("Uyarı!");
            alert.setContentText("Lütfen, bir metin girdiğinize emin olunuz!");
            alert.getButtonTypes().setAll(new ButtonType("Tamam"));
            alert.showAndWait();
        }

/**
 * Yukarıda ki alert javafx ile gelen swingde ki alert dialog'un daha
 * güzelleştirilmiş versiyonu diyebiliriz. Bu alert eğer textArea'ya herhangi
*  bir metin girilmemişse veya aranacak bir kelime girilmemişse karşımıza çıkacak.
 */
        else{
            String text = textArea.getText();//metini çekiyoruz
            String wanted = textField.getText();//aranan kelimeyi çekiyoruz
            String[] txtArray = text.split(" ");//metini boşluklara göre çekiyoruz
            if(historyText.equals("")){
                /**
                 * Burada ki sorgu ilk kez mi arama yaptığımızı kontrol ediyor
                 * ilk kez arama yapıyorsak bunu kaydediyor
                 */
                historyText=wanted;
                position=0;
            }
            else if(!historyText.equals(wanted)){
                /**
                 * Eğer ilk aramamız değilse ve daha önceki kelimede değilse
                 * her şeyin baştan yapılması gerek bu yüzden position sıfırlanıyor
                 */
                historyText=wanted;
                position=0;
            }
            if(textArea.getText().length()<=position)
                /**
                 * Metnin sonuna gelip gelmediğimizi kontrol ediyoruz
                 */
                position=0;
             /**
             * Bütün ön kontroller bittiğine göre şimdi aramaya başlayalım
             * Eğer aradığımız kelime txtArrayin içinde yoksa counter arttırılıyor
             * Eğer kelimeyi hiç bulamazsa txtArrayin uzunluğuyla aynı olacak
             * Ve buda bize aradığı kelimenin burada bulunmadığını anlatacak
             */
            for (int i = 0; i < txtArray.length; i++) {                 if(!txtArray[i].equals(wanted)){                     counter++;                 }if(counter==txtArray.length){                     Alert alert = new Alert(AlertType.WARNING);                     alert.setTitle("Uyarı!");                     alert.setHeaderText("Uyarı!");                     alert.setContentText("Girdiğiniz kelime metinde bulunamadı!");                     alert.getButtonTypes().setAll(new ButtonType("Tamam"));                     alert.showAndWait();                         lbl_count.setText("0");                 }                 }             /**              * Eğer daha önce bir kelime bulunmuşsa önceki kalınan index'ten               * aramaya devam edecek.              * positionCaret ve altında ki iki metod sayesinde kelime mouse ile              * çift tıklanmış gibi seçili olacak.              */             if(position>0){
                for(int i=startFrom; i < txtArray.length; i++) {
                    if(txtArray[i].equals(wanted)){
                        textArea.positionCaret(position);
                        textArea.requestFocus();
                        textArea.selectEndOfNextWord();
                        position += txtArray[i].length()+1;
                        startFrom=i+1;
                        break;
                    }
                    position += txtArray[i].length()+1;
                } 
            }
            else{
                for(int i=0; i < txtArray.length; i++) {
                    startFrom=i+1;
                    if(txtArray[i].equals(wanted)){
                        textArea.positionCaret(position);
                        textArea.requestFocus();
                        textArea.selectEndOfNextWord();
                        position += txtArray[i].length()+1;
                        break;
                    }
                    position += txtArray[i].length()+1;  
                }   
            }   
        }
    }

Alert görüntülerimiz;

Şimdi aradığımız kelime metin içinde kaç defa geçtiğini sayacak metodu yazabiliriz.

@FXML
private void actCount(ActionEvent event) {
        String text = textArea.getText();
        String wanted = textField.getText();
        String[] txtArray = text.split(" ");
        int counter=0;
        for (int i = 0; i < txtArray.length; i++) {
            if(txtArray[i].equals(wanted)){
                counter++;
            }if(i==txtArray.length-1){
                lbl_count.setText(String.valueOf(counter));
                lbl_count.setTextFill(Color.web("#FF0000"));
            }
        }
            
    }
/**
     * Yukarıda yaptığımız gibi metni ayırıyoruz, aranan kelimeyi çekiyoruz 
     * ve her kelimeyi bulduğunda counteri bir arttırıyoruz, 
     * daha sonrada bunu kırmızı olarak yazdırıyoruz.
     */

Umarım yazımı beğenmişsinizdir. Uygulamayı buradan indirebilirsiniz.

JavaFx – Döviz Kurları (JSON)

Merhaba arkadaşlar, bu yazımda döviz kurlarını doviz.com sitesinin sunduğu api ile json parse ederek, listeye aktaran otomatik yenileyen ve istediğiniz zamanda yenileme yapabileceğiniz bir uygulama olacak.

Bu uygulamanın ekran görüntüsü olacak.

prog

Koda geçersek;

Her zaman ki gibi JavaFx – FXML Application olarak projemizi oluşturuyoruz.

Currency adında yeni bir class oluşturuyoruz, bu class bizim jsondan çekeceğimiz verileri tutacak.

public class Currency {

public double selling;
public double buying;
public double change_rate;
public String name;
public String fullName;
public String code;
public int curr;

public double getSelling() {
return selling;
}

public void setSelling(double selling) {
this.selling = selling;
}

public double getBuying() {
return buying;
}

public void setBuying(int buying) {
this.buying = buying;
}

public double getChange_rate() {
return change_rate;
}

public void setChange_rate(double change_rate) {
this.change_rate = change_rate;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getFullName() {
return fullName;
}

public void setFullName(String fullName) {
this.fullName = fullName;
}

public String getCode() {
return code;
}

public void setCode(String code) {
this.code = code;
}

/**
* @return the currency
*/
public int getCurrency() {
return curr;
}

/**
* @param currency the currency to set
*/
public void setCurrency(int curr) {
this.curr = curr;
}

}

FXMLDocumentController classına geçersek,
Gerekli tanımlamaları yapıyoruz.

@FXML
    private ListView list_currency;
    @FXML
    private Label lbl_currencyName;
    @FXML
    private Label lbl_buying;
    @FXML
    private Label lbl_selling;
    @FXML
    private Label lbl_changeRate;
    @FXML
    private Label lbl_code;
    @FXML
    private RadioButton rb_refreshAutomatic;
    //kur listelerini tutacak listemiz
    //listview observableList ile çalıştığı için bu şekilde tanımlıyoruz
    ObservableList currList = FXCollections.observableArrayList();

initialize methodu ilk çalışan fonksiyonumuz

    @Override
    public void initialize(URL url, ResourceBundle rb) {
        //Api adresi tanımlanıyor
        String urlDoviz = "https://www.doviz.com/api/v1/currencies/all/latest";
        //Fonksiyona gönderiliyor
        getJsonData(urlDoviz);
        
    }

getJsonData fonksiyonunda Json verimizi Stringe dönüştürüyoruz. Burada ki işlemleri daha kısaltabiliriz fakat BufferedReader vs. gibi classlarıda göstermek istedim.

//Apide ki bilgileri stringe çevirecek fonksiyon
    public void getJsonData(String url){
        Currency[] currency = new Currency[68];
        String result = "";
        try {
            URL urlDoviz = new URL(url);
            HttpURLConnection urlDovizCom = (HttpURLConnection) urlDoviz.openConnection();
            InputStreamReader inputStreamReader = new InputStreamReader(urlDovizCom.getInputStream());
            try (BufferedReader bufferedReader = new BufferedReader(inputStreamReader)) {
                String line = "";
                while((line = bufferedReader.readLine()) != null){
                    result += line;
                }
            }
            
        } catch (MalformedURLException ex) {
            Logger.getLogger(FXMLDocumentController.class.getName()).log(Level.SEVERE, null, ex);
        } catch (IOException ex) {
            Logger.getLogger(FXMLDocumentController.class.getName()).log(Level.SEVERE, null, ex);
        }
        //json datayı parse edecek fonksiyona gönderiyoruz
        getJsonParseData(result);
        
    }

Json verimizi çektikten sonra parse etme işlemine geçiyoruz. getJsonParseData fonksiyonu buna yarayacak.

public void getJsonParseData(String json){
        
        //Listview'da kur isimlerini göstereceğimiz liste
        ObservableList currListName = FXCollections.observableArrayList();
        try {
            //bizim jsonumuz dizi şeklinde olduğu için array olarak çektik
            JSONArray jsonArray = new JSONArray(json);
            //for döngüsünde her bir dizide ki elemanları teker teker çekiyoruz
            //en sonunnda da Currency türünde diziye atıyoruz
            for (int i = 0; i < jsonArray.length(); i++) {
                Currency currency = new Currency();
                currency.fullName = jsonArray.getJSONObject(i).getString("full_name");
                currency.name = jsonArray.getJSONObject(i).getString("name");
                currency.code = jsonArray.getJSONObject(i).getString("code");
                currency.selling = jsonArray.getJSONObject(i).getDouble("selling");
                currency.buying = jsonArray.getJSONObject(i).getDouble("buying");
                currency.change_rate = jsonArray.getJSONObject(i).getDouble("change_rate");
                currency.curr = jsonArray.getJSONObject(i).getInt("currency");
                currList.add(currency);
            }
            //bunu aynı for içinde de yapabilirdik 
            for (int i = 0; i < jsonArray.length(); i++) {
                currListName.add(jsonArray.getJSONObject(i).getString("full_name"));                
            }
            //listView'a isimleri atıyoruz
            list_currency.setItems(currListName);
            //ilk açıldığında ilk indexde ki elemanın verilerini ekranda göstereceğiz
            lbl_buying.setText(Double.toString(currList.get(0).buying));
            lbl_selling.setText(Double.toString(currList.get(0).selling));
            lbl_changeRate.setText(Double.toString(currList.get(0).change_rate));
            if (currList.get(0).change_rate<0) {
                lbl_changeRate.setTextFill(Color.web("#FF0000"));
            }else{
                lbl_changeRate.setTextFill(Color.web("#008000"));
            }
            lbl_currencyName.setText(currList.get(0).fullName);
            lbl_code.setText(currList.get(0).code);
            
                    
        } catch (JSONException ex) {
            Logger.getLogger(FXMLDocumentController.class.getName()).log(Level.SEVERE, null, ex);
        }
        
        
    }

Bu işlemlerden sonra aslında çoğu işimiz bitti, şimdi buttonlarda vs. yapılacak işlemleri ayarlayalım. getCurrencyPass fonksiyonu listViewda kur seçtiğimizde detaylarını labellara aktaracak.

@FXML
    private void getCurrencyPass(MouseEvent event) {
        //seçilen isimi aktarıyoruz
        String fullName = list_currency.getSelectionModel().getSelectedItem();
        for (int i = 0; i < currList.size(); i++) {
            //eğer seçilen kişi ilk listedeki elemanında ismin aynısı ise 
            if (fullName.equals(currList.get(i).fullName)) {
                lbl_buying.setText(Double.toString(currList.get(i).buying));
                lbl_selling.setText(Double.toString(currList.get(i).selling));
                lbl_changeRate.setText(Double.toString(currList.get(i).change_rate));
                if (currList.get(i).change_rate<0) {
                    lbl_changeRate.setTextFill(Color.web("#FF0000"));
                }else{
                    lbl_changeRate.setTextFill(Color.web("#008000"));
                }
                lbl_currencyName.setText(currList.get(i).fullName);
                lbl_code.setText(currList.get(i).code);
            }
        }
    }

Ekrandaki kurları yenile butonunda çalışacak fonksiyonumuzu yazalım.

    @FXML
    private void refreshCurrency(ActionEvent event) {
        //yukarıda yazdığımız fonksiyonları tekrar tetikliyoruz
        getJsonData("https://www.doviz.com/api/v1/currencies/all/latest");
    }

Bunuda yazdıktan sonra otomatik olarak kurları yenileyecek fonksiyonumuzu yazıyoruz.

    @FXML
    private void refreshAutomatic(ActionEvent event) {
        //eğer seçilmiş ise
        if(rb_refreshAutomatic.isSelected()){
            //milisaniye şeklinde çalışır bu yüzden 1 dakikanın milisaniye cinsinden yazıyoruz
            Timeline timeline = new Timeline(new KeyFrame(Duration.millis(60000), new EventHandler() {

                @Override
                public void handle(ActionEvent event) {
                    //tekrar tetikliyoruz
                    getJsonData("https://www.doviz.com/api/v1/currencies/all/latest");
                }
            }));
            //sürekli tekrar etmesi için INDEFINITE olarak ayarlıyoruz
            timeline.setCycleCount(Animation.INDEFINITE);
            timeline.play();
        }
    }

Uygulamanın dosyasını buradan indirebilirsiniz.

JavaFx-Atama Programı(Veri Tabanlı)

JavaFx kullanarak basit bir öğretmen atama programı nasıl yapılır?
Ekran görüntüsü bu şekilde olacak. Öğretmenler ve yaşları tamamen kafadan atıldı, gerçekle ilgisi yoktur 🙂
1.jpg
Paylaşacağım dosyanın içinde veri tabanı olacak ama yine de nasıl bir veri tabanında uğraşacağımızı görelim.
2.jpg
Şimdi kodlara geçersek; Veri tabanına bağlantı sınıfımız aynı olacak diğer paylaştığım yazıdakiler gibi, ben ilk önce veri tabanından veri çekeceğimiz sınıfı yazalım.Sınıfımızın adı VeritabaniController.

//Bu fonksiyonu combo box'a ekleyeceklerimiz için kullanacağız
public ObservableList sehirGetir(){
        ObservableList list = FXCollections.observableArrayList();
        try {
            db.baglan();//veri tabanına bağlandık
            PreparedStatement ps =(PreparedStatement) db.connection.prepareStatement("select Sehir from atanacak_yerler");//komutumuzu yazdık
            ResultSet rs = ps.executeQuery();//sonuçlarını çektik
            while (rs.next()) {                
                list.add(rs.getString("Sehir"));//observable list'e ekledik
            }
            return list;//listeyi geri döndürdük
        } catch (SQLException ex) {
            System.out.println(ex.getMessage());
        }
        return list;
    }
//Arayüzde ki combo box için kullanacağımız fonksiyon
public ObservableList yerGetir(){
        ObservableList list = FXCollections.observableArrayList();
        try {
            db.baglan();
            PreparedStatement ps =(PreparedStatement) db.connection.prepareStatement("select Yer from atanacak_yerler");
            ResultSet rs = ps.executeQuery();
            while (rs.next()) {                
                list.add(rs.getString("Yer"));
            }
            return list;
        } catch (SQLException ex) {
            System.out.println(ex.getMessage());
        }
        return list;
    }
//Yine combo box için kullanacağımız bir başka fonksiyon
public ObservableList bransGetir(){
        ObservableList list = FXCollections.observableArrayList();
        try {
            db.baglan();
            PreparedStatement ps =(PreparedStatement) db.connection.prepareStatement("select Brans from atanacaklar");
            ResultSet rs = ps.executeQuery();
            while (rs.next()) {                
                list.add(rs.getString("Brans"));
            }
            return list;
        } catch (SQLException ex) {
            System.out.println(ex.getMessage());
        }
        return list;
    }
/*Veri tabanında şehirlere göre okullar ayrılmış durumda bu yüzden Antalya seçilmişse Antalya'da ki okulları getirecek fonksiyon*/
public ObservableList secilenYerGetir(String sehir){//sectiğimiz şehri parametre olarak gönderdik
        ObservableList list = FXCollections.observableArrayList();
        try {
            db.baglan();
            PreparedStatement ps =(PreparedStatement) db.connection.prepareStatement("select Yer from atanacak_yerler where sehir = ?");
            ps.setString(1, sehir);//gelen şehri komuta ekledik
            ResultSet rs = ps.executeQuery();
            while (rs.next()) {                
                list.add(rs.getString("Yer"));//listeye gelen yeri ekledik
            }
            return list;
        } catch (SQLException ex) {
            System.out.println(ex.getMessage());
        }
        return list;
    }
//Atama yap dedikten sonra bize atanmaya uygun öğretmenlerin branşlarını,isimlerini yaşlarını döndürecek
public ObservableList atamaYap(String brans){//branşını gönderdik çünkü asıl önemli olan branş bizim için
        ObservableList list = FXCollections.observableArrayList();
       
        try {
            db.baglan();
            PreparedStatement ps = (PreparedStatement) db.connection.prepareStatement("select Ad,Brans,Yas from atanacaklar where Brans = ?");
            ps.setString(1, brans);//gelen branşı komuta ekledik
            ResultSet rs = ps.executeQuery();
            while (rs.next()){  
                Atananlar atananlar = new Atananlar();//Atananlar diye bir sınıf oluşturduk aşağıda iç kısmını yazacağım              
                atananlar.setAd(rs.getString("Ad"));
                atananlar.setBrans(rs.getString("Brans"));
                atananlar.setYas(rs.getInt("Yas"));
                list.add(atananlar);//listeye ekledik atanan sınıfını
            }
            return list;//listeyi gönderdik
        } catch (Exception e) {
            System.out.println(e.getMessage());
        }
        return list;
    }

Şimdi unutmadan Atananlar sınıfında ne olacağını yazalım. Komutlarını yazmayacağım çünkü gereksiz uzun. Sadece String Ad, Brans ve Integer Yas oluşturup. Getter ve Setter yapacağız.
Şimdi FXMLDocumentController sınıfını yazalım. Bu arada aşağıda yazılmadı ama VeritabaniController gibi sınıfları en üstte çağırdım her yerde kullanabilmek için, tanımlanmamışsa en üstte tanımlamışım dır.

    public void cmbSehir(){//combo box'lara gelen şehirleri ekliyeceğiz
        list = vc.sehirGetir();//liste döndüren fonksiyonu çağırdık
        for (int i = 0; i < list.size(); i++) {
            cmb_sehir.getItems().add(list.get(i));//combo box'a ekledik
        }
    }

    public void cmbYer(){//komutlarımız aynı üstteki ile
        list = vc.yerGetir();
        for (int i = 0; i < list.size(); i++) {
            cmb_yer.getItems().add(list.get(i));
        }
    }
//branşlar veri tabanında aynı olarak birden çok var aynı olanları ayıklamamız gerekli
    public void cmbBrans(){
        list = vc.bransGetir();//fonksiyonu çağırıp listeye ekledik
        for (int i = 0; i < list.size(); i++) {
            if(i==0)//ilk gelen olmayacağı için hemen ekliyoruz
                cmb_brans.getItems().add(list.get(i));
            else
                while(true){
                    if(cmb_brans.getItems().contains(list.get(i)))//bu combo box'da eğer ekli ise iptal ediyoruz
                        break;
                    else//yoksa ekliyoruz
                        cmb_brans.getItems().add(list.get(i));
                }
        }
    }
//ve ilk başlangıçta bu yazdıklarımızı çağırıyoruz
    @Override
    public void initialize(URL url, ResourceBundle rb) {
        cmbSehir();
        cmbYer();
        cmbBrans();
    }
//Buton için onAction metodunu yazıyoruz
    @FXML
    private void atamaYap(ActionEvent event) {
        listView.getItems().clear();//ilk başta listview'in içini temizliyoruz
        int a = 0;//bu bir kontrol için lazım olacak
        ObservableList list2 = vc.atamaYap(cmb_brans.getSelectionModel().getSelectedItem());//gelecekleri observable list'e ekledik
        int ihtiyac = Integer.valueOf(txt_ihtiyac.getText());//arayüzdeki textfield'dan aldığımız değeri atıyoruz
            for (int i = 0; i < ihtiyac; i++) {                 String atanan = "Adı="+list2.get(i).getAd()+"\nBrans= "+list2.get(i).getBrans()+"\nYas= "+String.valueOf(list2.get(i).getYas()); /*Gelenleri tek bir string'e dönüştürdük*/                 if(list.contains(atanan)){//aynısı var mı kontrol ettik                     a++;//kontrol için oluşturduğumuz int değerini arttırdık                     break;                 }                 else                     list.add(atanan);//eğer aynısı yoksa ekledik             }                  if(a>0){//eğer en sonra a artmışsa aynısından bulmuş demek ki
//Bunu en sonra yazdım çünkü öbür türlü iki defa bulursa iki defa uyarı ekranı gösterecekti
            JOptionPane.showMessageDialog(null, "İhtiyacınız kadar öğretmen bulunamadı.");
        }
            listView.setItems(list);//list view'a ekledik
    }

Sonradan aklıma gelen bir şeyi de sonra yazmak zorunda kaldım şehir seçildiğinde orada hangi okul varsa combo box’ta da o gözüksün dedim onun için cmb_sehir combo box’una bir onAction ekledim komutları şu şekilde;

    @FXML
    private void sehirSecildi(ActionEvent event) {
        String secilen = cmb_sehir.getSelectionModel().getSelectedItem();//seçilen şehiri aldık
        list = vc.secilenYerGetir(secilen);//observable listeye ekledik
        for (int i = 0; i < list.size(); i++) {
            cmb_yer.getItems().clear();//sehir combo box'unu sildik
            cmb_yer.getItems().add(list.get(i));//gelen okulları tekrar ekledik
        }
    }
    

Veri tabanının dosyasının da içinde olduğu proje dosyasını buradan indirebilirsiniz.