Revision 280dc794
Added by Leszek Koltunski about 3 years ago
src/main/java/org/distorted/config/ConfigActivity.java | ||
---|---|---|
35 | 35 |
import org.distorted.dmesh.ObjectMesh; |
36 | 36 |
import org.distorted.jsons.ObjectJson; |
37 | 37 |
import org.distorted.library.main.DistortedLibrary; |
38 |
import org.distorted.library.type.Static4D; |
|
39 | 38 |
import org.distorted.main.R; |
40 | 39 |
import org.distorted.objectlib.main.ObjectControl; |
41 |
import org.distorted.objectlib.main.ShapeDodecahedron; |
|
42 |
import org.distorted.objectlib.main.ShapeHexahedron; |
|
43 |
import org.distorted.objectlib.main.ShapeOctahedron; |
|
44 |
import org.distorted.objectlib.main.ShapeTetrahedron; |
|
45 | 40 |
import org.distorted.objects.RubikObject; |
46 | 41 |
import org.distorted.objects.RubikObjectList; |
47 | 42 |
|
... | ... | |
138 | 133 |
} |
139 | 134 |
} |
140 | 135 |
|
141 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
|
142 |
|
|
143 |
@Override |
|
144 |
public void onAttachedToWindow() |
|
145 |
{ |
|
146 |
super.onAttachedToWindow(); |
|
147 |
|
|
148 |
if( mScreen==null ) mScreen = new ConfigScreen(); |
|
149 |
mScreen.onAttachedToWindow(this,mObjectOrdinal); |
|
150 |
} |
|
151 |
|
|
152 | 136 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
153 | 137 |
// do not avoid cutouts |
154 | 138 |
|
... | ... | |
194 | 178 |
ConfigSurfaceView view = findViewById(R.id.configSurfaceView); |
195 | 179 |
view.onResume(); |
196 | 180 |
|
181 |
if( mScreen==null ) mScreen = new ConfigScreen(); |
|
182 |
mScreen.onAttachedToWindow(this,mObjectOrdinal); |
|
183 |
|
|
197 | 184 |
if( mObjectOrdinal>=0 && mObjectOrdinal< RubikObjectList.getNumObjects() ) |
198 | 185 |
{ |
199 | 186 |
RubikObject object = RubikObjectList.getObject(mObjectOrdinal); |
... | ... | |
240 | 227 |
// PUBLIC API |
241 | 228 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
242 | 229 |
|
243 |
public void changeObject(RubikObject object)
|
|
230 |
public void changeObject(int ordinal)
|
|
244 | 231 |
{ |
232 |
mObjectOrdinal = ordinal; |
|
233 |
RubikObject object = RubikObjectList.getObject(ordinal); |
|
245 | 234 |
ConfigSurfaceView view = findViewById(R.id.configSurfaceView); |
246 | 235 |
ObjectControl control = view.getObjectControl(); |
247 | 236 |
changeIfDifferent(object,control); |
src/main/java/org/distorted/config/ConfigScreen.java | ||
---|---|---|
117 | 117 |
if( act.getControl().isUINotBlocked() && mObjectOrdinal!=ordinal ) |
118 | 118 |
{ |
119 | 119 |
mObjectOrdinal = ordinal; |
120 |
act.changeObject(rubikObject);
|
|
120 |
act.changeObject(mObjectOrdinal);
|
|
121 | 121 |
mMovesText.setText(act.getString(R.string.mo_placeholder,mObjectOrdinal+1,numObjects)); |
122 | 122 |
mPane.updatePane(act,mObjectOrdinal); |
123 | 123 |
} |
... | ... | |
241 | 241 |
mObjectOrdinal--; |
242 | 242 |
if( mObjectOrdinal<0 ) mObjectOrdinal=numObjects-1; |
243 | 243 |
|
244 |
RubikObject object = RubikObjectList.getObject(mObjectOrdinal); |
|
245 |
act.changeObject(object); |
|
246 |
|
|
244 |
act.changeObject(mObjectOrdinal); |
|
247 | 245 |
mPane.updatePane(act,mObjectOrdinal); |
248 | 246 |
} |
249 | 247 |
|
... | ... | |
254 | 252 |
mObjectOrdinal++; |
255 | 253 |
if( mObjectOrdinal>=numObjects ) mObjectOrdinal=0; |
256 | 254 |
|
257 |
RubikObject object = RubikObjectList.getObject(mObjectOrdinal); |
|
258 |
act.changeObject(object); |
|
259 |
|
|
255 |
act.changeObject(mObjectOrdinal); |
|
260 | 256 |
mPane.updatePane(act,mObjectOrdinal); |
261 | 257 |
} |
262 | 258 |
|
src/main/java/org/distorted/tutorials/TutorialActivity.java | ||
---|---|---|
134 | 134 |
{ |
135 | 135 |
super.onAttachedToWindow(); |
136 | 136 |
|
137 |
float width = getScreenWidthInPixels(); |
|
138 |
|
|
139 |
LinearLayout viewR = findViewById(R.id.tutorialRightBar); |
|
140 |
ViewGroup.LayoutParams paramsR = viewR.getLayoutParams(); |
|
141 |
paramsR.width = (int)(width*BAR_RATIO); |
|
142 |
viewR.setLayoutParams(paramsR); |
|
143 |
|
|
144 |
if( mScreen==null ) mScreen = new TutorialScreen(); |
|
145 |
|
|
146 |
mScreen.createRightPane(this); |
|
147 |
|
|
148 |
WebView videoView = findViewById(R.id.tutorialVideoView); |
|
149 |
mWebView = new TutorialWebView(videoView); |
|
150 |
mWebView.load(URL+mURL); |
|
137 |
if( mWebView==null ) |
|
138 |
{ |
|
139 |
WebView videoView = findViewById(R.id.tutorialVideoView); |
|
140 |
mWebView = new TutorialWebView(videoView); |
|
141 |
mWebView.load(URL+mURL); |
|
142 |
} |
|
151 | 143 |
} |
152 | 144 |
|
153 | 145 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
... | ... | |
198 | 190 |
TutorialSurfaceView view = findViewById(R.id.tutorialSurfaceView); |
199 | 191 |
view.onResume(); |
200 | 192 |
|
193 |
float width = getScreenWidthInPixels(); |
|
194 |
|
|
195 |
LinearLayout viewR = findViewById(R.id.tutorialRightBar); |
|
196 |
ViewGroup.LayoutParams paramsR = viewR.getLayoutParams(); |
|
197 |
paramsR.width = (int)(width*BAR_RATIO); |
|
198 |
viewR.setLayoutParams(paramsR); |
|
199 |
|
|
200 |
if( mScreen==null ) mScreen = new TutorialScreen(); |
|
201 |
|
|
202 |
mScreen.createRightPane(this); |
|
203 |
|
|
201 | 204 |
if( mWebView!=null ) mWebView.onResume(); |
202 | 205 |
|
203 | 206 |
if( mObjectOrdinal>=0 && mObjectOrdinal< RubikObjectList.getNumObjects() ) |
Also available in: Unified diff
Improve the behaviour of the Config and Tutorial activities when in the 'PopUpMode'. Also, remember the current object in the COnfig activity so that when we put it to the background and resume - the object stays.