fixed missing elements when searching

* minor clean up
This commit is contained in:
Jannik 2019-05-06 00:50:27 +02:00
parent 46cd28a642
commit fdb39ea2f5
Signed by: Seil0
GPG Key ID: E8459F3723C52C24
1 changed files with 238 additions and 261 deletions

View File

@ -37,6 +37,7 @@ import java.util.Locale;
import java.util.ResourceBundle; import java.util.ResourceBundle;
import java.util.concurrent.ExecutorService; import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; import java.util.concurrent.Executors;
import java.util.stream.Collectors;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
@ -55,12 +56,8 @@ import com.jfoenix.transitions.hamburger.HamburgerBackArrowBasicTransition;
import javafx.animation.TranslateTransition; import javafx.animation.TranslateTransition;
import javafx.application.Platform; import javafx.application.Platform;
import javafx.beans.value.ChangeListener;
import javafx.beans.value.ObservableValue;
import javafx.collections.FXCollections; import javafx.collections.FXCollections;
import javafx.collections.ObservableList; import javafx.collections.ObservableList;
import javafx.event.ActionEvent;
import javafx.event.EventHandler;
import javafx.fxml.FXML; import javafx.fxml.FXML;
import javafx.scene.Node; import javafx.scene.Node;
import javafx.scene.control.ChoiceBox; import javafx.scene.control.ChoiceBox;
@ -203,7 +200,7 @@ public class MainWindowController {
dbController = DBController.getInstance(); dbController = DBController.getInstance();
} }
public void init() { public void init() {
LOGGER.info("Initializing Project-HomeFlix build " + buildNumber); LOGGER.info("Initializing Project-HomeFlix build " + buildNumber);
xmlController.loadSettings(); // load settings xmlController.loadSettings(); // load settings
@ -246,8 +243,8 @@ public class MainWindowController {
} }
/** /**
* Initialize the tables (treeTableViewfilm and sourcesTable) * Initialize the tables (treeTableViewfilm and sourcesTable) only needed for
* only needed for Tabel-Mode * Tabel-Mode
*/ */
private void initTabel() { private void initTabel() {
@ -283,7 +280,6 @@ public class MainWindowController {
burgerTask.setRate(-1.0); burgerTask.setRate(-1.0);
burgerTask.play(); burgerTask.play();
menuTrue = false; menuTrue = false;
} else { } else {
sideMenuSlideIn(); sideMenuSlideIn();
burgerTask.setRate(1.0); burgerTask.setRate(1.0);
@ -295,166 +291,127 @@ public class MainWindowController {
} }
}); });
languageChoisBox.getSelectionModel().selectedIndexProperty().addListener(new ChangeListener<Number>() { languageChoisBox.getSelectionModel().selectedIndexProperty().addListener((e, oldValue, newValue) -> {
@Override String local = languageChoisBox.getItems().get((int) newValue).toString();
public void changed(ObservableValue<? extends Number> ov, Number value, Number new_value) { local = local.substring(local.length() - 6, local.length() - 1); // reading only en_US from English (en_US)
String local = languageChoisBox.getItems().get((int) new_value).toString(); XMLController.setUsrLocal(local);
local = local.substring(local.length() - 6, local.length() - 1); // reading only en_US from English (en_US) setLocalUI();
XMLController.setUsrLocal(local); xmlController.saveSettings();
setLocalUI();
xmlController.saveSettings();
}
}); });
branchChoisBox.getSelectionModel().selectedIndexProperty().addListener(new ChangeListener<Number>() { branchChoisBox.getSelectionModel().selectedIndexProperty().addListener((e, oldValue, newValue) -> {
@Override if (branchChoisBox.getItems().get((int) newValue).toString() == "beta") {
public void changed(ObservableValue<? extends Number> ov, Number value, Number new_value) { XMLController.setUseBeta(true);
if (branchChoisBox.getItems().get((int) new_value).toString() == "beta") { } else {
XMLController.setUseBeta(true); XMLController.setUseBeta(false);
} else {
XMLController.setUseBeta(false);
}
xmlController.saveSettings();
} }
xmlController.saveSettings();
}); });
fontsizeSlider.valueProperty().addListener(new ChangeListener<Number>() { fontsizeSlider.valueProperty().addListener(e -> {
@Override XMLController.setFontSize(fontsizeSlider.getValue());
public void changed(ObservableValue<? extends Number> ov, Number old_val, Number new_val) { if (!getCurrentTitle().isEmpty()) {
XMLController.setFontSize(fontsizeSlider.getValue()); setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl()));
if (!getCurrentTitle().isEmpty()) {
setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl()));
}
xmlController.saveSettings();
} }
xmlController.saveSettings();
}); });
// Table-Mode actions // Table-Mode actions
searchTextField.textProperty().addListener(new ChangeListener<String>() { searchTextField.textProperty().addListener((e, oldValue, newValue) -> {
@Override filmRoot.getChildren().clear();
public void changed(ObservableValue<? extends String> observable, String oldValue, String newValue) { filterData.clear();
ObservableList<FilmTabelDataType> helpData; filterData = filmsList.stream()
filterData.clear(); .filter(x -> x.getTitle().toLowerCase().contains(searchTextField.getText().toLowerCase()))
filmRoot.getChildren().clear(); .collect(Collectors.toCollection(FXCollections::observableArrayList));
helpData = filmsList; addFilmsToTable(filterData);
for (int i = 0; i < helpData.size(); i++) { if (searchTextField.getText().hashCode() == hashA) {
if (helpData.get(i).getTitle().toLowerCase().contains(searchTextField.getText().toLowerCase())) { XMLController.setColor("000000");
filterData.add(helpData.get(i)); // add data from newDaten to filteredData where title contains search input colorPicker.setValue(new Color(0, 0, 0, 1));
} applyColor();
}
for (int i = 0; i < filterData.size(); i++) {
filmRoot.getChildren().add(new TreeItem<FilmTabelDataType>(filterData.get(i))); // add filtered data to root node after search
}
if (searchTextField.getText().hashCode() == hashA) {
XMLController.setColor("000000");
colorPicker.setValue(new Color(0, 0, 0, 1));
applyColor();
}
} }
}); });
like.setOnAction(new EventHandler<ActionEvent>() { like.setOnAction(e -> {
@Override dbController.like(getCurrentStreamUrl());
public void handle(ActionEvent event) { filmsList.set(indexList, dbController.getDatabaseFilm(getCurrentStreamUrl()));
dbController.like(getCurrentStreamUrl()); refreshTableElement();
filmsList.set(indexList, dbController.getDatabaseFilm(getCurrentStreamUrl()));
refreshTableElement();
}
}); });
dislike.setOnAction(new EventHandler<ActionEvent>() { dislike.setOnAction(e -> {
@Override dbController.dislike(getCurrentStreamUrl());
public void handle(ActionEvent event) { filmsList.set(indexList, dbController.getDatabaseFilm(getCurrentStreamUrl()));
dbController.dislike(getCurrentStreamUrl()); refreshTableElement();
filmsList.set(indexList, dbController.getDatabaseFilm(getCurrentStreamUrl()));
refreshTableElement();
}
}); });
/** // FIXME fix bug when sort by ASCENDING, wrong order
* FIXME fix bug when sort by ASCENDING, wrong order columnFavorite.sortTypeProperty().addListener((e, paramT1, paramT2) -> {
*/ filmRoot.getChildren().clear();
columnFavorite.sortTypeProperty().addListener(new ChangeListener<SortType>() { filterData.clear();
@Override
public void changed(ObservableValue<? extends SortType> paramObservableValue, SortType paramT1, SortType paramT2) {
filmRoot.getChildren().clear();
filterData.clear();
if (paramT2.equals(SortType.DESCENDING)) { if (paramT2.equals(SortType.DESCENDING)) {
// add favorites at the top // add favorites at the top
for (FilmTabelDataType film : filmsList) { for (FilmTabelDataType film : filmsList) {
if (film.getFavorite()) { if (film.getFavorite()) {
filterData.add(0, film); filterData.add(0, film);
} else { } else {
filterData.add(film); filterData.add(film);
} }
} }
} else { } else {
// add favorites at the bottom // add favorites at the bottom
for (FilmTabelDataType film : filmsList) { for (FilmTabelDataType film : filmsList) {
if (!film.getFavorite()) { if (!film.getFavorite()) {
filterData.add(0, film); filterData.add(0, film);
} else { } else {
filterData.add(film); filterData.add(film);
}
} }
} }
addFilmsToTable(filterData);
} }
addFilmsToTable(filterData);
}); });
// Change-listener for treeTableViewfilm // Change-listener for treeTableViewfilm
filmsTreeTable.getSelectionModel().selectedItemProperty().addListener(new ChangeListener<Object>() { filmsTreeTable.getSelectionModel().selectedItemProperty().addListener((e, paramT1, paramT2) -> {
@Override if (filmsTreeTable.getSelectionModel().getSelectedItem() == null) {
public void changed(ObservableValue<?> observable, Object oldVal, Object newVal) { return;
if (filmsTreeTable.getSelectionModel().getSelectedItem() == null) { }
return;
currentTableFilm = filmsTreeTable.getSelectionModel().getSelectedItem().getValue(); // set the current film object
indexTable = filmsTreeTable.getSelectionModel().getSelectedIndex(); // get selected items table index
for (FilmTabelDataType film : filmsList) {
if (film.equals(currentTableFilm)) {
indexList = filmsList.indexOf(film); // get selected items list index
} }
}
currentTableFilm = filmsTreeTable.getSelectionModel().getSelectedItem().getValue(); // set the current film object last = indexTable - 1;
indexTable = filmsTreeTable.getSelectionModel().getSelectedIndex(); // get selected items table index next = indexTable + 1;
for (FilmTabelDataType film : filmsList) {
if (film.equals(currentTableFilm)) {
indexList = filmsList.indexOf(film); // get selected items list index
}
}
last = indexTable - 1; if ((currentTableFilm.getCached().isAfter(lastValidCache)) && dbController.searchCacheByURL(getCurrentStreamUrl())) {
next = indexTable + 1; LOGGER.info("loading from cache: " + getCurrentTitle());
setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl()));
} else {
// this is not perfect!
new Thread(() -> {
Thread omdbAPIThread = new Thread(new OMDbAPIController(dbController, currentTableFilm, XMLController.getOmdbAPIKey()));
omdbAPIThread.setName("OMDbAPI");
omdbAPIThread.start();
synchronized (omdbAPIThread) {
if ((currentTableFilm.getCached().isAfter(lastValidCache) )|| dbController.searchCacheByURL(getCurrentStreamUrl())) { try {
LOGGER.info("loading from cache: " + getCurrentTitle()); omdbAPIThread.wait();
setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl())); } catch (InterruptedException e1) {
// System.out.println("cache date is: " + currentTableFilm.getCached().toString()); LOGGER.error(e1);
} else {
// System.out.println("either not cached or to old!");
// System.out.println("cache date is: " + currentTableFilm.getCached().toString());
// this is not perfect!
new Thread(new Runnable() {
public void run() {
Thread omdbAPIThread = new Thread(new OMDbAPIController(dbController, currentTableFilm, XMLController.getOmdbAPIKey()));
omdbAPIThread.setName("OMDbAPI");
omdbAPIThread.start();
synchronized (omdbAPIThread) {
try {
omdbAPIThread.wait();
} catch (InterruptedException e) {
LOGGER.error(e);
}
// update the GUI for the selected film
Platform.runLater(() -> {
setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl()));
});
}
} }
}).start(); // update the GUI for the selected film
} Platform.runLater(() -> {
setSelectedFilmInfo(dbController.readCache(getCurrentStreamUrl()));
});
}
}).start();
} }
}); });
@ -491,8 +448,7 @@ public class MainWindowController {
} }
if (output.contains("which: no vlc") || output == "") { if (output.contains("which: no vlc") || output == "") {
JFXInfoAlert vlcInfoAlert = new JFXInfoAlert("Info", JFXInfoAlert vlcInfoAlert = new JFXInfoAlert("Info",
XMLController.getLocalBundle().getString("vlcNotInstalled"), XMLController.getLocalBundle().getString("vlcNotInstalled"), btnStyle, primaryStage);
btnStyle, primaryStage);
vlcInfoAlert.showAndWait(); vlcInfoAlert.showAndWait();
} else { } else {
try { try {
@ -529,20 +485,20 @@ public class MainWindowController {
} }
@FXML @FXML
private void returnBtnclicked(){ private void returnBtnclicked() {
filmsTreeTable.getSelectionModel().select(last); filmsTreeTable.getSelectionModel().select(last);
} }
@FXML @FXML
private void forwardBtnclicked(){ private void forwardBtnclicked() {
filmsTreeTable.getSelectionModel().select(next); filmsTreeTable.getSelectionModel().select(next);
} }
// general fxml actions // general fxml actions
@FXML @FXML
private void aboutBtnAction() { private void aboutBtnAction() {
String bodyText = "Project HomeFlix \nVersion: " + version + " (Build: " + buildNumber + ") \"" String bodyText = "Project HomeFlix \nVersion: " + version + " (Build: " + buildNumber + ") \"" + versionName
+ versionName + "\" \n" + XMLController.getLocalBundle().getString("infoText"); + "\" \n" + XMLController.getLocalBundle().getString("infoText");
JFXInfoAlert infoAlert = new JFXInfoAlert("Project HomeFlix", bodyText, btnStyle, primaryStage); JFXInfoAlert infoAlert = new JFXInfoAlert("Project HomeFlix", bodyText, btnStyle, primaryStage);
infoAlert.showAndWait(); infoAlert.showAndWait();
} }
@ -557,7 +513,7 @@ public class MainWindowController {
} }
@FXML @FXML
private void addDirectoryBtnAction(){ private void addDirectoryBtnAction() {
DirectoryChooser directoryChooser = new DirectoryChooser(); DirectoryChooser directoryChooser = new DirectoryChooser();
directoryChooser.setTitle(XMLController.getLocalBundle().getString("addDirectory")); directoryChooser.setTitle(XMLController.getLocalBundle().getString("addDirectory"));
File selectedFolder = directoryChooser.showDialog(primaryStage); File selectedFolder = directoryChooser.showDialog(primaryStage);
@ -569,7 +525,7 @@ public class MainWindowController {
} }
@FXML @FXML
private void addStreamSourceBtnAction(){ private void addStreamSourceBtnAction() {
FileChooser fileChooser = new FileChooser(); FileChooser fileChooser = new FileChooser();
fileChooser.setTitle(XMLController.getLocalBundle().getString("addStreamSource")); fileChooser.setTitle(XMLController.getLocalBundle().getString("addStreamSource"));
File selectedFile = fileChooser.showOpenDialog(primaryStage); File selectedFile = fileChooser.showOpenDialog(primaryStage);
@ -602,7 +558,7 @@ public class MainWindowController {
} }
@FXML @FXML
private void autoplayToggleBtnAction(){ private void autoplayToggleBtnAction() {
XMLController.setAutoplay(!XMLController.isAutoplay()); XMLController.setAutoplay(!XMLController.isAutoplay());
xmlController.saveSettings(); xmlController.saveSettings();
} }
@ -613,8 +569,8 @@ public class MainWindowController {
} }
/** /**
* refresh all films in filmsList and in filmsTable * refresh all films in filmsList and in filmsTable clear the FilmsList and
* clear the FilmsList and FilmRoot children, then update the database * FilmRoot children, then update the database
*/ */
private void refreshAllFilms() { private void refreshAllFilms() {
filmsList.clear(); filmsList.clear();
@ -625,7 +581,9 @@ public class MainWindowController {
} }
/** /**
* add data from films-list to films-table * TODO rework! add data from a ObservableList to the films-table
*
* @param elementsList a list of elements you want to add
*/ */
public void addFilmsToTable(ObservableList<FilmTabelDataType> elementsList) { public void addFilmsToTable(ObservableList<FilmTabelDataType> elementsList) {
@ -634,22 +592,40 @@ public class MainWindowController {
// only if the entry contains a season and a episode it's a valid series // only if the entry contains a season and a episode it's a valid series
if (!element.getSeason().isEmpty() && !element.getEpisode().isEmpty()) { if (!element.getSeason().isEmpty() && !element.getEpisode().isEmpty()) {
// check if there is a series node to add the item // if there is any node check if it's the root node to the episode
for (int i = 0; i < filmRoot.getChildren().size(); i++) { // else there is no node at all so we must create a new
if (filmRoot.getChildren().get(i).getValue().getTitle().equals(element.getTitle())) { if (filmRoot.getChildren().size() > 0) {
// if a root node exists, add element as child for (int i = 0; i < filmRoot.getChildren().size(); i++) {
TreeItem<FilmTabelDataType> episodeNode = new TreeItem<>(new FilmTabelDataType( // if a root node exists, add element
element.getStreamUrl(), element.getTitle(), element.getSeason(), element.getEpisode(), // else create a new root node and add the element (if rootNode is the last
element.getFavorite(), element.getCached(), element.getImage())); // node) (works since we edit the element!)
filmRoot.getChildren().get(i).getChildren().add(episodeNode); if (filmRoot.getChildren().get(i).getValue().getTitle().equals(element.getTitle())) {
} else if (filmRoot.getChildren().get(i).nextSibling() == null) { TreeItem<FilmTabelDataType> episodeNode = new TreeItem<>(
// if no root node exists, create one and add element as child new FilmTabelDataType(element.getStreamUrl(), element.getTitle(),
TreeItem<FilmTabelDataType> seriesRootNode = new TreeItem<>(new FilmTabelDataType( element.getSeason(), element.getEpisode(), element.getFavorite(),
element.getTitle() + "_rootNode", element.getTitle(), "", "", element.getFavorite(), element.getCached(), element.getImage()));
element.getCached() , element.getImage())); filmRoot.getChildren().get(i).getChildren().add(episodeNode);
filmRoot.getChildren().add(seriesRootNode); } else if (filmRoot.getChildren().get(i).nextSibling() == null) {
TreeItem<FilmTabelDataType> seriesRootNode = new TreeItem<>(
new FilmTabelDataType(element.getTitle() + "_rootNode", element.getTitle(), "", "",
element.getFavorite(), element.getCached(), element.getImage()));
filmRoot.getChildren().add(seriesRootNode);
}
} }
} else {
// add new root node
TreeItem<FilmTabelDataType> seriesRootNode = new TreeItem<>(
new FilmTabelDataType(element.getTitle() + "_rootNode", element.getTitle(), "", "",
element.getFavorite(), element.getCached(), element.getImage()));
filmRoot.getChildren().add(seriesRootNode);
// add new element
TreeItem<FilmTabelDataType> episodeNode = new TreeItem<>(new FilmTabelDataType(
element.getStreamUrl(), element.getTitle(), element.getSeason(), element.getEpisode(),
element.getFavorite(), element.getCached(), element.getImage()));
filmRoot.getChildren().get(0).getChildren().add(episodeNode);
} }
} else { } else {
// if season and episode are empty, we can assume the object is a film // if season and episode are empty, we can assume the object is a film
filmRoot.getChildren().add(new TreeItem<FilmTabelDataType>(element)); filmRoot.getChildren().add(new TreeItem<FilmTabelDataType>(element));
@ -659,18 +635,18 @@ public class MainWindowController {
// add a all elements of sourcesList to the sources table on the settings pane // add a all elements of sourcesList to the sources table on the settings pane
public void addSourceToTable() { public void addSourceToTable() {
for (SourceDataType source: sourcesList) { for (SourceDataType source : sourcesList) {
sourceRoot.getChildren().add(new TreeItem<SourceDataType>(source)); // add data to root-node sourceRoot.getChildren().add(new TreeItem<SourceDataType>(source)); // add data to root-node
} }
} }
/** /**
* add a source to the newsources list * add a source to the newsources list
*
* @param path to the source * @param path to the source
* @param mode of the source (local or streaming) * @param mode of the source (local or streaming)
*/ */
public void addSource(String path, String mode) { public void addSource(String path, String mode) {
JsonObject source = null;
JsonArray newsources = null; JsonArray newsources = null;
try { try {
@ -683,7 +659,7 @@ public class MainWindowController {
} }
// add new source // add new source
source = Json.object().add("path", path).add("mode", mode); JsonObject source = Json.object().add("path", path).add("mode", mode);
newsources.add(source); newsources.add(source);
Writer writer = new FileWriter(XMLController.getDirHomeFlix() + "/sources.json"); Writer writer = new FileWriter(XMLController.getDirHomeFlix() + "/sources.json");
newsources.writeTo(writer); newsources.writeTo(writer);
@ -696,15 +672,13 @@ public class MainWindowController {
getSourcesList().clear(); getSourcesList().clear();
sourceRoot.getChildren().clear(); sourceRoot.getChildren().clear();
// clear the FilmsList and FilmRoot children, then update the database refreshAllFilms(); // refresh the FilmsList
refreshAllFilms();
checkAllPosters(); // check if there is anything to cache checkAllPosters(); // check if there is anything to cache
} }
/** /**
* set the color of the GUI-Elements * set the color of the GUI-Elements if usedColor is less than checkColor set
* if usedColor is less than checkColor set text fill white, else black * text fill white, else black
*/ */
private void applyColor() { private void applyColor() {
String menuBtnStyle; String menuBtnStyle;
@ -712,7 +686,8 @@ public class MainWindowController {
BigInteger checkColor = new BigInteger("78909cff", 16); BigInteger checkColor = new BigInteger("78909cff", 16);
if (usedColor.compareTo(checkColor) == -1) { if (usedColor.compareTo(checkColor) == -1) {
btnStyle = "-fx-button-type: RAISED; -fx-background-color: #" + XMLController.getColor() + "; -fx-text-fill: WHITE;"; btnStyle = "-fx-button-type: RAISED; -fx-background-color: #" + XMLController.getColor()
+ "; -fx-text-fill: WHITE;";
menuBtnStyle = "-fx-text-fill: WHITE;"; menuBtnStyle = "-fx-text-fill: WHITE;";
playbtn.setGraphic(new ImageView(new Image("icons/ic_play_arrow_white_18dp_1x.png"))); playbtn.setGraphic(new ImageView(new Image("icons/ic_play_arrow_white_18dp_1x.png")));
@ -722,7 +697,8 @@ public class MainWindowController {
menuHam.getStyleClass().clear(); menuHam.getStyleClass().clear();
menuHam.getStyleClass().add("jfx-hamburgerW"); menuHam.getStyleClass().add("jfx-hamburgerW");
} else { } else {
btnStyle = "-fx-button-type: RAISED; -fx-background-color: #" + XMLController.getColor() + "; -fx-text-fill: BLACK;"; btnStyle = "-fx-button-type: RAISED; -fx-background-color: #" + XMLController.getColor()
+ "; -fx-text-fill: BLACK;";
menuBtnStyle = "-fx-text-fill: BLACK;"; menuBtnStyle = "-fx-text-fill: BLACK;";
playbtn.setGraphic(new ImageView(new Image("icons/ic_play_arrow_black_18dp_1x.png"))); playbtn.setGraphic(new ImageView(new Image("icons/ic_play_arrow_black_18dp_1x.png")));
@ -836,7 +812,7 @@ public class MainWindowController {
nameText[19] = new Text(XMLController.getLocalBundle().getString("website") + ": "); nameText[19] = new Text(XMLController.getLocalBundle().getString("website") + ": ");
// *** // ***
// set the correct font for the nameText // set the correct font for the nameText
for (Text text : nameText) { for (Text text : nameText) {
text.setFont(font); text.setFont(font);
} }
@ -845,10 +821,10 @@ public class MainWindowController {
textFlow.clear(); textFlow.clear();
// TODO rework // TODO rework
for(int i = 0; i < 20; i++) { for (int i = 0; i < 20; i++) {
if (cacheData[i] != null && (i == 5 || i == 6) && cacheData[5].length() == 0) { if (cacheData[i] != null && (i == 5 || i == 6) && cacheData[5].length() == 0) {
// do nothing // do nothing
} else if(cacheData[i] != null){ } else if (cacheData[i] != null) {
textFlow.addAll(nameText[i], new Text(cacheData[i] + "\n")); textFlow.addAll(nameText[i], new Text(cacheData[i] + "\n"));
} }
} }
@ -886,14 +862,15 @@ public class MainWindowController {
} }
/** /**
* check if a film is supported by the HomeFlixPlayer or not * check if a film is supported by the HomeFlixPlayer or not this is the case if
* this is the case if the mime type is mp4 * the mime type is mp4
*
* @param entry the film you want to check * @param entry the film you want to check
* @return true if so, false if not * @return true if so, false if not
*/ */
private boolean isSupportedFormat(FilmTabelDataType film) { private boolean isSupportedFormat(FilmTabelDataType film) {
String mimeType = URLConnection.guessContentTypeFromName(film.getStreamUrl()); String mimeType = URLConnection.guessContentTypeFromName(film.getStreamUrl());
return mimeType != null && (mimeType.contains("mp4") || mimeType.contains("vp6")); return mimeType != null && (mimeType.contains("mp4") || mimeType.contains("vp6"));
} }
/** /**