first implementation of scrobble chart
This commit is contained in:
parent
c037d7414a
commit
11836840bf
@ -125,6 +125,75 @@ public class FmUserNetwork extends FmNetwork {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int getScrobbleCountByDate(int day, int month, int year) {
|
||||||
|
if (ConsoleHandler.isVerbose())
|
||||||
|
ConsoleHandler.getConsole().write(">>getScrobblesByDate " + day + "." + month + "." + year);
|
||||||
|
|
||||||
|
LocalDate startDate = LocalDate.of(year, month, day);
|
||||||
|
|
||||||
|
ZoneId zoneId = ZoneId.systemDefault();
|
||||||
|
long epoch = startDate.atStartOfDay(zoneId).toEpochSecond();
|
||||||
|
long endEpoch = epoch + (24*60*60);
|
||||||
|
|
||||||
|
try {
|
||||||
|
HttpResponse<JsonNode> response = Unirest.get("http://ws.audioscrobbler.com/2.0/").
|
||||||
|
header("Accept", "application/json").
|
||||||
|
header("User-Agent", "fmframework").
|
||||||
|
queryString("method","user.getrecenttracks").
|
||||||
|
queryString("user", userName).
|
||||||
|
queryString("from", epoch).
|
||||||
|
queryString("to", endEpoch).
|
||||||
|
queryString("limit", 1).
|
||||||
|
queryString("api_key", key).
|
||||||
|
queryString("format", "json").
|
||||||
|
asJson();
|
||||||
|
|
||||||
|
int total = new JSONObject(response.getBody().toString()).getJSONObject("recenttracks").getJSONObject("@attr").getInt("total");
|
||||||
|
|
||||||
|
return total;
|
||||||
|
|
||||||
|
} catch (UnirestException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getScrobbleCountByDeltaDay(int day) {
|
||||||
|
if (ConsoleHandler.isVerbose())
|
||||||
|
ConsoleHandler.getConsole().write(">>getScrobblesByDeltaDay " + day);
|
||||||
|
|
||||||
|
LocalDate local = LocalDate.now();
|
||||||
|
|
||||||
|
ZoneId zoneId = ZoneId.systemDefault();
|
||||||
|
long epoch = local.atStartOfDay(zoneId).toEpochSecond();
|
||||||
|
epoch -= (day * (24*60*60));
|
||||||
|
long endEpoch = epoch + (24*60*60);
|
||||||
|
|
||||||
|
try {
|
||||||
|
HttpResponse<JsonNode> response = Unirest.get("http://ws.audioscrobbler.com/2.0/").
|
||||||
|
header("Accept", "application/json").
|
||||||
|
header("User-Agent", "fmframework").
|
||||||
|
queryString("method","user.getrecenttracks").
|
||||||
|
queryString("user", userName).
|
||||||
|
queryString("from", epoch).
|
||||||
|
queryString("to", endEpoch).
|
||||||
|
queryString("limit", 1).
|
||||||
|
queryString("api_key", key).
|
||||||
|
queryString("format", "json").
|
||||||
|
asJson();
|
||||||
|
|
||||||
|
int total = new JSONObject(response.getBody().toString()).getJSONObject("recenttracks").getJSONObject("@attr").getInt("total");
|
||||||
|
|
||||||
|
return total;
|
||||||
|
|
||||||
|
} catch (UnirestException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
public ArrayList<Tag> getTags(){
|
public ArrayList<Tag> getTags(){
|
||||||
if (ConsoleHandler.isVerbose())
|
if (ConsoleHandler.isVerbose())
|
||||||
ConsoleHandler.getConsole().write(">>getTags");
|
ConsoleHandler.getConsole().write(">>getTags");
|
||||||
|
@ -3,12 +3,21 @@ package sarsoo.fmframework.fx.controller;
|
|||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.text.NumberFormat;
|
import java.text.NumberFormat;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
import java.util.concurrent.CountDownLatch;
|
||||||
|
|
||||||
|
import javax.swing.JOptionPane;
|
||||||
|
|
||||||
|
import javafx.application.Platform;
|
||||||
|
import javafx.collections.FXCollections;
|
||||||
|
import javafx.concurrent.Service;
|
||||||
|
import javafx.concurrent.Task;
|
||||||
import javafx.event.ActionEvent;
|
import javafx.event.ActionEvent;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import sarsoo.fmframework.fm.FmNetwork;
|
import sarsoo.fmframework.fm.FmNetwork;
|
||||||
|
import sarsoo.fmframework.fm.FmUserNetwork;
|
||||||
import sarsoo.fmframework.fx.ArtistTab;
|
import sarsoo.fmframework.fx.ArtistTab;
|
||||||
import sarsoo.fmframework.fx.FmFramework;
|
import sarsoo.fmframework.fx.FmFramework;
|
||||||
|
import sarsoo.fmframework.fx.TrackTab;
|
||||||
import sarsoo.fmframework.music.Album;
|
import sarsoo.fmframework.music.Album;
|
||||||
import sarsoo.fmframework.music.Wiki;
|
import sarsoo.fmframework.music.Wiki;
|
||||||
import sarsoo.fmframework.net.Key;
|
import sarsoo.fmframework.net.Key;
|
||||||
@ -16,6 +25,7 @@ import sarsoo.fmframework.net.Network;
|
|||||||
import sarsoo.fmframework.util.Maths;
|
import sarsoo.fmframework.util.Maths;
|
||||||
import sarsoo.fmframework.util.Reference;
|
import sarsoo.fmframework.util.Reference;
|
||||||
import javafx.scene.chart.LineChart;
|
import javafx.scene.chart.LineChart;
|
||||||
|
import javafx.scene.chart.XYChart;
|
||||||
import javafx.scene.control.*;
|
import javafx.scene.control.*;
|
||||||
import javafx.scene.layout.BorderPane;
|
import javafx.scene.layout.BorderPane;
|
||||||
|
|
||||||
@ -38,8 +48,9 @@ public class ScrobbleChartPaneController {
|
|||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
public void initialize() {
|
public void initialize() {
|
||||||
|
// dropDownTimeRange.setItems(FXCollections.observableArrayList("week", "month",
|
||||||
|
// "3 month", "6 month", "year"));
|
||||||
|
dropDownTimeRange.getItems().addAll("week", "30 day", "90 day", "180 day", "year");
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
@ -47,14 +58,71 @@ public class ScrobbleChartPaneController {
|
|||||||
refresh();
|
refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void populate(Album album) {
|
public void populate(Album album) {
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void refresh() {
|
public void refresh() {
|
||||||
|
Service<Void> service = new Service<Void>() {
|
||||||
|
@Override
|
||||||
|
protected Task<Void> createTask() {
|
||||||
|
return new Task<Void>() {
|
||||||
|
@Override
|
||||||
|
protected Void call() throws Exception {
|
||||||
|
|
||||||
|
FmUserNetwork net = new FmUserNetwork(Key.getKey(), "sarsoo");
|
||||||
|
String value = (String) dropDownTimeRange.getValue();
|
||||||
|
|
||||||
|
int dayLength = 0;
|
||||||
|
|
||||||
|
switch (value) {
|
||||||
|
case "week":
|
||||||
|
dayLength = 7;
|
||||||
|
break;
|
||||||
|
case "30 day":
|
||||||
|
dayLength = 30;
|
||||||
|
break;
|
||||||
|
case "90 day":
|
||||||
|
dayLength = 90;
|
||||||
|
break;
|
||||||
|
case "180 day":
|
||||||
|
dayLength = 180;
|
||||||
|
break;
|
||||||
|
case "year":
|
||||||
|
dayLength = 365;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
XYChart.Series series = new XYChart.Series();
|
||||||
|
|
||||||
|
int counter;
|
||||||
|
for (counter = 0; counter < dayLength; counter++) {
|
||||||
|
int scrobble = net.getScrobbleCountByDeltaDay(dayLength - counter - 1);
|
||||||
|
// System.out.println(scrobble);
|
||||||
|
series.getData().add(new XYChart.Data(String.valueOf(dayLength - counter), scrobble));
|
||||||
|
}
|
||||||
|
|
||||||
|
final CountDownLatch latch = new CountDownLatch(1);
|
||||||
|
Platform.runLater(new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
lineChartScrobbles.getData().clear();
|
||||||
|
lineChartScrobbles.getData().add(series);
|
||||||
|
|
||||||
|
} finally {
|
||||||
|
latch.countDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
latch.await();
|
||||||
|
// Keep with the background work
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
};
|
||||||
|
service.start();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
</ToolBar>
|
</ToolBar>
|
||||||
</bottom>
|
</bottom>
|
||||||
<center>
|
<center>
|
||||||
<LineChart fx:id="lineChartScrobbles" BorderPane.alignment="CENTER">
|
<LineChart fx:id="lineChartScrobbles" legendVisible="false" BorderPane.alignment="CENTER">
|
||||||
<xAxis>
|
<xAxis>
|
||||||
<CategoryAxis side="BOTTOM" />
|
<CategoryAxis side="BOTTOM" />
|
||||||
</xAxis>
|
</xAxis>
|
||||||
|
Loading…
Reference in New Issue
Block a user