Revision 5055b5d4
Added by Leszek Koltunski almost 9 years ago
| src/main/java/org/distorted/examples/aroundtheworld/AroundTheWorldRenderer.java | ||
|---|---|---|
| 78 | 78 |
{
|
| 79 | 79 |
mObject.abortEffects(EffectTypes.MATRIX); |
| 80 | 80 |
|
| 81 |
if( mObjHeight/mObjWidth > height/width )
|
|
| 81 |
if( (float)mObjHeight/mObjWidth > (float)height/width )
|
|
| 82 | 82 |
{
|
| 83 | 83 |
int w = (height*mObjWidth)/mObjHeight; |
| 84 | 84 |
float factor = (float)height/mObjHeight; |
| src/main/java/org/distorted/examples/bean/BeanRenderer.java | ||
|---|---|---|
| 97 | 97 |
{
|
| 98 | 98 |
mBean.abortEffects(EffectTypes.MATRIX); |
| 99 | 99 |
|
| 100 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 100 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 101 | 101 |
{
|
| 102 | 102 |
int w = (height*bmpWidth)/bmpHeight; |
| 103 | 103 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/check/CheckRenderer.java | ||
|---|---|---|
| 84 | 84 |
{
|
| 85 | 85 |
mSuccess.abortEffects(EffectTypes.MATRIX); |
| 86 | 86 |
|
| 87 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 87 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 88 | 88 |
{
|
| 89 | 89 |
int w = (height*bmpWidth)/bmpHeight; |
| 90 | 90 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/differentbitmaps/DifferentBitmapsRenderer.java | ||
|---|---|---|
| 109 | 109 |
bmp[i].abortEffects(EffectTypes.MATRIX); |
| 110 | 110 |
} |
| 111 | 111 |
|
| 112 |
if( bmpHeight/(NUM*bmpWidth) > height/width )
|
|
| 112 |
if( (float)bmpHeight/(NUM*bmpWidth) > (float)height/width )
|
|
| 113 | 113 |
{
|
| 114 | 114 |
int w = (height*bmpWidth)/bmpHeight; |
| 115 | 115 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/differenteffects/DifferentEffectsRenderer.java | ||
|---|---|---|
| 77 | 77 |
|
| 78 | 78 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| 79 | 79 |
|
| 80 |
public void onDrawFrame(GL10 glUnused)
|
|
| 81 |
{
|
|
| 82 |
GLES20.glClear( GLES20.GL_DEPTH_BUFFER_BIT | GLES20.GL_COLOR_BUFFER_BIT);
|
|
| 80 |
public void onDrawFrame(GL10 glUnused)
|
|
| 81 |
{
|
|
| 82 |
GLES20.glClear( GLES20.GL_DEPTH_BUFFER_BIT | GLES20.GL_COLOR_BUFFER_BIT); |
|
| 83 | 83 |
|
| 84 |
long time = System.currentTimeMillis();
|
|
| 84 |
long time = System.currentTimeMillis(); |
|
| 85 | 85 |
|
| 86 |
for(int i=NUM-1; i>=0; i--) bmp[i].draw(time);
|
|
| 87 |
}
|
|
| 86 |
for(int i=NUM-1; i>=0; i--) bmp[i].draw(time); |
|
| 87 |
} |
|
| 88 | 88 |
|
| 89 | 89 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| 90 | 90 |
|
| 91 |
public void onSurfaceChanged(GL10 glUnused, int width, int height)
|
|
| 92 |
{
|
|
| 93 |
for(int i=NUM-1; i>=0; i--)
|
|
| 94 |
{
|
|
| 95 |
bmp[i].abortEffects(EffectTypes.MATRIX);
|
|
| 96 |
}
|
|
| 91 |
public void onSurfaceChanged(GL10 glUnused, int width, int height)
|
|
| 92 |
{
|
|
| 93 |
for(int i=NUM-1; i>=0; i--)
|
|
| 94 |
{
|
|
| 95 |
bmp[i].abortEffects(EffectTypes.MATRIX); |
|
| 96 |
} |
|
| 97 | 97 |
|
| 98 |
if( bmpHeight/(NUM*bmpWidth) > height/width )
|
|
| 99 |
{
|
|
| 100 |
int w = (height*bmpWidth)/bmpHeight;
|
|
| 101 |
float factor = (float)height/bmpHeight;
|
|
| 102 |
|
|
| 103 |
for(int i=NUM-1; i>=0; i--)
|
|
| 104 |
{
|
|
| 105 |
bmp[i].move( new Static3D((width-NUM*w)/2 +i*w , 0, 0) );
|
|
| 106 |
bmp[i].scale(factor);
|
|
| 107 |
}
|
|
| 108 |
}
|
|
| 109 |
else
|
|
| 110 |
{
|
|
| 111 |
int w = width/NUM;
|
|
| 112 |
int h = (width*bmpHeight)/(bmpWidth*NUM);
|
|
| 113 |
float factor = (float)width/(bmpWidth*NUM);
|
|
| 114 |
|
|
| 115 |
for(int i=NUM-1; i>=0; i--)
|
|
| 116 |
{
|
|
| 117 |
bmp[i].move( new Static3D(i*w, (height-h)/2, 0) );
|
|
| 118 |
bmp[i].scale(factor);
|
|
| 119 |
}
|
|
| 120 |
}
|
|
| 98 |
if( (float)bmpHeight/(NUM*bmpWidth) > (float)height/width )
|
|
| 99 |
{
|
|
| 100 |
int w = (height*bmpWidth)/bmpHeight; |
|
| 101 |
float factor = (float)height/bmpHeight; |
|
| 102 |
|
|
| 103 |
for(int i=NUM-1; i>=0; i--)
|
|
| 104 |
{
|
|
| 105 |
bmp[i].move( new Static3D((width-NUM*w)/2 +i*w , 0, 0) ); |
|
| 106 |
bmp[i].scale(factor); |
|
| 107 |
} |
|
| 108 |
} |
|
| 109 |
else |
|
| 110 |
{
|
|
| 111 |
int w = width/NUM;
|
|
| 112 |
int h = (width*bmpHeight)/(bmpWidth*NUM); |
|
| 113 |
float factor = (float)width/(bmpWidth*NUM); |
|
| 114 |
|
|
| 115 |
for(int i=NUM-1; i>=0; i--)
|
|
| 116 |
{
|
|
| 117 |
bmp[i].move( new Static3D(i*w, (height-h)/2, 0) ); |
|
| 118 |
bmp[i].scale(factor); |
|
| 119 |
} |
|
| 120 |
} |
|
| 121 | 121 |
|
| 122 |
Distorted.onSurfaceChanged(width, height);
|
|
| 123 |
}
|
|
| 122 |
Distorted.onSurfaceChanged(width, height);
|
|
| 123 |
} |
|
| 124 | 124 |
|
| 125 | 125 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| 126 | 126 |
|
| 127 |
public void onSurfaceCreated(GL10 glUnused, EGLConfig config)
|
|
| 128 |
{
|
|
| 129 |
GLES20.glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
|
| 127 |
public void onSurfaceCreated(GL10 glUnused, EGLConfig config)
|
|
| 128 |
{
|
|
| 129 |
GLES20.glClearColor(0.0f, 0.0f, 0.0f, 1.0f); |
|
| 130 | 130 |
|
| 131 |
InputStream is = mView.getContext().getResources().openRawResource(R.raw.dog);
|
|
| 132 |
Bitmap bitmap;
|
|
| 131 |
InputStream is = mView.getContext().getResources().openRawResource(R.raw.dog); |
|
| 132 |
Bitmap bitmap; |
|
| 133 | 133 |
|
| 134 |
try
|
|
| 135 |
{
|
|
| 136 |
bitmap = BitmapFactory.decodeStream(is);
|
|
| 137 |
}
|
|
| 138 |
finally
|
|
| 139 |
{
|
|
| 140 |
try
|
|
| 141 |
{
|
|
| 142 |
is.close();
|
|
| 143 |
}
|
|
| 144 |
catch(IOException e) { }
|
|
| 145 |
}
|
|
| 134 |
try
|
|
| 135 |
{
|
|
| 136 |
bitmap = BitmapFactory.decodeStream(is); |
|
| 137 |
}
|
|
| 138 |
finally
|
|
| 139 |
{
|
|
| 140 |
try
|
|
| 141 |
{
|
|
| 142 |
is.close(); |
|
| 143 |
}
|
|
| 144 |
catch(IOException e) { }
|
|
| 145 |
}
|
|
| 146 | 146 |
|
| 147 |
bmpHeight = bitmap.getHeight();
|
|
| 148 |
bmpWidth = bitmap.getWidth();
|
|
| 147 |
bmpHeight = bitmap.getHeight(); |
|
| 148 |
bmpWidth = bitmap.getWidth(); |
|
| 149 | 149 |
|
| 150 |
bmp = new DistortedBitmap[NUM];
|
|
| 151 |
bmp[0] = new DistortedBitmap(bmpWidth, bmpHeight, 30);
|
|
| 150 |
bmp = new DistortedBitmap[NUM]; |
|
| 151 |
bmp[0] = new DistortedBitmap(bmpWidth, bmpHeight, 30); |
|
| 152 | 152 |
|
| 153 |
for(int i=1; i<NUM; i++) bmp[i] = new DistortedBitmap(bmp[0], Distorted.CLONE_BITMAP);
|
|
| 153 |
for(int i=1; i<NUM; i++) bmp[i] = new DistortedBitmap(bmp[0], Distorted.CLONE_BITMAP); |
|
| 154 | 154 |
|
| 155 |
// setting the bitmap once is enough; others are cloned!
|
|
| 156 |
bmp[0].setBitmap(bitmap);
|
|
| 155 |
// setting the bitmap once is enough; others are cloned! |
|
| 156 |
bmp[0].setBitmap(bitmap); |
|
| 157 | 157 |
|
| 158 |
Dynamic1D sink = new Dynamic1D(2000,0.0f);
|
|
| 159 |
sink.add(new Static1D( 1));
|
|
| 160 |
sink.add(new Static1D(10));
|
|
| 158 |
Dynamic1D sink = new Dynamic1D(2000,0.0f); |
|
| 159 |
sink.add(new Static1D( 1)); |
|
| 160 |
sink.add(new Static1D(10)); |
|
| 161 | 161 |
|
| 162 |
bmp[0].sink(sink, pLeft, RegionEye);
|
|
| 163 |
bmp[0].sink(sink, pRight,RegionEye);
|
|
| 164 |
bmp[1].distort(mDI, pNose1);
|
|
| 162 |
bmp[0].sink(sink, pLeft, RegionEye); |
|
| 163 |
bmp[0].sink(sink, pRight,RegionEye); |
|
| 164 |
bmp[1].distort(mDI, pNose1); |
|
| 165 | 165 |
|
| 166 |
Dynamic1D chromaDyn = new Dynamic1D(3000,0.0f);
|
|
| 167 |
chromaDyn.add(new Static1D(0));
|
|
| 168 |
chromaDyn.add(new Static1D(1));
|
|
| 166 |
Dynamic1D chromaDyn = new Dynamic1D(3000,0.0f); |
|
| 167 |
chromaDyn.add(new Static1D(0)); |
|
| 168 |
chromaDyn.add(new Static1D(1)); |
|
| 169 | 169 |
|
| 170 |
bmp[2].chroma(chromaDyn, new Static3D(0,1,0) );
|
|
| 170 |
bmp[2].chroma(chromaDyn, new Static3D(0,1,0) ); |
|
| 171 | 171 |
|
| 172 |
try
|
|
| 173 |
{
|
|
| 174 |
Distorted.onSurfaceCreated(mView.getContext());
|
|
| 175 |
}
|
|
| 176 |
catch(Exception ex)
|
|
| 177 |
{
|
|
| 178 |
android.util.Log.e("DifferentEffects", ex.getMessage() );
|
|
| 179 |
}
|
|
| 180 |
}
|
|
| 172 |
try |
|
| 173 |
{
|
|
| 174 |
Distorted.onSurfaceCreated(mView.getContext()); |
|
| 175 |
} |
|
| 176 |
catch(Exception ex) |
|
| 177 |
{
|
|
| 178 |
android.util.Log.e("DifferentEffects", ex.getMessage() );
|
|
| 179 |
} |
|
| 180 |
} |
|
| 181 | 181 |
} |
| src/main/java/org/distorted/examples/fbo/FBORenderer.java | ||
|---|---|---|
| 72 | 72 |
{
|
| 73 | 73 |
mLisa.abortEffects(EffectTypes.MATRIX); |
| 74 | 74 |
|
| 75 |
if( lisaHeight/lisaWidth > height/width )
|
|
| 75 |
if( (float)lisaHeight/lisaWidth > (float)height/width )
|
|
| 76 | 76 |
{
|
| 77 | 77 |
int w = (height*lisaWidth)/lisaHeight; |
| 78 | 78 |
float factor = (float)height/lisaHeight; |
| src/main/java/org/distorted/examples/girl/GirlRenderer.java | ||
|---|---|---|
| 161 | 161 |
{
|
| 162 | 162 |
mGirl.abortEffects(EffectTypes.MATRIX); |
| 163 | 163 |
|
| 164 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 164 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 165 | 165 |
{
|
| 166 | 166 |
int w = (height*bmpWidth)/bmpHeight; |
| 167 | 167 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/listener/ListenerRenderer.java | ||
|---|---|---|
| 106 | 106 |
{
|
| 107 | 107 |
water.abortEffects(EffectTypes.MATRIX); |
| 108 | 108 |
|
| 109 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 109 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 110 | 110 |
{
|
| 111 | 111 |
int w = (height*bmpWidth)/bmpHeight; |
| 112 | 112 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/monalisa/MonaLisaRenderer.java | ||
|---|---|---|
| 84 | 84 |
{
|
| 85 | 85 |
monaLisa.abortEffects(EffectTypes.MATRIX); |
| 86 | 86 |
|
| 87 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 87 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 88 | 88 |
{
|
| 89 | 89 |
int w = (height*bmpWidth)/bmpHeight; |
| 90 | 90 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/olimpic/OlimpicRenderer.java | ||
|---|---|---|
| 122 | 122 |
|
| 123 | 123 |
bmp.abortEffects(EffectTypes.MATRIX); |
| 124 | 124 |
|
| 125 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 125 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 126 | 126 |
{
|
| 127 | 127 |
int w = (height*bmpWidth)/bmpHeight; |
| 128 | 128 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/plainmonalisa/RenderThread.java | ||
|---|---|---|
| 214 | 214 |
|
| 215 | 215 |
monaLisa.abortEffects(EffectTypes.MATRIX); |
| 216 | 216 |
|
| 217 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 217 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 218 | 218 |
{
|
| 219 | 219 |
int w = (height*bmpWidth)/bmpHeight; |
| 220 | 220 |
float factor = (float)height/bmpHeight; |
| src/main/java/org/distorted/examples/save/SaveActivity.java | ||
|---|---|---|
| 65 | 65 |
|
| 66 | 66 |
setContentView(R.layout.savelayout); |
| 67 | 67 |
|
| 68 |
SeekBar barSize = (SeekBar)findViewById(R.id.saveSeekBar); |
|
| 68 |
SeekBar barSize = (SeekBar)findViewById(R.id.saveSeekBarSize);
|
|
| 69 | 69 |
barSize.setOnSeekBarChangeListener(this); |
| 70 | 70 |
barSize.setProgress(50); |
| 71 |
|
|
| 72 |
SeekBar barScale = (SeekBar)findViewById(R.id.saveSeekBarScale); |
|
| 73 |
barScale.setOnSeekBarChangeListener(this); |
|
| 74 |
barScale.setProgress(100); |
|
| 71 | 75 |
} |
| 72 | 76 |
|
| 73 | 77 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| ... | ... | |
| 117 | 121 |
|
| 118 | 122 |
public void onProgressChanged(SeekBar bar, int progress, boolean fromUser) |
| 119 | 123 |
{
|
| 120 |
float s = (progress>50 ? ((progress-50)/16.0f + 1.0f):(0.015f*progress + 0.25f)); |
|
| 121 | 124 |
SaveSurfaceView view = (SaveSurfaceView) this.findViewById(R.id.saveSurfaceView); |
| 122 |
view.getRenderer().setSize(s); |
|
| 125 |
|
|
| 126 |
switch (bar.getId()) |
|
| 127 |
{
|
|
| 128 |
case R.id.saveSeekBarSize : view.getRenderer().setSize(progress>50 ? ((progress-50)/16.0f + 1.0f):(0.015f*progress + 0.25f)); |
|
| 129 |
break; |
|
| 130 |
case R.id.saveSeekBarScale: view.getRenderer().setScale(0.009f*progress+0.1f); |
|
| 131 |
break; |
|
| 132 |
} |
|
| 123 | 133 |
} |
| 124 | 134 |
|
| 125 | 135 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| src/main/java/org/distorted/examples/save/SaveRenderer.java | ||
|---|---|---|
| 35 | 35 |
import org.distorted.library.DistortedFramebuffer; |
| 36 | 36 |
import org.distorted.library.EffectTypes; |
| 37 | 37 |
import org.distorted.library.type.Dynamic1D; |
| 38 |
import org.distorted.library.type.Dynamic3D; |
|
| 38 | 39 |
import org.distorted.library.type.Static1D; |
| 39 | 40 |
import org.distorted.library.type.Static3D; |
| 40 | 41 |
import org.distorted.library.type.Static4D; |
| ... | ... | |
| 56 | 57 |
private Static4D sinkRegion; |
| 57 | 58 |
private Dynamic1D diSink; |
| 58 | 59 |
private Static1D s0; |
| 60 |
private Dynamic3D mScaleDyn; |
|
| 61 |
private Static3D mScaleFactor; |
|
| 59 | 62 |
|
| 60 |
private int fboHeight, fboWidth;
|
|
| 63 |
private float mScale;
|
|
| 61 | 64 |
private int bmpHeight, bmpWidth; |
| 62 | 65 |
private int scrHeight, scrWidth; |
| 63 | 66 |
private float boobsSink; |
| ... | ... | |
| 79 | 82 |
|
| 80 | 83 |
s0 = new Static1D(boobsSink); |
| 81 | 84 |
|
| 82 |
diSink = new Dynamic1D(0,0.5f);
|
|
| 85 |
diSink = new Dynamic1D(); |
|
| 83 | 86 |
diSink.add(s0); |
| 84 | 87 |
|
| 85 |
fboHeight = 150; |
|
| 86 |
fboWidth = 100; |
|
| 88 |
mScale = 1.0f; |
|
| 89 |
mScaleDyn = new Dynamic3D(); |
|
| 90 |
mScaleFactor = new Static3D(mScale,mScale,1.0f); |
|
| 91 |
mScaleDyn.add(mScaleFactor); |
|
| 87 | 92 |
} |
| 88 | 93 |
|
| 89 | 94 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| ... | ... | |
| 94 | 99 |
s0.set(boobsSink); |
| 95 | 100 |
} |
| 96 | 101 |
|
| 102 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
|
| 103 |
|
|
| 104 |
void setScale(float s) |
|
| 105 |
{
|
|
| 106 |
mScale = s; |
|
| 107 |
mScaleFactor.set(s,s,1.0f); |
|
| 108 |
|
|
| 109 |
// when we move our scroll bar, this does NOT keep allocating and deallocating |
|
| 110 |
// the whole WxH texture - the allocation happens only once, on next render, i.e. - |
|
| 111 |
// when one presses the 'SAVE' button. |
|
| 112 |
|
|
| 113 |
if( mOffscreen!=null ) |
|
| 114 |
mOffscreen.resize( (int)(mScale*bmpWidth),(int)(mScale*bmpHeight)); |
|
| 115 |
} |
|
| 116 |
|
|
| 97 | 117 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| 98 | 118 |
|
| 99 | 119 |
void Save() |
| ... | ... | |
| 125 | 145 |
|
| 126 | 146 |
if( isSaving ) // render to an offscreen buffer and read pixels |
| 127 | 147 |
{
|
| 128 |
long scaleID = mGirl.scale(new Static3D( (float)fboWidth/scrWidth, (float)fboHeight/scrHeight, 1.0f)); |
|
| 148 |
mGirl.abortEffects(EffectTypes.MATRIX); |
|
| 149 |
mGirl.scale(mScaleFactor); |
|
| 129 | 150 |
mGirl.draw(System.currentTimeMillis(), mOffscreen); |
| 130 |
mGirl.abortEffect(scaleID);
|
|
| 151 |
applyMatrixEffects(scrWidth,scrHeight);
|
|
| 131 | 152 |
|
| 132 |
ByteBuffer buf = ByteBuffer.allocateDirect( fboWidth*fboHeight*4 ); |
|
| 153 |
int fW =(int)(mScale*bmpWidth); |
|
| 154 |
int fH =(int)(mScale*bmpHeight); |
|
| 155 |
ByteBuffer buf = ByteBuffer.allocateDirect(fW*fH*4); |
|
| 133 | 156 |
buf.order(ByteOrder.LITTLE_ENDIAN); |
| 134 | 157 |
mOffscreen.setAsInput(); |
| 135 | 158 |
|
| 136 |
GLES20.glReadPixels( 0, 0, fboWidth, fboHeight , GLES20.GL_RGBA, GLES20.GL_UNSIGNED_BYTE, buf);
|
|
| 137 |
SaveWorkerThread.newBuffer(buf,fboWidth,fboHeight,mPath);
|
|
| 159 |
GLES20.glReadPixels( 0, 0, fW, fH, GLES20.GL_RGBA, GLES20.GL_UNSIGNED_BYTE, buf);
|
|
| 160 |
SaveWorkerThread.newBuffer(buf,fW,fH,mPath);
|
|
| 138 | 161 |
|
| 139 | 162 |
isSaving = false; |
| 140 | 163 |
} |
| 141 |
else |
|
| 142 |
{
|
|
| 143 |
mGirl.draw(System.currentTimeMillis()); |
|
| 144 |
} |
|
| 164 |
|
|
| 165 |
mGirl.draw(System.currentTimeMillis()); |
|
| 145 | 166 |
} |
| 146 | 167 |
|
| 168 |
|
|
| 147 | 169 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
| 148 |
|
|
| 149 |
public void onSurfaceChanged(GL10 glUnused, int width, int height) |
|
| 150 |
{
|
|
| 151 |
scrWidth = width; |
|
| 152 |
scrHeight= height; |
|
| 153 | 170 |
|
| 171 |
private void applyMatrixEffects(int width, int height) |
|
| 172 |
{
|
|
| 154 | 173 |
mGirl.abortEffects(EffectTypes.MATRIX); |
| 155 |
|
|
| 156 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 174 |
|
|
| 175 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 157 | 176 |
{
|
| 158 | 177 |
int w = (height*bmpWidth)/bmpHeight; |
| 159 | 178 |
float factor = (float)height/bmpHeight; |
| ... | ... | |
| 169 | 188 |
mGirl.move( new Static3D(0,(height-h)/2,0) ); |
| 170 | 189 |
mGirl.scale(factor); |
| 171 | 190 |
} |
| 172 |
|
|
| 191 |
|
|
| 192 |
mGirl.scale(mScaleDyn); |
|
| 193 |
} |
|
| 194 |
|
|
| 195 |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
|
| 196 |
|
|
| 197 |
public void onSurfaceChanged(GL10 glUnused, int width, int height) |
|
| 198 |
{
|
|
| 199 |
scrWidth = width; |
|
| 200 |
scrHeight= height; |
|
| 201 |
applyMatrixEffects(width, height); |
|
| 173 | 202 |
Distorted.onSurfaceChanged(width, height); |
| 174 | 203 |
} |
| 175 | 204 |
|
| ... | ... | |
| 203 | 232 |
mGirl.sink( diSink, pLeft , sinkRegion); |
| 204 | 233 |
mGirl.sink( diSink, pRight, sinkRegion); |
| 205 | 234 |
|
| 206 |
mOffscreen = new DistortedFramebuffer(fboWidth,fboHeight);
|
|
| 235 |
mOffscreen = new DistortedFramebuffer(bmpWidth,bmpHeight);
|
|
| 207 | 236 |
|
| 208 | 237 |
try |
| 209 | 238 |
{
|
| src/main/java/org/distorted/examples/sink/SinkRenderer.java | ||
|---|---|---|
| 76 | 76 |
{
|
| 77 | 77 |
sinkBmp.abortEffects(EffectTypes.MATRIX); |
| 78 | 78 |
|
| 79 |
if( bmpHeight/bmpWidth > height/width )
|
|
| 79 |
if( (float)bmpHeight/bmpWidth > (float)height/width )
|
|
| 80 | 80 |
{
|
| 81 | 81 |
int w = (height*bmpWidth)/bmpHeight; |
| 82 | 82 |
float factor = (float)height/bmpHeight; |
| src/main/res/layout/savelayout.xml | ||
|---|---|---|
| 8 | 8 |
android:id="@+id/saveSurfaceView" |
| 9 | 9 |
android:layout_width="fill_parent" |
| 10 | 10 |
android:layout_height="0dp" |
| 11 |
android:layout_weight="0.85" />
|
|
| 11 |
android:layout_weight="0.9"/>
|
|
| 12 | 12 |
|
| 13 | 13 |
<LinearLayout |
| 14 | 14 |
android:orientation="horizontal" |
| 15 | 15 |
android:layout_width="match_parent" |
| 16 | 16 |
android:layout_height="wrap_content" |
| 17 |
android:gravity="bottom" |
|
| 18 |
android:layout_weight="0.03"> |
|
| 17 |
android:gravity="bottom"> |
|
| 19 | 18 |
|
| 20 | 19 |
<Button |
| 21 | 20 |
android:id="@+id/saveButton" |
| 22 |
android:layout_width="132dp"
|
|
| 23 |
android:layout_height="wrap_content"
|
|
| 21 |
android:layout_width="100dp"
|
|
| 22 |
android:layout_height="fill_parent"
|
|
| 24 | 23 |
android:gravity="center_vertical|center" |
| 25 | 24 |
android:text="@string/save" |
| 26 | 25 |
android:onClick="Save" |
| 27 | 26 |
android:textAppearance="?android:attr/textAppearanceMedium" |
| 28 | 27 |
android:layout_gravity="center_vertical"/> |
| 29 | 28 |
|
| 30 |
<SeekBar |
|
| 31 |
android:layout_width="fill_parent" |
|
| 32 |
android:layout_height="wrap_content" |
|
| 33 |
android:id="@+id/saveSeekBar" |
|
| 34 |
android:layout_gravity="center_vertical" |
|
| 35 |
android:layout_margin="5dp"/> |
|
| 29 |
<LinearLayout |
|
| 30 |
android:orientation="vertical" |
|
| 31 |
android:layout_width="match_parent" |
|
| 32 |
android:layout_height="match_parent"> |
|
| 33 |
|
|
| 34 |
<SeekBar |
|
| 35 |
android:layout_width="match_parent" |
|
| 36 |
android:layout_height="wrap_content" |
|
| 37 |
android:id="@+id/saveSeekBarSize" |
|
| 38 |
android:layout_gravity="center_vertical" |
|
| 39 |
android:layout_margin="5dp"/> |
|
| 40 |
<SeekBar |
|
| 41 |
android:layout_width="match_parent" |
|
| 42 |
android:layout_height="wrap_content" |
|
| 43 |
android:id="@+id/saveSeekBarScale" |
|
| 44 |
android:layout_gravity="center_vertical" |
|
| 45 |
android:layout_margin="5dp"/> |
|
| 46 |
</LinearLayout> |
|
| 36 | 47 |
|
| 37 | 48 |
</LinearLayout> |
| 38 | 49 |
|
Also available in: Unified diff
1. (hopefully) finish the 'Save' app (now we can adjust the size of the resulting file)
2. Fix one long-standing bug in almost every single app.