Project

General

Profile

Download (11.3 KB) Statistics
| Branch: | Tag: | Revision:

magiccube / src / main / java / org / distorted / screens / RubikScreenSolver.java @ 3f7a4363

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2020 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Magic Cube.                                                              //
5
//                                                                                               //
6
// Magic Cube is free software: you can redistribute it and/or modify                            //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Magic Cube is distributed in the hope that it will be useful,                                 //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Magic Cube.  If not, see <http://www.gnu.org/licenses/>.                           //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.screens;
21

    
22
import java.lang.ref.WeakReference;
23

    
24
import android.content.SharedPreferences;
25
import android.graphics.Bitmap;
26
import android.graphics.Canvas;
27
import android.graphics.Paint;
28
import android.graphics.PorterDuff;
29
import android.graphics.drawable.Drawable;
30
import android.os.Bundle;
31
import androidx.core.content.ContextCompat;
32
import android.view.View;
33
import android.widget.ImageButton;
34
import android.widget.LinearLayout;
35

    
36
import org.distorted.objectlib.main.TwistyObject;
37
import org.distorted.objectlib.main.ObjectList;
38

    
39
import org.distorted.dialogs.RubikDialogSolverError;
40
import org.distorted.helpers.TransparentImageButton;
41
import org.distorted.main.R;
42
import org.distorted.main.RubikActivity;
43
import org.distorted.main.RubikPreRender;
44
import org.distorted.solvers.ImplementedSolversList;
45
import org.distorted.solvers.SolverMain;
46

    
47
///////////////////////////////////////////////////////////////////////////////////////////////////
48

    
49
public class RubikScreenSolver extends RubikScreenAbstract
50
  {
51
  private static Bitmap[] mBitmap;
52
  private ImageButton[] mColorButton;
53
  private ImageButton mBackButton, mSolveButton;
54
  private boolean mSolving;
55
  private int mCurrentColor;
56
  private int[] mFaceColors;
57
  private int mNumFaces;
58
  private float mBitmapSize;
59
  private WeakReference<RubikActivity> mWeakAct;
60

    
61
///////////////////////////////////////////////////////////////////////////////////////////////////
62

    
63
  void leaveScreen(RubikActivity act)
64
    {
65

    
66
    }
67

    
68
///////////////////////////////////////////////////////////////////////////////////////////////////
69

    
70
  void enterScreen(final RubikActivity act)
71
    {
72
    float width = act.getScreenWidthInPixels();
73
    float heigh = act.getScreenHeightInPixels();
74

    
75
    int sizeV = (int)(heigh*RubikActivity.SOLVER_BMP_V_SIZE);
76
    int sizeH = (int)(width*RubikActivity.SOLVER_BMP_H_SIZE);
77

    
78
    mBitmapSize = Math.min(sizeV,sizeH);
79
    mWeakAct = new WeakReference<>(act);
80
    mSolving = false;
81

    
82
    ObjectList currentObject= ImplementedSolversList.getObject(0);
83
    int currentObjectSize   = ImplementedSolversList.getObjectSize(0);
84

    
85
    act.setupObject(currentObject, currentObjectSize, null);
86
    RubikScreenPlay play = (RubikScreenPlay) ScreenList.PLAY.getScreenClass();
87
    play.setObjectAndSize(act, currentObject, currentObjectSize);
88

    
89
    generateFaceColors();
90

    
91
    // TOP ////////////////////////////
92
    LinearLayout layoutTop = act.findViewById(R.id.upperBar);
93
    layoutTop.removeAllViews();
94

    
95
    LinearLayout.LayoutParams paramsL = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT,1);
96

    
97
    LinearLayout layoutLeft = new LinearLayout(act);
98
    layoutLeft.setLayoutParams(paramsL);
99
    LinearLayout layoutMid = new LinearLayout(act);
100
    layoutMid.setLayoutParams(paramsL);
101
    LinearLayout layoutRight = new LinearLayout(act);
102
    layoutRight.setLayoutParams(paramsL);
103

    
104
    if( mNumFaces>0 )
105
      {
106
      setupBitmaps();
107
      setupColorButtons(act,width);
108
      markButton(act);
109
      }
110

    
111
    for(ImageButton button: mColorButton) layoutTop.addView(button);
112

    
113
    // BOT ////////////////////////////
114
    LinearLayout layoutBot = act.findViewById(R.id.lowerBar);
115
    layoutBot.removeAllViews();
116

    
117
    setupSolveButton(act,width);
118
    setupBackButton(act,width);
119

    
120
    layoutLeft.addView(mSolveButton);
121
    layoutRight.addView(mBackButton);
122

    
123
    layoutBot.addView(layoutLeft);
124
    layoutBot.addView(layoutMid);
125
    layoutBot.addView(layoutRight);
126
    }
127

    
128
///////////////////////////////////////////////////////////////////////////////////////////////////
129

    
130
  public void generateFaceColors()
131
    {
132
    mFaceColors= new int[] {  TwistyObject.COLOR_YELLOW,
133
                              TwistyObject.COLOR_WHITE,
134
                              TwistyObject.COLOR_BLUE ,
135
                              TwistyObject.COLOR_GREEN,
136
                              TwistyObject.COLOR_RED   ,
137
                              TwistyObject.COLOR_ORANGE };
138
    mNumFaces = 6;
139
    }
140

    
141
///////////////////////////////////////////////////////////////////////////////////////////////////
142

    
143
  private void setupBitmaps()
144
    {
145
    final int SIZE = (int)mBitmapSize;
146
    final float R = SIZE*0.15f;
147
    final float M = SIZE*0.08f;
148

    
149
    mBitmap = new Bitmap[mNumFaces];
150

    
151
    Paint paint = new Paint();
152
    paint.setColor(0xff008800);
153
    paint.setStyle(Paint.Style.FILL);
154

    
155
    paint.setAntiAlias(true);
156
    paint.setTextAlign(Paint.Align.CENTER);
157
    paint.setStyle(Paint.Style.FILL);
158

    
159
    for(int i=0; i<mNumFaces; i++)
160
      {
161
      mBitmap[i] = Bitmap.createBitmap(SIZE, SIZE, Bitmap.Config.ARGB_8888);
162
      Canvas canvas = new Canvas(mBitmap[i]);
163

    
164
      paint.setColor(0xff000000);
165
      canvas.drawRect(0, 0, SIZE, SIZE, paint);
166

    
167
      paint.setColor(mFaceColors[i]);
168
      canvas.drawRoundRect( M, M, SIZE-M, SIZE-M, R, R, paint);
169
      }
170
    }
171

    
172
///////////////////////////////////////////////////////////////////////////////////////////////////
173

    
174
  private void setupColorButtons(final RubikActivity act, final float width)
175
    {
176
    mColorButton = new ImageButton[mNumFaces];
177
    int padding = (int)(width*RubikActivity.PADDING);
178
    int margin  = (int)(width*RubikActivity.MARGIN);
179

    
180
    for(int i=0; i<mNumFaces; i++)
181
      {
182
      final int ii = i;
183
      LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.MATCH_PARENT, 1.0f);
184
      params.topMargin    = margin;
185
      params.bottomMargin = margin;
186
      params.leftMargin   = margin;
187
      params.rightMargin  = margin;
188

    
189
      mColorButton[i] = new ImageButton(act);
190
      mColorButton[i].setLayoutParams(params);
191
      mColorButton[i].setPadding(padding,0,padding,0);
192
      mColorButton[i].setImageBitmap(mBitmap[i]);
193

    
194
      mColorButton[i].setOnClickListener( new View.OnClickListener()
195
        {
196
        @Override
197
        public void onClick(View view)
198
          {
199
          mCurrentColor = ii;
200
          markButton(act);
201
          }
202
        });
203
      }
204
    }
205

    
206
///////////////////////////////////////////////////////////////////////////////////////////////////
207

    
208
  private void setupSolveButton(final RubikActivity act, final float width)
209
    {
210
    final int icon = RubikActivity.getDrawable(R.drawable.ui_small_solve,R.drawable.ui_medium_solve, R.drawable.ui_big_solve, R.drawable.ui_huge_solve);
211
    mSolveButton = new TransparentImageButton(act,icon,width, LinearLayout.LayoutParams.MATCH_PARENT);
212

    
213
    mSolveButton.setOnClickListener( new View.OnClickListener()
214
      {
215
      @Override
216
      public void onClick(View v)
217
        {
218
        if( !mSolving )
219
          {
220
          mSolving = true;
221
          TwistyObject object = act.getObject();
222
          SolverMain solver = new SolverMain( act.getResources(), object );
223
          solver.start();
224
          }
225
        }
226
      });
227
    }
228

    
229
///////////////////////////////////////////////////////////////////////////////////////////////////
230

    
231
  private void setupBackButton(final RubikActivity act, final float width)
232
    {
233
    final int icon = RubikActivity.getDrawable(R.drawable.ui_small_back,R.drawable.ui_medium_back, R.drawable.ui_big_back, R.drawable.ui_huge_back);
234
    mBackButton = new TransparentImageButton(act, icon, width, LinearLayout.LayoutParams.MATCH_PARENT);
235

    
236
    mBackButton.setOnClickListener( new View.OnClickListener()
237
      {
238
      @Override
239
      public void onClick(View v)
240
        {
241
        RubikPreRender pre = act.getPreRender();
242
        pre.resetAllTextureMaps();
243
        ScreenList.goBack(act);
244
        }
245
      });
246
    }
247

    
248
///////////////////////////////////////////////////////////////////////////////////////////////////
249

    
250
  private void markButton(RubikActivity act)
251
    {
252
    for(int b=0; b<mNumFaces; b++)
253
      {
254
      Drawable d = mColorButton[b].getBackground();
255

    
256
      if( b==mCurrentColor )
257
        {
258
        d.setColorFilter(ContextCompat.getColor(act,R.color.red), PorterDuff.Mode.MULTIPLY);
259
        }
260
      else
261
        {
262
        d.clearColorFilter();
263
        }
264
      }
265
    }
266

    
267
///////////////////////////////////////////////////////////////////////////////////////////////////
268

    
269
  public void savePreferences(SharedPreferences.Editor editor)
270
    {
271
    editor.putInt("stateSolver_color", mCurrentColor);
272
    }
273

    
274
///////////////////////////////////////////////////////////////////////////////////////////////////
275

    
276
  public void restorePreferences(SharedPreferences preferences)
277
    {
278
    mCurrentColor = preferences.getInt("stateSolver_color", 0);
279
    }
280

    
281
///////////////////////////////////////////////////////////////////////////////////////////////////
282

    
283
  public int getCurrentColor()
284
    {
285
    return mCurrentColor;
286
    }
287

    
288
///////////////////////////////////////////////////////////////////////////////////////////////////
289

    
290
  public void setSolved(final String moves)
291
    {
292
    mSolving = false;
293
    final RubikActivity act = mWeakAct.get();
294

    
295
    if( act!=null )
296
      {
297
      act.runOnUiThread(new Runnable()
298
        {
299
        @Override
300
        public void run()
301
          {
302
          ScreenList.switchScreen(act, ScreenList.SOLU);
303
          RubikScreenSolution solution = (RubikScreenSolution) ScreenList.SOLU.getScreenClass();
304
          solution.setupMoves(act, moves);
305
          }
306
        });
307
      }
308
    }
309

    
310
///////////////////////////////////////////////////////////////////////////////////////////////////
311

    
312
  public void displayErrorDialog( String message)
313
    {
314
    mSolving = false;
315
    RubikActivity act = mWeakAct.get();
316

    
317
    if( act!=null )
318
      {
319
      RubikDialogSolverError dialog = new RubikDialogSolverError();
320
      Bundle bundle = new Bundle();
321
      bundle.putString("error", message );
322
      dialog.setArguments(bundle);
323
      dialog.show( act.getSupportFragmentManager(), null);
324
      }
325
    }
326
  }
(8-8/10)