Project

General

Profile

« Previous | Next » 

Revision ff4a2a13

Added by Leszek Koltunski 4 months ago

progress with new sorting methods.

View differences:

src/main/java/org/distorted/bandaged/BandagedRenderer.java
304 304
     try
305 305
       {
306 306
       JsonWriter writer = JsonWriter.getInstance();
307
       String json = writer.createObjectString(object,24,0);
307
       String json = writer.createObjectString(object);
308 308
       writer.write(filename,json);
309 309
       return true;
310 310
       }
src/main/java/org/distorted/config/ConfigScreenPane.java
9 9

  
10 10
package org.distorted.config;
11 11

  
12
import static org.distorted.objects.RubikObjectCategories.DIFF_IDS;
13
import static org.distorted.objects.RubikObjectCategories.DIFF_IMAGES;
14

  
12 15
import java.io.InputStream;
13 16

  
14 17
import android.graphics.PorterDuff;
......
26 29

  
27 30
public class ConfigScreenPane
28 31
{
29
  private static final int[] IDS =
30
    {
31
    R.id.configDifficulty0,
32
    R.id.configDifficulty1,
33
    R.id.configDifficulty2,
34
    R.id.configDifficulty3,
35
    R.id.configDifficulty4
36
    };
37

  
38
  private static final int[] IMAGES =
39
    {
40
    R.drawable.difficulty1,
41
    R.drawable.difficulty2,
42
    R.drawable.difficulty3,
43
    R.drawable.difficulty4,
44
    R.drawable.difficulty5,
45
    };
46

  
47
  private static final int NUM_IDS         = IDS.length;
32
  private static final int NUM_IDS         = DIFF_IDS.length;
48 33
  private static final float PADDING_RATIO = 0.016f;
49 34
  private static final float TEXT_RATIO    = 0.025f;
50 35

  
......
66 51
        {
67 52
        reader.parseJsonFileMetadata(stream);
68 53
        name       = reader.getObjectName();
69
        author     = reader.getInventor();
54
        author     = reader.getAuthor();
70 55
        year       = reader.getYearOfInvention();
71
        difficulty = (int)reader.getComplexity();
56
        difficulty = (int)reader.getDifficulty();
72 57
        }
73 58
      catch(Exception ex)
74 59
        {
......
91 76

  
92 77
      for(int i=0; i<NUM_IDS; i++)
93 78
        {
94
        ImageView image = layout.findViewById(IDS[i]);
95
        image.setImageResource(IMAGES[i]);
79
        ImageView image = layout.findViewById(DIFF_IDS[i]);
80
        image.setImageResource(DIFF_IMAGES[i]);
96 81
        image.setColorFilter( difficulty==i ? 0xffff0000 : 0xffffffff, PorterDuff.Mode.MULTIPLY );
97 82
        }
98 83
      }
src/main/java/org/distorted/dialogs/RubikDialogUpdateView.java
197 197
          File file = new File(act.getFilesDir(), objectName);
198 198
          InputStream stream = new FileInputStream(file);
199 199
          JsonReader reader = new JsonReader();
200
          reader.readNumScramblesAndPrice(stream);
200
          reader.parseJsonFileMetadata(stream);
201 201
          stream.close();
202 202

  
203 203
          mInfo.mNumScrambles = reader.getNumScrambles();
204 204
          mInfo.mPrice        = reader.getPrice();
205
          float diff          = reader.getDifficulty();
206
          int category        = reader.getCategory();
207
          int year            = reader.getYearOfInvention();
208
          String author       = reader.getAuthor();
209

  
205 210
          if( SHOW_DOWNLOADED_DEBUG ) android.util.Log.e("D", "Read from JSON numScrambles="+mInfo.mNumScrambles+" price="+mInfo.mPrice);
206 211

  
207 212
          if( mInfo.mExtrasStream!=null )
......
218 223

  
219 224
            if( SHOW_DOWNLOADED_DEBUG ) android.util.Log.e("D", "1");
220 225

  
221
            boolean success = RubikObjectList.addDownloadedObject(act, mInfo.mObjectShortName, mInfo.mNumScrambles, mInfo.mPrice,
222
                                                                  mInfo.mObjectMinorVersion, mInfo.mExtrasMinorVersion, mIconSaved, oSuccess, eSuccess);
226
            boolean success = RubikObjectList.addDownloadedObject(act, mInfo.mObjectShortName, mInfo.mNumScrambles, mInfo.mPrice, mInfo.mObjectMinorVersion,
227
                                                                  mInfo.mExtrasMinorVersion, mIconSaved, oSuccess, eSuccess, diff, category, year, author);
223 228
            if( success )
224 229
              {
225 230
              if( SHOW_DOWNLOADED_DEBUG ) android.util.Log.e("D", "2");
src/main/java/org/distorted/helpers/ObjectGridCreator.java
235 235
      }
236 236

  
237 237
    LayoutInflater layoutInflater = (LayoutInflater)act.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
238
    int obj = 0;
238 239

  
239 240
    for(int object : objects)
240 241
      {
241 242
      View v = createView(act,layoutInflater,object,mPadding );
242
      int row = object/colCount;
243
      int row = obj/colCount;
244
      obj++;
245
      GridLayout.Spec rs = rowSpecs[row];
246
      GridLayout.Spec cs = colSpecs[nextInRow[row]];
243 247

  
244
      GridLayout.LayoutParams params = new GridLayout.LayoutParams(rowSpecs[row],colSpecs[nextInRow[row]]);
248
      GridLayout.LayoutParams params = new GridLayout.LayoutParams(rs,cs);
245 249
      params.bottomMargin = mMargin;
246 250
      params.topMargin    = mMargin;
247 251
      params.leftMargin   = mMargin;
src/main/java/org/distorted/objects/RubikObject.java
42 42
  private final int mSolverOrdinal;
43 43
  private final int mObjectOrdinal;
44 44
  private final boolean mIsLocal;
45
  private final int mCategory, mYear;
46
  private final float mDifficulty;
47
  private final String mAuthor;
45 48

  
46 49
  private boolean mIsFree;
47 50
  private int mJsonID, mMeshID, mExtrasID;
......
65 68
    mJsonID      = meta.objectJson();
66 69
    mMeshID      = meta.mesh();
67 70
    mExtrasID    = meta.extrasJson();
71
    mDifficulty  = meta.getDifficulty();
72
    mCategory    = meta.getCategory();
73
    mYear        = meta.getYearOfInvention();
74
    mAuthor      = meta.getAuthor();
68 75
    mIsLocal     = false;
69 76

  
70 77
    int patternOrdinal  = RubikPatternList.getOrdinal(mObjectOrdinal);
......
90 97
    mIsFree        = mPrice==0;
91 98
    mObjectVersion = object.objectVersion;
92 99
    mExtrasVersion = object.extrasVersion;
100
    mDifficulty    = object.difficulty;
101
    mCategory      = object.category;
102
    mYear          = object.year;
103
    mAuthor        = object.author;
93 104

  
94 105
    mPatterns      = null;
95 106
    mExtrasOrdinal = -1;
......
285 296
    return null;
286 297
    }
287 298

  
299
///////////////////////////////////////////////////////////////////////////////////////////////////
300

  
301
  public int getCategory()
302
    {
303
    return mCategory;
304
    }
305

  
306
///////////////////////////////////////////////////////////////////////////////////////////////////
307

  
308
  public float getDifficulty()
309
    {
310
    return mDifficulty;
311
    }
312

  
313
///////////////////////////////////////////////////////////////////////////////////////////////////
314

  
315
  public int getYearOfInvention()
316
    {
317
    return mYear;
318
    }
319

  
320
///////////////////////////////////////////////////////////////////////////////////////////////////
321

  
322
  public String getAuthor()
323
    {
324
    return mAuthor;
325
    }
326

  
288 327
///////////////////////////////////////////////////////////////////////////////////////////////////
289 328

  
290 329
  public boolean hasExtras()
src/main/java/org/distorted/objects/RubikObjectCategories.java
11 11

  
12 12
import static org.distorted.main.MainSettingsPopup.*;
13 13

  
14
import org.distorted.main.R;
15

  
16
import java.util.Arrays;
17

  
14 18
///////////////////////////////////////////////////////////////////////////////////////////////////
15 19

  
16 20
public class RubikObjectCategories
17 21
{
22
  public static final int[] DIFF_IDS =
23
    {
24
    R.id.configDifficulty0,
25
    R.id.configDifficulty1,
26
    R.id.configDifficulty2,
27
    R.id.configDifficulty3,
28
    R.id.configDifficulty4
29
    };
30

  
31
  public static final int[] DIFF_IMAGES =
32
    {
33
    R.drawable.difficulty1,
34
    R.drawable.difficulty2,
35
    R.drawable.difficulty3,
36
    R.drawable.difficulty4,
37
    R.drawable.difficulty5,
38
    };
39

  
40
  public static final int[] CATEGORY_IMAGES =
41
    {
42
    R.drawable.difficulty1,
43
    R.drawable.difficulty2,
44
    R.drawable.difficulty3,
45
    R.drawable.difficulty4,
46
    R.drawable.difficulty5,
47
    };
48

  
18 49
  private final int mNumCategories;
19 50
  private int[][] mObjectIndices;
20 51
  private int[] mIconIDs;
......
43 74
      }
44 75
    }
45 76

  
77
///////////////////////////////////////////////////////////////////////////////////////////////////
78

  
79
  private void buildSortStr(String[] data)
80
    {
81
    int numObjects = data.length;
82
    String[] sorted = new String[numObjects];
83
    System.arraycopy(data, 0, sorted, 0, numObjects);
84

  
85
    Arrays.sort(sorted);
86

  
87
    String[] categories = new String[numObjects];
88
    int numCategories = 0;
89

  
90
    for(int o=0; o<numObjects; o++)
91
      if( o==0 || !sorted[o-1].equals(sorted[o]) )
92
        {
93
        categories[numCategories] = sorted[o];
94
        numCategories++;
95
        }
96

  
97
    int lastChange = -1;
98
    int curr = 0;
99
    int[] numInCategory = new int[numCategories];
100

  
101
    for(int o=0; o<numObjects; o++)
102
      if( o==numObjects-1 || !sorted[o].equals(sorted[o+1]) )
103
        {
104
        numInCategory[curr] = o-lastChange;
105
        curr++;
106
        lastChange = o;
107
        }
108

  
109
    mObjectIndices = new int[numCategories][];
110

  
111
    for(int c=0; c<numCategories; c++)
112
      {
113
      mObjectIndices[c] = new int[numInCategory[c]];
114

  
115
      String cat = categories[c];
116
      int index = 0;
117

  
118
      for(int o=0; o<numObjects; o++)
119
        if( data[o].equals(cat) ) mObjectIndices[c][index++] = o;
120
      }
121
    }
122

  
123
///////////////////////////////////////////////////////////////////////////////////////////////////
124

  
125
  private void buildSortInt(int[] data)
126
    {
127
    int numObjects = data.length;
128
    int[] sorted = new int[numObjects];
129
    System.arraycopy(data, 0, sorted, 0, numObjects);
130

  
131
    Arrays.sort(sorted);
132

  
133
    int[] categories = new int[numObjects];
134
    int numCategories = 0;
135

  
136
    for(int o=0; o<numObjects; o++)
137
      if( o==0 || sorted[o-1]!=sorted[o] )
138
        {
139
        categories[numCategories] = sorted[o];
140
        numCategories++;
141
        }
142

  
143
    int lastChange = -1;
144
    int curr = 0;
145
    int[] numInCategory = new int[numCategories];
146

  
147
    for(int o=0; o<numObjects; o++)
148
      if( o==numObjects-1 || sorted[o]!=sorted[o+1] )
149
        {
150
        numInCategory[curr] = o-lastChange;
151
        curr++;
152
        lastChange = o;
153
        }
154

  
155
    mObjectIndices = new int[numCategories][];
156

  
157
    for(int c=0; c<numCategories; c++)
158
      {
159
      mObjectIndices[c] = new int[numInCategory[c]];
160

  
161
      int cat = categories[c];
162
      int index = 0;
163

  
164
      for(int o=0; o<numObjects; o++)
165
        if( data[o]==cat ) mObjectIndices[c][index++] = o;
166
      }
167
    }
168

  
169
///////////////////////////////////////////////////////////////////////////////////////////////////
170

  
171
  private void buildSortFloat(float[] data)
172
    {
173
    int numObjects = data.length;
174
    float[] sorted = new float[numObjects];
175
    System.arraycopy(data, 0, sorted, 0, numObjects);
176

  
177
    Arrays.sort(sorted);
178

  
179
    float[] categories = new float[numObjects];
180
    int numCategories = 0;
181

  
182
    for(int o=0; o<numObjects; o++)
183
      if( o==0 || sorted[o-1]!=sorted[o] )
184
        {
185
        categories[numCategories] = sorted[o];
186
        numCategories++;
187
        }
188

  
189
    int lastChange = -1;
190
    int curr = 0;
191
    int[] numInCategory = new int[numCategories];
192

  
193
    for(int o=0; o<numObjects; o++)
194
      if( o==numObjects-1 || sorted[o]!=sorted[o+1] )
195
        {
196
        numInCategory[curr] = o-lastChange;
197
        curr++;
198
        lastChange = o;
199
        }
200

  
201
    mObjectIndices = new int[numCategories][];
202

  
203
    for(int c=0; c<numCategories; c++)
204
      {
205
      mObjectIndices[c] = new int[numInCategory[c]];
206

  
207
      float cat = categories[c];
208
      int index = 0;
209

  
210
      for(int o=0; o<numObjects; o++)
211
        if( data[o]==cat ) mObjectIndices[c][index++] = o;
212
      }
213
    }
214

  
46 215
///////////////////////////////////////////////////////////////////////////////////////////////////
47 216

  
48 217
  private void buildSortCategory()
49 218
    {
219
    int numObjects = RubikObjectList.getNumObjects();
220
    int[] cats = new int[numObjects];
50 221

  
222
    for(int o=0; o<numObjects; o++)
223
      {
224
      RubikObject obj = RubikObjectList.getObject(o);
225
      cats[o] = obj==null ? 0 : obj.getCategory();
226
      }
227

  
228
    buildSortInt(cats);
51 229
    }
52 230

  
53 231
///////////////////////////////////////////////////////////////////////////////////////////////////
54 232

  
55 233
  private void buildSortDifficulty()
56 234
    {
235
    int numObjects = RubikObjectList.getNumObjects();
236
    float[] diffs = new float[numObjects];
237

  
238
    for(int o=0; o<numObjects; o++)
239
      {
240
      RubikObject obj = RubikObjectList.getObject(o);
241
      diffs[o] = obj==null ? 0 : obj.getDifficulty();
242
      }
57 243

  
244
    buildSortFloat(diffs);
58 245
    }
59 246

  
60 247
///////////////////////////////////////////////////////////////////////////////////////////////////
61 248

  
62 249
  private void buildSortAuthor()
63 250
    {
251
    int numObjects = RubikObjectList.getNumObjects();
252
    String[] auths = new String[numObjects];
253

  
254
    for(int o=0; o<numObjects; o++)
255
      {
256
      RubikObject obj = RubikObjectList.getObject(o);
257
      auths[o] = obj==null ? "" : obj.getAuthor();
258
      }
64 259

  
260
    buildSortStr(auths);
65 261
    }
66 262

  
67 263
///////////////////////////////////////////////////////////////////////////////////////////////////
68 264

  
69 265
  private void buildSortYear()
70 266
    {
267
    int numObjects = RubikObjectList.getNumObjects();
268
    int[] years = new int[numObjects];
71 269

  
270
    for(int o=0; o<numObjects; o++)
271
      {
272
      RubikObject obj = RubikObjectList.getObject(o);
273
      years[o] = obj==null ? 0 : obj.getYearOfInvention();
274
      }
275

  
276
    buildSortInt(years);
72 277
    }
73 278

  
74 279
///////////////////////////////////////////////////////////////////////////////////////////////////
75 280

  
76 281
  private void buildIconsCategory()
77 282
    {
283
    mIconIDs = new int[mNumCategories];
78 284

  
285
    for(int t=0; t<mNumCategories; t++)
286
      {
287
      int obj = mObjectIndices[t][0];
288
      RubikObject object = RubikObjectList.getObject(obj);
289
      int category = object==null ? 0 : object.getCategory();
290
      mIconIDs[t] = CATEGORY_IMAGES[category%5];  //TODO
291
      }
79 292
    }
80 293

  
81 294
///////////////////////////////////////////////////////////////////////////////////////////////////
82 295

  
83 296
  private void buildIconsDifficulty()
84 297
    {
298
    mIconIDs = new int[mNumCategories];
85 299

  
300
    for(int t=0; t<mNumCategories; t++)
301
      {
302
      int obj = mObjectIndices[t][0];
303
      RubikObject object = RubikObjectList.getObject(obj);
304
      int difficulty = object==null ? 0 : (int)object.getDifficulty();
305
      mIconIDs[t] = DIFF_IMAGES[difficulty];
306
      }
86 307
    }
87 308

  
88 309
///////////////////////////////////////////////////////////////////////////////////////////////////
......
95 316
      {
96 317
      int obj = mObjectIndices[t][0];
97 318
      RubikObject object = RubikObjectList.getObject(obj);
98

  
319
      mTitles[t] = object==null ? "" : object.getAuthor();
99 320
      }
100 321
    }
101 322

  
......
103 324

  
104 325
  private void buildTitleYear()
105 326
    {
327
    mTitles = new String[mNumCategories];
106 328

  
329
    for(int t=0; t<mNumCategories; t++)
330
      {
331
      int obj = mObjectIndices[t][0];
332
      RubikObject object = RubikObjectList.getObject(obj);
333
      int year = object==null ? 0 : object.getYearOfInvention();
334
      mTitles[t] = String.valueOf(year);
335
      }
107 336
    }
108 337

  
109 338
///////////////////////////////////////////////////////////////////////////////////////////////////
src/main/java/org/distorted/objects/RubikObjectList.java
39 39
    String shortName;
40 40
    boolean icon,object,extras;
41 41
    int numScrambles, objectVersion, extrasVersion, price;
42
    int category, year;
43
    float difficulty;
44
    String author;
42 45

  
43
    DownloadedObject(String sName, int scrambles, int pr, int oVersion, int eVersion, boolean i, boolean o, boolean e)
46
    DownloadedObject(String sName, int scrambles, int pr, int oVersion, int eVersion, boolean i,
47
                     boolean o, boolean e, float diff, int cat, int y, String a)
44 48
      {
45 49
      shortName     = sName;
46 50
      numScrambles  = scrambles;
47 51
      price         = pr;
48 52
      objectVersion = oVersion;
49 53
      extrasVersion = eVersion;
54
      difficulty    = diff;
55
      category      = cat;
56
      year          = y;
57
      author        = a;
50 58

  
51 59
      icon   = i;
52 60
      object = o;
......
186 194
// PUBLIC API
187 195

  
188 196
  public static boolean addDownloadedObject(Context context, String shortName, int numScrambles, int price, int objectVersion,
189
                                         int extrasVersion, boolean icon, boolean object, boolean extras)
197
                                         int extrasVersion, boolean icon, boolean object, boolean extras, float diff, int category, int year, String author)
190 198
    {
191 199
    if( SHOW_DOWNLOADED_DEBUG ) android.util.Log.e("D", "New downloaded object "+shortName+" icon="+icon+" object="+object+" extras="+extras);
192 200

  
......
213 221
    if( !object ) objectVersion=-1;
214 222
    if( !extras ) extrasVersion=-1;
215 223

  
216
    DownloadedObject obj = new DownloadedObject(shortName,numScrambles,price,objectVersion,extrasVersion,icon,object,extras);
224
    DownloadedObject obj = new DownloadedObject(shortName,numScrambles,price,objectVersion,extrasVersion,icon,object,extras,diff,category,year,author);
217 225
    if ( internalAddDownloadedObject(obj) )
218 226
      {
219 227
      if( SHOW_DOWNLOADED_DEBUG ) android.util.Log.e("D", "Adding new downloaded object "+shortName+" icon="+obj.icon+" object="+obj.object+" extras="+obj.extras);
......
310 318
        downloadedObjects.append(' ');
311 319
        downloadedObjects.append(object.extras ? "1":"0");
312 320
        downloadedObjects.append(' ');
321
        downloadedObjects.append(object.difficulty);
322
        downloadedObjects.append(' ');
323
        downloadedObjects.append(object.category);
324
        downloadedObjects.append(' ');
325
        downloadedObjects.append(object.year);
326
        downloadedObjects.append(' ');
327
        downloadedObjects.append(object.author);
328
        downloadedObjects.append(' ');
313 329
        downloadedObjects.append(object.price);
314 330
        }
315 331

  
......
352 368
        String[] parts = dObj.split(" ");
353 369
        int length = parts.length;
354 370

  
355
        if( length==7 || length==8 )
371
        if( length>=7 )
356 372
          {
357 373
          String name = parts[0];
358 374
          String scra = parts[1];
......
362 378
          String obje = parts[5];
363 379
          String extr = parts[6];
364 380

  
365
          int price;
381
          int price=0,category=0,year=0;
382
          float diff=0.0f;
383
          String author="";
366 384

  
367
          if( length==7 ) price=0;
368
          else
385
          if( length>=11 )
386
            {
387
            diff     = Float.parseFloat(parts[7]);
388
            category = Integer.parseInt(parts[8]);
389
            year     = Integer.parseInt(parts[9]);
390
            author   = parts[10];
391
            }
392
          if( length>=12 )
369 393
            {
370
            char c = parts[7].charAt(0);
394
            char c = parts[11].charAt(0);
371 395
            if( c=='t' )      price = 0;
372 396
            else if( c=='f' ) price = ListObjects.DEFAULT_PRICE_OF_OLD_OBJECTS;
373 397
            else              price = Integer.parseInt(parts[7]);
......
381 405
          boolean bObje = obje.equals("1");
382 406
          boolean bExtr = extr.equals("1");
383 407

  
384
          addDownloadedObject(context,name,scrambles,price,oVersion,eVersion,bIcon,bObje,bExtr);
408
          addDownloadedObject(context,name,scrambles,price,oVersion,eVersion,bIcon,bObje,bExtr,diff,category,year,author);
385 409
          }
386 410
        }
387 411
      }
src/main/java/org/distorted/purchase/PurchaseScreenPane.java
189 189
        {
190 190
        reader.parseJsonFileMetadata(stream);
191 191
        name       = reader.getObjectName();
192
        author     = reader.getInventor();
192
        author     = reader.getAuthor();
193 193
        year       = reader.getYearOfInvention();
194
        difficulty = (int)reader.getComplexity();
194
        difficulty = (int)reader.getDifficulty();
195 195
        }
196 196
      catch(Exception ex)
197 197
        {

Also available in: Unified diff