use of com.cpjd.roblu.models.metrics.RBoolean in project Roblu by wdavies973.
the class MetricEditor method onItemSelected.
/**
* Called when the user selects a metric type
* @param adapterView the adapter containing all the choices
* @param view the view that was tapped
* @param i the position of the view
* @param l id of the view
*/
@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
((TextView) adapterView.getChildAt(0)).setTextColor(rui.getText());
/*
* User selected a new metric, let's create it
*/
String stringOfSelected = METRIC_TYPES[i];
if (stringOfSelected.equals(METRIC_TYPES[0])) {
metric = new RBoolean(0, "Boolean", false);
} else if (stringOfSelected.equals(METRIC_TYPES[1])) {
metric = new RCounter(0, "Counter", 1, 0);
} else if (stringOfSelected.equals(METRIC_TYPES[2])) {
metric = new RSlider(0, "Slider", 0, 100, 0);
} else if (stringOfSelected.equals(METRIC_TYPES[3])) {
metric = new RChooser(0, "Chooser", null, 0);
} else if (stringOfSelected.equals(METRIC_TYPES[4])) {
metric = new RCheckbox(0, "Checkbox", null);
} else if (stringOfSelected.equals(METRIC_TYPES[5])) {
metric = new RStopwatch(0, "Stopwatch", 0);
} else if (stringOfSelected.equals(METRIC_TYPES[6])) {
metric = new RTextfield(0, "Text field", "");
} else if (stringOfSelected.equals(METRIC_TYPES[7])) {
metric = new RGallery(0, "Gallery");
} else if (stringOfSelected.equalsIgnoreCase(METRIC_TYPES[8])) {
metric = new RDivider(0, "Divider");
} else if (stringOfSelected.equals(METRIC_TYPES[9])) {
metric = new RFieldDiagram(0, R.drawable.field2018, null);
} else if (stringOfSelected.equals(METRIC_TYPES[10])) {
metric = new RCalculation(0, "Custom calculation");
} else if (stringOfSelected.equals(METRIC_TYPES[11])) {
metric = new RFieldData(0, "Match data");
}
metric.setModified(true);
addMetricPreviewToToolbar();
buildConfigLayout();
}
use of com.cpjd.roblu.models.metrics.RBoolean in project Roblu by wdavies973.
the class Overview method onCreateView.
@Override
public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.overview_tab, container, false);
Bundle bundle = this.getArguments();
layout = view.findViewById(R.id.overview_layout);
REvent event = (REvent) getArguments().getSerializable("event");
RTeam team = new IO(getActivity()).loadTeam(event.getID(), TeamViewer.team.getID());
rMetricToUI = new RMetricToUI(getActivity(), new IO(getActivity()).loadSettings().getRui(), true);
try {
/*
* Do statistics generation, this will generate graphs for certain metrics
*/
// Stores pie chart values, with the sub linked hash map <item,occurrences>, this will need to be processed later into a percent
LinkedHashMap<String, LinkedHashMap<String, Double>> pieValues = new LinkedHashMap<>();
// Stores line chart values, with the sub linked hash map <matchName,value>
LinkedHashMap<String, LinkedHashMap<String, Double>> lineValues = new LinkedHashMap<>();
// This isn't directly related, more of a side project
ArrayList<RGallery> galleries = new ArrayList<>();
for (RTab tab : team.getTabs()) {
// Rule out disallowed tabs
if (tab.getTitle().equalsIgnoreCase("PIT"))
continue;
// Start processing metrics
for (RMetric metric : tab.getMetrics()) {
if (metric instanceof RGallery) {
galleries.add((RGallery) metric);
}
if (!metric.isModified())
continue;
// Pie graph metrics, scan these here
if (metric instanceof RBoolean) {
LinkedHashMap<String, Double> temp = pieValues.get(metric.getTitle());
if (temp == null)
temp = new LinkedHashMap<>();
String key = ((RBoolean) metric).isValue() ? "Yes" : "No";
if (temp.get(key) == null)
temp.put(key, 1.0);
else
temp.put(key, temp.get(key) + 1);
pieValues.put(metric.getTitle(), temp);
} else if (metric instanceof RCheckbox) {
if (((RCheckbox) metric).getValues() != null) {
for (Object key : ((RCheckbox) metric).getValues().keySet()) {
LinkedHashMap<String, Double> temp = pieValues.get(metric.getTitle());
if (temp == null)
temp = new LinkedHashMap<>();
if (temp.get(key.toString()) == null)
temp.put(key.toString(), 1.0);
else
temp.put(key.toString(), temp.get(key.toString()) + 1);
pieValues.put(metric.getTitle(), temp);
}
}
} else if (metric instanceof RChooser) {
LinkedHashMap<String, Double> temp = pieValues.get(metric.getTitle());
if (temp == null)
temp = new LinkedHashMap<>();
if (temp.get(metric.toString()) == null)
temp.put(metric.toString(), 1.0);
else
temp.put(metric.toString(), temp.get(metric.toString()) + 1);
pieValues.put(metric.getTitle(), temp);
} else // Line chart metrics
if (metric instanceof RCounter || metric instanceof RSlider || metric instanceof RStopwatch || metric instanceof RCalculation) {
LinkedHashMap<String, Double> temp = lineValues.get(metric.getTitle());
if (temp == null)
temp = new LinkedHashMap<>();
temp.put(tab.getTitle(), Double.parseDouble(metric.toString()));
lineValues.put(metric.getTitle(), temp);
}
}
}
// Add the divider metrics by position, -1 if no metric after it, or at the end
ArrayList<RDivider> addedDividers = new ArrayList<>();
/*
* Add the charts!
*/
for (Object key : lineValues.keySet()) {
if (lineValues.get(key.toString()).size() >= 2) {
loop: for (RTab tab : team.getTabs()) {
for (int i = 0; i < tab.getMetrics().size(); i++) {
if (tab.getMetrics().get(i).getTitle().equals(key.toString())) {
// See if there is a RDivider hiding above this metric
for (int j = i; j >= 0; j--) {
if (tab.getMetrics().get(j) instanceof RDivider && !addedDividers.contains(tab.getMetrics().get(j))) {
layout.addView(rMetricToUI.getDivider((RDivider) tab.getMetrics().get(j)));
addedDividers.add((RDivider) tab.getMetrics().get(j));
break loop;
}
}
}
}
}
layout.addView(rMetricToUI.generateLineChart(key.toString(), lineValues.get(key.toString())));
}
}
// Process the pie charts
for (Object key : pieValues.keySet()) {
if (pieValues.get(key.toString()).size() <= 1)
continue;
int metricID = 0;
loop: for (RTab tab : team.getTabs()) {
for (int i = 0; i < tab.getMetrics().size(); i++) {
if (tab.getMetrics().get(i).getTitle().equals(key.toString())) {
metricID = tab.getMetrics().get(i).getID();
// See if there is a RDivider hiding above this metric
for (int j = i; j >= 0; j--) {
if (tab.getMetrics().get(j) instanceof RDivider && !addedDividers.contains(tab.getMetrics().get(j))) {
layout.addView(rMetricToUI.getDivider((RDivider) tab.getMetrics().get(j)));
addedDividers.add((RDivider) tab.getMetrics().get(j));
break loop;
}
}
}
}
}
for (Object key2 : pieValues.get(key.toString()).keySet()) {
if (numModified(team.getTabs(), metricID) != 0)
pieValues.get(key.toString()).put(key2.toString(), pieValues.get(key.toString()).get(key2.toString()) / (double) numModified(team.getTabs(), metricID));
}
layout.addView(rMetricToUI.generatePieChart(key.toString(), pieValues.get(key.toString())));
}
/*
* Find the image with the most entropy, and add
* it as the "featured" image
*/
galleryLoop: for (int j = galleries.size() - 1; j >= 0; j--) {
if (galleries.get(j).getImages() != null && galleries.get(j).getImages().size() > 0) {
for (int i = galleries.get(j).getImages().size() - 1; i >= 0; i--) {
try {
layout.addView(rMetricToUI.getImageView("Featured image", BitmapFactory.decodeByteArray(galleries.get(j).getImages().get(i), 0, galleries.get(j).getImages().get(i).length)));
break galleryLoop;
} catch (Exception e) {
Log.d("RBS", "Failed to load featured image: " + e.getMessage());
}
}
}
}
} catch (Exception e) {
Log.d("RBS", "Failed to generate graphs for this team profile.");
}
/*
* Attempt to download TBA info for this team
*/
if (!team.hasTBAInfo()) {
if (event.getKey() != null && event.getKey().length() >= 4)
new TBATeamInfoTask(view.getContext(), team.getNumber(), event.getKey().substring(0, 4), this);
} else {
// TBA info card
layout.addView(rMetricToUI.getInfoField("TBA.com information", TeamViewer.team.getTbaInfo(), TeamViewer.team.getWebsite(), TeamViewer.team.getNumber()), 0);
if (TeamViewer.team.getImage() != null) {
// Image view
Bitmap bitmap = BitmapFactory.decodeByteArray(TeamViewer.team.getImage(), 0, TeamViewer.team.getImage().length);
layout.addView(rMetricToUI.getImageView("Robot", bitmap));
}
}
/*
* Add UI cards to the layout
*/
// "Other" card
layout.addView(rMetricToUI.getInfoField("Other", "Last edited: " + Utils.convertTime(team.getLastEdit()) + "\nSize on disk: " + new IO(view.getContext()).getTeamSize(bundle.getInt("eventID"), team.getID()) + " KB", "", 0));
return view;
}
use of com.cpjd.roblu.models.metrics.RBoolean in project Roblu by wdavies973.
the class CheckoutEncoder method decodeCheckout.
/**
* Decodes a checkout encoded in the CheckoutEncoder format
* @param string the string to deserialize
* @return an instantiated checkout from the string
*/
public RCheckout decodeCheckout(String string) {
try {
String[] lines = string.split("\n");
for (String s : lines) {
Log.d("RBS", "Line: " + s);
}
// Meta
RCheckout checkout = new RCheckout();
checkout.setID(Integer.parseInt(lines[0]));
checkout.setNameTag(lines[1]);
RTeam team = new RTeam();
team.setID(Integer.parseInt(lines[2]));
team.setLastEdit(Long.parseLong(lines[3]));
team.setTabs(new ArrayList<RTab>());
// Tabs
for (int i = 0; i < lines.length; i++) {
if (!lines[i].startsWith("TAB"))
continue;
// Tab meta
RTab tab = new RTab();
tab.setTitle(lines[i].substring(3));
tab.setWon(Boolean.parseBoolean(lines[i + 1]));
tab.setMetrics(new ArrayList<RMetric>());
String[] tokens = lines[i + 2].split(",");
LinkedHashMap<String, Long> edits = new LinkedHashMap<>();
for (int k = 1; k < tokens.length; k++) {
edits.put(tokens[1], Long.parseLong(tokens[2]));
}
tab.setEdits(edits);
// Metrics
for (int k = i + 1; k < lines.length; k++) {
if (lines[k].startsWith("TAB"))
break;
if (lines[i].startsWith("null"))
continue;
String[] mTokens = lines[k].split(String.valueOf(DELIMITER));
RMetric metric = null;
switch(mTokens[0]) {
case // boolean
"B":
metric = new RBoolean();
((RBoolean) metric).setValue(Boolean.parseBoolean(mTokens[4]));
break;
case "CH":
{
// checkbox
metric = new RCheckbox();
LinkedHashMap<String, Boolean> values = new LinkedHashMap<>();
for (int l = 4; l < mTokens.length; l++) {
values.put(mTokens[l].split(",")[0].substring(1), Boolean.parseBoolean(mTokens[l].split(",")[1].replace(")", "")));
}
((RCheckbox) metric).setValues(values);
break;
}
case "CO":
{
// chooser
metric = new RChooser();
((RChooser) metric).setSelectedIndex(Integer.parseInt(mTokens[4]));
// the amount of values, with the header info removed
String[] values = new String[mTokens.length - 6];
for (int l = 5; l < mTokens.length - 1; l++) {
if (mTokens[l] != null && !mTokens[l].equals(""))
values[l - 5] = mTokens[l];
}
((RChooser) metric).setValues(values);
break;
}
case // counter
"C":
metric = new RCounter();
((RCounter) metric).setVerboseInput(Boolean.parseBoolean(mTokens[4]));
((RCounter) metric).setValue(Double.parseDouble(mTokens[5]));
((RCounter) metric).setIncrement(Double.parseDouble(mTokens[6]));
break;
case // slider
"S":
metric = new RSlider();
((RSlider) metric).setValue(Integer.parseInt(mTokens[4]));
((RSlider) metric).setMin(Integer.parseInt(mTokens[5]));
((RSlider) metric).setMax(Integer.parseInt(mTokens[6]));
break;
case // stopwatch
"ST":
metric = new RStopwatch();
((RStopwatch) metric).setTime(Double.parseDouble(mTokens[4]));
((RStopwatch) metric).setTimes(new ArrayList<Double>());
for (int l = 5; l < mTokens.length; l++) {
if (!mTokens[l].equals(""))
((RStopwatch) metric).getTimes().add(Double.parseDouble(mTokens[5]));
}
break;
case // textfield
"T":
metric = new RTextfield();
((RTextfield) metric).setText((mTokens[4]));
break;
}
if (metric != null) {
metric.setID(Integer.parseInt(mTokens[1]));
metric.setTitle(mTokens[2]);
metric.setModified(Boolean.parseBoolean(mTokens[3]));
tab.getMetrics().add(metric);
// Adding metric
Log.d("RBS", "Adding metric " + metric.toString());
}
}
team.getTabs().add(tab);
}
checkout.setTeam(team);
return checkout;
} catch (Exception e) {
e.printStackTrace();
Log.d("RBS", "An error occurred while decoding a checkout. " + e.getMessage());
return null;
}
}
use of com.cpjd.roblu.models.metrics.RBoolean in project Roblu by wdavies973.
the class Utils method randomizeTeamMetrics.
/**
* This code will randomize an event with random metric data for the purposes of show casing an app
* or testing
*/
public static void randomizeTeamMetrics(ArrayList<RTab> tabs) {
Random r = new Random();
if (tabs != null) {
for (RTab tab : tabs) {
for (RMetric metric : tab.getMetrics()) {
metric.setModified(true);
if (metric instanceof RSlider) {
((RSlider) metric).setMax(100);
((RSlider) metric).setValue(r.nextInt(100));
} else if (metric instanceof RCounter) {
((RCounter) metric).setValue(r.nextDouble() * 100);
} else if (metric instanceof RStopwatch) {
((RStopwatch) metric).setTime(r.nextDouble() * 10);
((RStopwatch) metric).setTimes(new ArrayList<Double>());
for (int i = 0; i < r.nextInt(5); i++) {
((RStopwatch) metric).getTimes().add(Utils.round(r.nextDouble() * 8.2, 2));
}
} else if (metric instanceof RBoolean) {
((RBoolean) metric).setValue(r.nextDouble() <= 0.5);
} else if (metric instanceof RCheckbox) {
for (Object o : ((RCheckbox) metric).getValues().keySet()) {
((RCheckbox) metric).getValues().put(o.toString(), r.nextDouble() <= 0.50);
}
} else if (metric instanceof RChooser) {
((RChooser) metric).setSelectedIndex(r.nextInt(((RChooser) metric).getValues().length - 1));
} else if (metric instanceof RTextfield) {
if (!((RTextfield) metric).isOneLine())
((RTextfield) metric).setText("RTextfield has been randomized to: " + getSaltString());
}
}
}
}
}
use of com.cpjd.roblu.models.metrics.RBoolean in project Roblu by wdavies973.
the class RTeam method verify.
/**
* verify() makes sure that the form and team are synchronized. Here's what it does:
* <p>
* PIT:
* -If the user modified the form and ADDED elements, then we'll make sure to add them to this team's form copy
* -If the user modified the form and REMOVED elements, then we'll make sure to remove them from this team's form copy
* -If the user changed any item titles, change them right away
* -If the user changed any default values, reset all the values on all elements that have NOT been modified
* -If the user changed the order of any elements, change the order
* <p>
* MATCH:
* -If the user modified the match form and ADDED elements, then we'll add those to EVERY match profile
* -If the user modified the match form and REMOVED elements, then we'll remove those from EVERY match profile
* -If the user changed any item titles, change them on ALL match profiles
* -If the user changed any default values, reset all the values of EVERY match that have NOT been modified
* -If the user changed the order of any elements, change the order
* <p>
* PREMISE:
* -PIT and MATCH form arrays may NOT be null, only empty
* <p>
* NULLS to check for:
* -If the team has never been opened before, set the PIT values, matches don't need to be set until creation.
*/
public void verify(RForm form) {
// Check for null or missing Pit & Predictions tabs
if (this.tabs == null || this.tabs.size() == 0) {
this.tabs = new ArrayList<>();
addTab(new RTab(number, "Pit", Utils.duplicateRMetricArray(form.getPit()), false, false, 0));
addTab(new RTab(number, "Predictions", Utils.duplicateRMetricArray(form.getMatch()), false, false, 0));
// Check to make sure the team name and number have been inserted into the form
for (RMetric m : this.getTabs().get(0).getMetrics()) {
if (// team name
m.getID() == 0)
// team name
((RTextfield) m).setText(name);
else // team number
if (m.getID() == 1)
((RTextfield) m).setText(String.valueOf(number));
}
return;
}
// Remove elements that aren't on the form
// less if statements, just switches between PIT or MATCH depending on what needs to be verified
ArrayList<RMetric> temp = form.getPit();
for (int i = 0; i < tabs.size(); i++) {
if (!tabs.get(i).getTitle().equalsIgnoreCase("Pit"))
temp = form.getMatch();
for (int j = 0; j < tabs.get(i).getMetrics().size(); j++) {
boolean found = false;
if (temp.size() == 0) {
tabs.get(i).getMetrics().clear();
break;
}
for (int k = 0; k < temp.size(); k++) {
if (tabs.get(i).getMetrics().get(j).getID() == temp.get(k).getID())
found = true;
if (k == temp.size() - 1 && !found) {
tabs.get(i).getMetrics().remove(j);
j = 0;
break;
}
}
}
}
/*
* Alright, so we removed old elements, but we're still very suspicious. For example,
* let's say the user edited the form (by removing an element), didn't re-verify any teams (by not opening them),
* and then added a new element in the position of the old one. What will happen is that the above method will
* NOT remove the old metric instance, and instead below the metrics name will not get updated. So, here we will
* make sure that both the ID and INSTANCE TYPE of each metric (in the form and team) match, otherwise, the metric
* gets booted.
*/
temp = form.getPit();
for (int i = 0; i < tabs.size(); i++) {
if (!tabs.get(i).getTitle().equalsIgnoreCase("Pit"))
temp = form.getMatch();
for (int j = 0; j < temp.size(); j++) {
for (int k = 0; k < tabs.get(i).getMetrics().size(); k++) {
if (tabs.get(i).getMetrics().get(k).getID() == temp.get(j).getID()) {
if (!temp.get(j).getClass().equals(tabs.get(i).getMetrics().get(k).getClass())) {
tabs.get(i).getMetrics().remove(k);
j = 0;
k = 0;
}
}
}
}
}
// Add elements that are on the form, but not in this team
temp = form.getPit();
for (int i = 0; i < tabs.size(); i++) {
if (!tabs.get(i).getTitle().equalsIgnoreCase("Pit"))
temp = form.getMatch();
for (int j = 0; j < temp.size(); j++) {
boolean found = false;
if (tabs.get(i).getMetrics().size() == 0) {
tabs.get(i).getMetrics().add(temp.get(j).clone());
continue;
}
for (int k = 0; k < tabs.get(i).getMetrics().size(); k++) {
if (tabs.get(i).getMetrics().get(k).getID() == temp.get(j).getID())
found = true;
if (k == tabs.get(i).getMetrics().size() - 1 && !found) {
tabs.get(i).getMetrics().add(temp.get(j).clone());
j = 0;
break;
}
}
}
}
// Update item names
temp = form.getPit();
for (int i = 0; i < tabs.size(); i++) {
if (!tabs.get(i).getTitle().equalsIgnoreCase("PIT"))
temp = form.getMatch();
for (int j = 0; j < temp.size(); j++) {
for (int k = 0; k < tabs.get(i).getMetrics().size(); k++) {
if (temp.get(j).getID() == tabs.get(i).getMetrics().get(k).getID()) {
tabs.get(i).getMetrics().get(k).setTitle(temp.get(j).getTitle());
break;
}
}
}
}
// Update default values for non-modified values, also check for some weird scenario
temp = form.getPit();
for (int i = 0; i < tabs.size(); i++) {
if (!tabs.get(i).getTitle().equalsIgnoreCase("PIT"))
temp = form.getMatch();
for (int j = 0; j < temp.size(); j++) {
for (int k = 0; k < tabs.get(i).getMetrics().size(); k++) {
if (temp.get(j).getID() == tabs.get(i).getMetrics().get(k).getID()) {
RMetric e = temp.get(j);
RMetric s = tabs.get(i).getMetrics().get(k);
if (e instanceof RBoolean && !s.isModified() && s instanceof RBoolean)
((RBoolean) s).setValue(((RBoolean) e).isValue());
else if (e instanceof RCounter && !s.isModified() && s instanceof RCounter) {
((RCounter) s).setValue(((RCounter) e).getValue());
} else if (e instanceof RCalculation && s instanceof RCalculation) {
((RCalculation) s).setCalculation(((RCalculation) e).getCalculation());
} else if (e instanceof RCheckbox && s instanceof RCheckbox) {
// update the titles always, rely on position for this one
LinkedHashMap<String, Boolean> newHash = new LinkedHashMap<>();
// get old values
ArrayList<Boolean> values = new ArrayList<>();
// put values from team checkbox into this array
for (String oKey : ((RCheckbox) s).getValues().keySet()) {
values.add(((RCheckbox) s).getValues().get(oKey));
}
// copy values to new linked hash map, replacing the new keys
int index = 0;
for (String oKey : ((RCheckbox) e).getValues().keySet()) {
newHash.put(oKey, values.get(index));
index++;
}
// set new array back to team metric
((RCheckbox) s).setValues(newHash);
// if the checkbox is not modified, reset the boolean values
if (!s.isModified()) {
for (String key : ((RCheckbox) e).getValues().keySet()) ((RCheckbox) s).getValues().put(key, ((RCheckbox) e).getValues().get(key));
}
} else // if one line is true, it means its the team name or number metric and its value shouldn't be overrided
if (e instanceof RTextfield && !s.isModified() && !((RTextfield) e).isOneLine())
((RTextfield) s).setText(((RTextfield) e).getText());
else if (e instanceof RChooser && s instanceof RChooser) {
// Always update the title
if (!Arrays.equals(((RChooser) s).getValues(), ((RChooser) e).getValues())) {
((RChooser) s).setValues(((RChooser) e).getValues());
}
// if the chooser is not modified, reset the chooser values
if (!s.isModified())
((RChooser) s).setSelectedIndex(((RChooser) e).getSelectedIndex());
} else if (e instanceof RStopwatch && !s.isModified() && s instanceof RStopwatch)
((RStopwatch) s).setTime(((RStopwatch) e).getTime());
else if (e instanceof RSlider && !s.isModified() && s instanceof RSlider) {
((RSlider) s).setMax(((RSlider) e).getMax());
((RSlider) s).setMin(((RSlider) e).getMin());
((RSlider) s).setValue(((RSlider) e).getValue());
} else if (e instanceof RCounter && s instanceof RCounter) {
((RCounter) s).setIncrement(((RCounter) e).getIncrement());
((RCounter) s).setVerboseInput(((RCounter) e).isVerboseInput());
if (!s.isModified())
((RCounter) s).setValue(((RCounter) e).getValue());
}
break;
}
}
}
}
}
Aggregations