From 2d8187935c8a6d1fca8d9dbd916b7143c3e41c9c Mon Sep 17 00:00:00 2001
From: Jacek Kowalski <Jacek@jacekk.info>
Date: Sun, 18 Jan 2015 19:16:23 +0000
Subject: [PATCH] Allow to reset application state using "back" button & fix toggles state detection.

---
 app/src/main/java/net/jacekk/bridge/BridgeInputException.java               |    7 +
 app/src/main/java/net/jacekk/bridge/android/MainActivity.java               |   98 ++++++++++-----
 app/src/main/java/net/jacekk/bridge/BridgeInput.java                        |    7 +
 app/src/androidTest/java/net/jacekk/bridge/BridgeComputeTest.java           |    7 +
 app/src/main/java/net/jacekk/bridge/android/BridgeInputExceptionMapper.java |    7 +
 app/src/androidTest/java/net/jacekk/bridge/BrydzLicz.java                   |  213 +++++++++++++++++++++++++++++++++++
 6 files changed, 306 insertions(+), 33 deletions(-)

diff --git a/app/src/androidTest/java/net/jacekk/bridge/BridgeComputeTest.java b/app/src/androidTest/java/net/jacekk/bridge/BridgeComputeTest.java
new file mode 100644
index 0000000..f283084
--- /dev/null
+++ b/app/src/androidTest/java/net/jacekk/bridge/BridgeComputeTest.java
@@ -0,0 +1,7 @@
+package net.jacekk.bridge;
+
+/**
+ * Created by jacek on 18.01.15.
+ */
+public class BridgeComputeTest {
+}
diff --git a/app/src/androidTest/java/net/jacekk/bridge/BrydzLicz.java b/app/src/androidTest/java/net/jacekk/bridge/BrydzLicz.java
new file mode 100644
index 0000000..e1e1ae1
--- /dev/null
+++ b/app/src/androidTest/java/net/jacekk/bridge/BrydzLicz.java
@@ -0,0 +1,213 @@
+/*
+ * Copyright (c) 2012, Jacek Kowalski (http://jacekk.info)
+ * Wszystkie prawa zastrzeżone
+ * 
+ * Licencja w pliku BSD-3.txt
+ */
+
+package net.jacekk.bridge;
+
+public class BrydzLicz {
+    protected int lewy[][] = {
+        {0, 20, 40, 60, 80, 100, 120, 140}, // młodsze
+        {0, 30, 60, 90, 120, 150, 180, 210}, // starsze
+        {0, 40, 70, 100, 130, 160, 190, 220} // bez atu
+    };
+    
+    protected int wpadki[][][] = {
+        {   // przed partią
+            {0, 50, 100, 150, 200, 250, 300, 350, 400, 450, 500, 550, 600, 650}, // normalnie
+            {0, 100, 300, 500, 700, 900, 1100, 1300, 1500, 1700, 1900, 2100, 2300, 2500}, // kontra
+            {0, 200, 600, 1000, 1400, 1800, 2200, 2600, 3000, 3400, 3800, 4200, 4600, 5000} // rekontra
+        },
+        {   // po partii
+            {0, 100, 200, 300, 400, 500, 600, 700, 800, 900, 1000, 1100, 1200, 1300}, // normalnie
+            {0, 200, 500, 800, 1100, 1400, 1700, 2000, 2300, 2600, 2900, 3200, 3500, 3800}, // kontra
+            {0, 400, 1000, 1600, 2200, 2800, 3400, 4000, 4600, 5200, 5800, 6400, 7000, 7600} // rekontra
+        }
+    };
+    
+    protected int PC[][][] = {
+        {   // MY: przed, WY: przed partią
+            {-1400, -1400, -1400, -1400, -1200, -1100, -1000, -900, -700, -600, -490, -460, -430, -400, -350, -300, -200, -110, -70, -50, 0, 50, 70, 110, 200, 300, 350, 400, 430, 460, 490, 600, 700, 900, 1000, 1100, 1200, 1400, 1400, 1400, 1400},
+            // MY: przed, WY: po partii
+            {-2100, -2100, -2100, -2100, -1800, -1650, -1500, -1350, -1050, -800, -690, -660, -630, -600, -520, -440, -290, -110, -70, -50, 0, 50, 70, 110, 200, 300, 350, 400, 430, 460, 490, 600, 700, 900, 1000, 1100, 1200, 1400, 1400, 1400, 1400}
+        },
+        {   // MY: po, WY: przed partią
+            {-1400, -1400, -1400, -1400, -1200, -1100, -1000, -900, -700, -600, -490, -460, -430, -400, -350, -300, -200, -110, -70, -50, 0, 50, 70, 110, 290, 440, 520, 600, 630, 660, 690, 800, 1050, 1350, 1500, 1650, 1800, 2100, 2100, 2100, 2100},
+            // MY: po, WY: po partii
+            {-2100, -2100, -2100, -2100, -1800, -1650, -1500, -1350, -1050, -800, -690, -660, -630, -600, -520, -440, -290, -110, -70, -50, 0, 50, 70, 110, 290, 440, 520, 600, 630, 660, 690, 800, 1050, 1350, 1500, 1650, 1800, 2100, 2100, 2100, 2100}
+        }
+    };
+    
+    protected int IMP[] = {0, 20, 50, 90, 130, 170, 220, 270, 320, 370, 430, 500, 600, 750, 900, 1100, 1300, 1500, 1750, 2000, 2250, 2500, 3000, 3500, 4000, 9999999};
+    
+    protected int procenty_punkty[][] = {
+        {0, 50, 90, 120, 150, 180, 210, 300, 400, 430, 460, 490, 520, 800, 920, 940, 980, 990, 1020, 1400, 1440, 1520, 1530, 9999999}, // przed
+        {0, 50, 90, 120, 150, 180, 210, 500, 600, 360, 660, 690, 720, 810, 1370, 1390, 1430, 1440, 1470, 1700, 2000, 2220, 2230, 9999999} //po
+    };
+    
+    protected int procenty_PC[] = {0, 6, 10, 16, 21, 25, 31, 35, 9999999};
+    
+    protected int procenty[][] = {
+        {-1, -1, -1, 50, 44, 26, 8, 0},
+        {83, 74, 65, 56, 47, 29, 11, 0},
+        {86, 77, 68, 59, 50, 32, 14, 0},
+        {89, 80, 71, 62, 53, 35, 17, 0},
+        {92, 83, 74, 65, 56, 38, 20, 2},
+        {95, 86, 77, 68, 59, 41, 23, 5},
+        {98, 89, 80, 71, 62, 44, 26, 8},
+        {100, 92, 83, 74, 65, 47, 29, 11},
+        {100, 95, 86, 77, 68, 50, 32, 14},
+        {100, 98, 89, 80, 71, 53, 35, 17},
+        {100, 100, 92, 83, 74, 56, 38, 20},
+        {100, 100, 95, 86, 77, 59, 41, 23},
+        {100, 100, 98, 89, 80, 62, 44, 26},
+        {100, 100, 100, 92, 83, 65, 47, 29},
+        {100, 100, 100, 95, 86, 68, 50, 32},
+        {100, 100, 100, 98, 89, 71, 53, 35},
+        {100, 100, 100, 100, 92, 74, 56, 38},
+        {100, 100, 100, 100, 95, 77, 59, 41},
+        {100, 100, 100, 100, 98, 80, 62, 44},
+        {100, 100, 100, 100, 100, 83, 65, 47},
+        {100, 100, 100, 100, 100, 86, 68, 50},
+        {100, 100, 100, 100, 100, 89, 71, 53},
+        {100, 100, 100, 100, 100, 100, 95, 90}
+    };
+    
+    protected int IMP(int punkty) {
+        int i = 0;
+        while( IMP[i+1] <= punkty ) {
+            i++;
+        }
+        return i;
+    }
+    
+    protected int procenty(int PC, int punkty, int partia) {
+        int punkty_i = 0;
+        int PC_i = 0;
+        
+        while(this.procenty_punkty[partia][punkty_i+1] <= punkty) {
+            punkty_i++;
+        }
+        
+        while(this.procenty_PC[PC_i+1] <= PC) {
+            PC_i++;
+        }
+        
+        return this.procenty[punkty_i][PC_i];
+    }
+    
+    public BrydzWynik policz(int kontrakt, int kolor, int kontra, int partia, int PC, int lewy) {
+        BrydzWynik wynik = new BrydzWynik();
+        int my_partia = partia / 2;
+        int wy_partia = partia % 2;
+        
+        // 4 pasy
+        if( kontrakt == 0 ) {
+            wynik.dla = 1;
+            wynik.punkty = this.PC[my_partia][wy_partia][PC];
+            wynik.IMP = this.IMP(wynik.punkty);
+            wynik.procent = 100-this.procenty(PC, 0, my_partia);
+            
+            return wynik;
+        }
+        
+        
+        // Wynik w punktach
+        int wynik_punkty;
+        // Punkty za lewy kontraktowe
+        int wynik_lewy;
+        // Wynik w punktach, uwzględniając ilość PC
+        int wynik_punkty_PC;
+        
+        // Ilość nadróbek
+        int nadrobki = lewy - 6 - kontrakt;
+        
+        // Mnożnik przy kontrze
+        int mnoznik = kontra+1;
+        if( mnoznik == 3 ) {
+            mnoznik = 4;
+        }
+        
+        // Kontrakt ugrany
+        if( nadrobki >= 0 ) {
+            // "Nadróbki: jak za lewy"
+            if( mnoznik == 1 ) {
+                wynik_lewy = this.lewy[kolor][kontrakt];
+                wynik_punkty = this.lewy[kolor][lewy - 6];
+            }
+            // Kontra lub rekontra
+            else
+            {
+                wynik_lewy = this.lewy[kolor][kontrakt] * mnoznik;
+                wynik_punkty = wynik_lewy;
+                
+                // Za wygranie z kontrą
+                wynik_punkty += 25 * mnoznik;
+                // Za nadróbki
+                wynik_punkty += nadrobki * (my_partia == 0 ? 50 : 100) * mnoznik;
+            }
+            
+            if(kontrakt == 6) {
+                // Za szlemika
+                wynik_punkty += (my_partia == 0 ? 500 : 750);
+            }
+            else if(kontrakt == 7) {
+                // Za szlema
+                wynik_punkty += (my_partia == 0 ? 1000 : 1500);
+            }
+            
+            if(wynik_lewy >= 100) {
+                // Za partię
+                wynik_punkty += (my_partia == 0 ? 300 : 500);
+            }
+            else
+            {
+                // Za częściówkę
+                wynik_punkty += 50;
+            }
+        }
+        // Wpadka
+        else
+        {
+            // Punkty za wpadkę
+            wynik_punkty = -1 * this.wpadki[my_partia][kontra][-1 * nadrobki];
+        }
+        
+        // Uwzględniamy ilość punktów, którą trzeba było zdobyć
+        wynik_punkty_PC = wynik_punkty - this.PC[my_partia][wy_partia][PC];
+        
+        // Zapis dla przeciwników
+        if( wynik_punkty_PC < 0 ) {
+            wynik.dla = 1;
+            wynik.punkty_przed = -1 * wynik_punkty;
+            wynik.punkty = -1 * wynik_punkty_PC;
+            wynik.IMP = IMP(wynik.punkty);
+            if( wynik_punkty < 0 ) {
+                wynik.procent = procenty(40 - PC, -1 * wynik_punkty, wy_partia);
+            }
+            else
+            {
+                wynik.procent = 100 - procenty(PC, wynik_punkty, my_partia);
+            }
+        }
+        // Zapis dla rozgrywających
+        else
+        {
+            wynik.dla = 0;
+            wynik.punkty_przed = wynik_punkty;
+            wynik.punkty = wynik_punkty_PC;
+            wynik.IMP = IMP(wynik.punkty);
+            if( wynik_punkty > 0 ) {
+                wynik.procent = procenty(PC, wynik_punkty, my_partia);
+            }
+            else
+            {
+                wynik.procent = 100 - procenty(40 - PC, -1 * wynik_punkty, wy_partia);
+            }
+        }
+        
+        return wynik;
+    }
+}
diff --git a/app/src/main/java/net/jacekk/bridge/BridgeInput.java b/app/src/main/java/net/jacekk/bridge/BridgeInput.java
new file mode 100644
index 0000000..e47323d
--- /dev/null
+++ b/app/src/main/java/net/jacekk/bridge/BridgeInput.java
@@ -0,0 +1,7 @@
+package net.jacekk.bridge;
+
+/**
+ * Created by jacek on 18.01.15.
+ */
+public class BridgeInput {
+}
diff --git a/app/src/main/java/net/jacekk/bridge/BridgeInputException.java b/app/src/main/java/net/jacekk/bridge/BridgeInputException.java
new file mode 100644
index 0000000..8b3c0f6
--- /dev/null
+++ b/app/src/main/java/net/jacekk/bridge/BridgeInputException.java
@@ -0,0 +1,7 @@
+package net.jacekk.bridge;
+
+/**
+ * Created by jacek on 18.01.15.
+ */
+public class BridgeInputException {
+}
diff --git a/app/src/main/java/net/jacekk/bridge/android/BridgeInputExceptionMapper.java b/app/src/main/java/net/jacekk/bridge/android/BridgeInputExceptionMapper.java
new file mode 100644
index 0000000..7f929c0
--- /dev/null
+++ b/app/src/main/java/net/jacekk/bridge/android/BridgeInputExceptionMapper.java
@@ -0,0 +1,7 @@
+package net.jacekk.bridge.android;
+
+/**
+ * Created by jacek on 18.01.15.
+ */
+public class BridgeInputExceptionMapper {
+}
diff --git a/app/src/main/java/net/jacekk/bridge/android/MainActivity.java b/app/src/main/java/net/jacekk/bridge/android/MainActivity.java
index e7fe4cd..9c60f4e 100644
--- a/app/src/main/java/net/jacekk/bridge/android/MainActivity.java
+++ b/app/src/main/java/net/jacekk/bridge/android/MainActivity.java
@@ -4,7 +4,7 @@
 import android.os.Bundle;
 import android.text.Editable;
 import android.text.TextWatcher;
-import android.view.View;
+import android.widget.CompoundButton;
 import android.widget.EditText;
 import android.widget.SeekBar;
 import android.widget.TextView;
@@ -49,6 +49,17 @@
         InitializeApp();
     }
 
+    @Override
+    public void onBackPressed() {
+        // Reset
+        BidSlider.setProgress(0);
+        MinorSuitsToggle.setChecked(true);
+        ContractToggle.setChecked(true);
+        NNToggle.setChecked(true);
+        PCInput.setText("");
+        TricksInput.setText("");
+    }
+
     private void InitializeApp() {
         bridgeCompute = new BridgeCompute();
 
@@ -73,6 +84,8 @@
 
         resultText = (TextView) findViewById(R.id.ResultsText);
 
+        CompoundButton.OnCheckedChangeListener changeListener;
+
         BidSlider.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {
             @Override
             public void onProgressChanged(SeekBar seekBar, int i, boolean b) {
@@ -89,67 +102,86 @@
             }
         });
 
-        ToggleButton.OnClickListener colorClickListener = new ToggleButton.OnClickListener() {
+        changeListener = new CompoundButton.OnCheckedChangeListener() {
             @Override
-            public void onClick(View view) {
-                ToggleButton toggle = (ToggleButton) view;
+            public void onCheckedChanged(CompoundButton button, boolean isChecked) {
+                if (!isChecked) {
+                    if (!MinorSuitsToggle.isChecked() && !MajorSuitsToggle.isChecked()
+                            && !NoTrumpToggle.isChecked()) {
+                        MinorSuitsToggle.setChecked(true);
+                    }
+                    return;
+                }
 
-                if (!toggle.equals(MinorSuitsToggle))
+                if (!button.equals(MinorSuitsToggle))
                     MinorSuitsToggle.setChecked(false);
-                if (!toggle.equals(MajorSuitsToggle))
+                if (!button.equals(MajorSuitsToggle))
                     MajorSuitsToggle.setChecked(false);
-                if (!toggle.equals(NoTrumpToggle))
+                if (!button.equals(NoTrumpToggle))
                     NoTrumpToggle.setChecked(false);
 
                 updateResults();
             }
         };
 
-        MinorSuitsToggle.setOnClickListener(colorClickListener);
-        MajorSuitsToggle.setOnClickListener(colorClickListener);
-        NoTrumpToggle.setOnClickListener(colorClickListener);
+        MinorSuitsToggle.setOnCheckedChangeListener(changeListener);
+        MajorSuitsToggle.setOnCheckedChangeListener(changeListener);
+        NoTrumpToggle.setOnCheckedChangeListener(changeListener);
 
-        ToggleButton.OnClickListener bidClickListener = new ToggleButton.OnClickListener() {
+        changeListener = new CompoundButton.OnCheckedChangeListener() {
             @Override
-            public void onClick(View view) {
-                ToggleButton toggle = (ToggleButton) view;
+            public void onCheckedChanged(CompoundButton button, boolean isChecked) {
+                if (!isChecked) {
+                    if (!ContractToggle.isChecked() && !DoubleToggle.isChecked()
+                            && !RedoubleToggle.isChecked()) {
+                        ContractToggle.setChecked(true);
+                    }
+                    return;
+                }
 
-                if (!toggle.equals(ContractToggle))
+                if (!button.equals(ContractToggle))
                     ContractToggle.setChecked(false);
-                if (!toggle.equals(DoubleToggle))
+                if (!button.equals(DoubleToggle))
                     DoubleToggle.setChecked(false);
-                if (!toggle.equals(RedoubleToggle))
+                if (!button.equals(RedoubleToggle))
                     RedoubleToggle.setChecked(false);
 
                 updateResults();
             }
         };
 
-        ContractToggle.setOnClickListener(bidClickListener);
-        DoubleToggle.setOnClickListener(bidClickListener);
-        RedoubleToggle.setOnClickListener(bidClickListener);
+        ContractToggle.setOnCheckedChangeListener(changeListener);
+        DoubleToggle.setOnCheckedChangeListener(changeListener);
+        RedoubleToggle.setOnCheckedChangeListener(changeListener);
 
-        ToggleButton.OnClickListener baClickListener = new ToggleButton.OnClickListener() {
-            public void onClick(View view) {
-                ToggleButton toggle = (ToggleButton) view;
+        changeListener = new CompoundButton.OnCheckedChangeListener() {
+            @Override
+            public void onCheckedChanged(CompoundButton button, boolean isChecked) {
+                if (!isChecked) {
+                    if (!VVToggle.isChecked() && !VNToggle.isChecked()
+                            && !NVToggle.isChecked() && !NNToggle.isChecked()) {
+                        NNToggle.setChecked(true);
+                    }
+                    return;
+                }
 
-                if (!toggle.equals(VVToggle))
-                    VVToggle.setChecked(false);
-                if (!toggle.equals(VNToggle))
-                    VNToggle.setChecked(false);
-                if (!toggle.equals(NVToggle))
-                    NVToggle.setChecked(false);
-                if (!toggle.equals(NNToggle))
+                if (!button.equals(NNToggle))
                     NNToggle.setChecked(false);
+                if (!button.equals(NVToggle))
+                    NVToggle.setChecked(false);
+                if (!button.equals(VNToggle))
+                    VNToggle.setChecked(false);
+                if (!button.equals(VVToggle))
+                    VVToggle.setChecked(false);
 
                 updateResults();
             }
         };
 
-        VVToggle.setOnClickListener(baClickListener);
-        VNToggle.setOnClickListener(baClickListener);
-        NVToggle.setOnClickListener(baClickListener);
-        NNToggle.setOnClickListener(baClickListener);
+        VVToggle.setOnCheckedChangeListener(changeListener);
+        VNToggle.setOnCheckedChangeListener(changeListener);
+        NVToggle.setOnCheckedChangeListener(changeListener);
+        NNToggle.setOnCheckedChangeListener(changeListener);
 
         TextWatcher textWatcher = new TextWatcher() {
             @Override

--
Gitblit v1.9.1