Project

General

Profile

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

magiccube / src / main / java / org / distorted / screens / RubikScreenSolver.java @ b600ccd9

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.ObjectControl;
37
import org.distorted.objectlib.main.TwistyObject;
38
import org.distorted.objectlib.main.ObjectType;
39

    
40
import org.distorted.dialogs.RubikDialogSolverError;
41
import org.distorted.helpers.TransparentImageButton;
42
import org.distorted.main.R;
43
import org.distorted.main.RubikActivity;
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 TransparentImageButton 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
    ObjectControl control = act.getControl();
66
    control.unsetLock();
67
    }
68

    
69
///////////////////////////////////////////////////////////////////////////////////////////////////
70

    
71
  void enterScreen(final RubikActivity act)
72
    {
73
    ObjectControl control = act.getControl();
74
    control.setLock(false);
75

    
76
    float width = act.getScreenWidthInPixels();
77
    float heigh = act.getScreenHeightInPixels();
78

    
79
    int sizeV = (int)(heigh*RubikActivity.SOLVER_BMP_V_SIZE);
80
    int sizeH = (int)(width*RubikActivity.SOLVER_BMP_H_SIZE);
81

    
82
    mBitmapSize = Math.min(sizeV,sizeH);
83
    mWeakAct = new WeakReference<>(act);
84
    mSolving = false;
85

    
86
    ObjectType currentObject= ImplementedSolversList.getObject(0);
87
    act.changeIfDifferent(currentObject,control);
88
    control.solveOnly();
89

    
90
    RubikScreenPlay play = (RubikScreenPlay) ScreenList.PLAY.getScreenClass();
91
    play.setObject(act, currentObject);
92

    
93
    generateFaceColors();
94

    
95
    // TOP ////////////////////////////
96
    LinearLayout layoutTop = act.findViewById(R.id.upperBar);
97
    layoutTop.removeAllViews();
98

    
99
    LinearLayout.LayoutParams paramsL = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT,1);
100

    
101
    LinearLayout layoutLeft = new LinearLayout(act);
102
    layoutLeft.setLayoutParams(paramsL);
103
    LinearLayout layoutMid = new LinearLayout(act);
104
    layoutMid.setLayoutParams(paramsL);
105
    LinearLayout layoutRight = new LinearLayout(act);
106
    layoutRight.setLayoutParams(paramsL);
107

    
108
    if( mNumFaces>0 )
109
      {
110
      setupBitmaps();
111
      setupColorButtons(act,width);
112
      markButton(act);
113
      }
114

    
115
    for(ImageButton button: mColorButton) layoutTop.addView(button);
116

    
117
    // BOT ////////////////////////////
118
    LinearLayout layoutBot = act.findViewById(R.id.lowerBar);
119
    layoutBot.removeAllViews();
120

    
121
    setupSolveButton(act);
122
    setupBackButton(act);
123

    
124
    layoutLeft.addView(mSolveButton);
125
    layoutRight.addView(mBackButton);
126

    
127
    layoutBot.addView(layoutLeft);
128
    layoutBot.addView(layoutMid);
129
    layoutBot.addView(layoutRight);
130
    }
131

    
132
///////////////////////////////////////////////////////////////////////////////////////////////////
133

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

    
145
///////////////////////////////////////////////////////////////////////////////////////////////////
146

    
147
  private void setupBitmaps()
148
    {
149
    final int SIZE = (int)mBitmapSize;
150
    final float R = SIZE*0.15f;
151
    final float M = SIZE*0.08f;
152

    
153
    mBitmap = new Bitmap[mNumFaces];
154

    
155
    Paint paint = new Paint();
156
    paint.setColor(0xff008800);
157
    paint.setStyle(Paint.Style.FILL);
158

    
159
    paint.setAntiAlias(true);
160
    paint.setTextAlign(Paint.Align.CENTER);
161
    paint.setStyle(Paint.Style.FILL);
162

    
163
    for(int i=0; i<mNumFaces; i++)
164
      {
165
      mBitmap[i] = Bitmap.createBitmap(SIZE, SIZE, Bitmap.Config.ARGB_8888);
166
      Canvas canvas = new Canvas(mBitmap[i]);
167

    
168
      paint.setColor(0xff000000);
169
      canvas.drawRect(0, 0, SIZE, SIZE, paint);
170

    
171
      paint.setColor(mFaceColors[i]);
172
      canvas.drawRoundRect( M, M, SIZE-M, SIZE-M, R, R, paint);
173
      }
174
    }
175

    
176
///////////////////////////////////////////////////////////////////////////////////////////////////
177

    
178
  private void setupColorButtons(final RubikActivity act, final float width)
179
    {
180
    mColorButton = new ImageButton[mNumFaces];
181
    int padding = (int)(width*RubikActivity.PADDING);
182
    int margin  = (int)(width*RubikActivity.MARGIN);
183

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

    
193
      mColorButton[i] = new ImageButton(act);
194
      mColorButton[i].setLayoutParams(params);
195
      mColorButton[i].setPadding(padding,0,padding,0);
196
      mColorButton[i].setImageBitmap(mBitmap[i]);
197

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

    
210
///////////////////////////////////////////////////////////////////////////////////////////////////
211

    
212
  private void setupSolveButton(final RubikActivity act)
213
    {
214
    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);
215
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT,1.0f);
216
    mSolveButton = new TransparentImageButton(act,icon,TransparentImageButton.GRAVITY_MIDDLE,params);
217

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

    
234
///////////////////////////////////////////////////////////////////////////////////////////////////
235

    
236
  private void setupBackButton(final RubikActivity act)
237
    {
238
    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);
239
    LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT,LinearLayout.LayoutParams.MATCH_PARENT,1.0f);
240
    mBackButton = new TransparentImageButton(act, icon, TransparentImageButton.GRAVITY_MIDDLE, params);
241

    
242
    mBackButton.setOnClickListener( new View.OnClickListener()
243
      {
244
      @Override
245
      public void onClick(View v)
246
        {
247
        ObjectControl control = act.getControl();
248
        control.resetAllTextureMaps();
249
        ScreenList.goBack(act);
250
        }
251
      });
252
    }
253

    
254
///////////////////////////////////////////////////////////////////////////////////////////////////
255

    
256
  private void markButton(RubikActivity act)
257
    {
258
    for(int b=0; b<mNumFaces; b++)
259
      {
260
      Drawable d = mColorButton[b].getBackground();
261

    
262
      if( b==mCurrentColor )
263
        {
264
        d.setColorFilter(ContextCompat.getColor(act,R.color.red), PorterDuff.Mode.MULTIPLY);
265
        }
266
      else
267
        {
268
        d.clearColorFilter();
269
        }
270
      }
271
    }
272

    
273
///////////////////////////////////////////////////////////////////////////////////////////////////
274

    
275
  public void savePreferences(SharedPreferences.Editor editor)
276
    {
277
    editor.putInt("stateSolver_color", mCurrentColor);
278
    }
279

    
280
///////////////////////////////////////////////////////////////////////////////////////////////////
281

    
282
  public void restorePreferences(SharedPreferences preferences)
283
    {
284
    mCurrentColor = preferences.getInt("stateSolver_color", 0);
285
    }
286

    
287
///////////////////////////////////////////////////////////////////////////////////////////////////
288

    
289
  public int getCurrentColor()
290
    {
291
    return mCurrentColor;
292
    }
293

    
294
///////////////////////////////////////////////////////////////////////////////////////////////////
295

    
296
  public void setSolved(final String moves)
297
    {
298
    mSolving = false;
299
    final RubikActivity act = mWeakAct.get();
300

    
301
    if( act!=null )
302
      {
303
      act.runOnUiThread(new Runnable()
304
        {
305
        @Override
306
        public void run()
307
          {
308
          ScreenList.switchScreen(act, ScreenList.SOLU);
309
          RubikScreenSolution solution = (RubikScreenSolution) ScreenList.SOLU.getScreenClass();
310
          solution.setupMoves(act, moves);
311
          }
312
        });
313
      }
314
    }
315

    
316
///////////////////////////////////////////////////////////////////////////////////////////////////
317

    
318
  public void displayErrorDialog( String message)
319
    {
320
    mSolving = false;
321
    RubikActivity act = mWeakAct.get();
322

    
323
    if( act!=null )
324
      {
325
      RubikDialogSolverError dialog = new RubikDialogSolverError();
326
      Bundle bundle = new Bundle();
327
      bundle.putString("error", message );
328
      dialog.setArguments(bundle);
329
      dialog.show( act.getSupportFragmentManager(), null);
330
      }
331
    }
332
  }
(8-8/10)