如何在不调整原始图像大小的情况下使用GPU Image库,我需要为整个GPUImageView申请像Pixelate或Blur这样的过滤器.

我想用GPUImage,但我不知道怎么做.

解决方法

您更改GPUImage库GPUImageRendering类
下面的代码是
/*
 * copyright (C) 2012 CyberAgent
 *
 * Licensed under the Apache License,Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,software
 * distributed under the License is distributed on an "AS IS" BASIS,* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package jp.co.cyberagent.android.gpuimage;

import android.annotation.SuppressLint;
import android.annotation.TargetApi;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.SurfaceTexture;
import android.hardware.Camera;
import android.hardware.Camera.PreviewCallback;
import android.hardware.Camera.Size;
import android.opengl.GLES20;
import android.opengl.GLSurfaceView.Renderer;
import jp.co.cyberagent.android.gpuimage.util.TextureRotationUtil;

import javax.microedition.khronos.egl.EGLConfig;
import javax.microedition.khronos.opengles.GL10;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.FloatBuffer;
import java.nio.IntBuffer;
import java.util.LinkedList;
import java.util.Queue;

import static jp.co.cyberagent.android.gpuimage.util.TextureRotationUtil.TEXTURE_NO_ROTATION;

@SuppressLint("WrongCall")
@TargetApi(11)
public class GPUImageRenderer implements Renderer,PreviewCallback {
    public static final int NO_IMAGE = -1;
    static final float CUBE[] = {
            -1.0f,-1.0f,1.0f,};

    private GPUImageFilter mFilter;

    public final Object mSurfaceChangedWaiter = new Object();

    private int mGLTextureId = NO_IMAGE;
    private SurfaceTexture mSurfaceTexture = null;
    private final FloatBuffer mGLCubeBuffer;
    private final FloatBuffer mGLTextureBuffer;
    private IntBuffer mglrgbBuffer;
    int mwidth,mheight,wheight;
    private int mOutputWidth;
    private int mOutputHeight;
    private int mImageWidth;
    private int mImageHeight;
    private int mAddedPadding;

    private final Queue<Runnable> mRunOnDraw;
    private final Queue<Runnable> mRunOnDrawEnd;
    private Rotation mRotation;
    private boolean mFlipHorizontal;
    private boolean mFlipVertical;
    private GPUImage.ScaleType mScaleType = GPUImage.ScaleType.CENTER_CROP;

    public GPUImageRenderer(final GPUImageFilter filter) {
        mFilter = filter;
        mRunOnDraw = new LinkedList<Runnable>();
        mRunOnDrawEnd = new LinkedList<Runnable>();

        mGLCubeBuffer = ByteBuffer.allocateDirect(CUBE.length * 4)
                .order(ByteOrder.nativeOrder())
                .asFloatBuffer();
        mGLCubeBuffer.put(CUBE).position(0);

        mGLTextureBuffer = ByteBuffer.allocateDirect(TEXTURE_NO_ROTATION.length * 4)
                .order(ByteOrder.nativeOrder())
                .asFloatBuffer();
        setRotation(Rotation.norMAL,false,false);
    }

    @Override
    public void onSurfaceCreated(final GL10 unused,final EGLConfig config) {
        GLES20.glClearColor(0,1);
        GLES20.gldisable(GLES20.GL_DEPTH_TEST);
        mFilter.init();
    }

    public void onSurfacSize(final int width,final int height) {
        mwidth=width;
        mheight=height;
    }

    @Override
    public void onSurfaceChanged(final GL10 gl,final int width,final int height) {

        if(height>mheight)
        {
            mOutputWidth = mwidth;
            mOutputHeight = mheight;
            GLES20.glViewport(0,mwidth,mheight);
            //  GLES20.glViewport(0+(mwidth/2),0+(mheight/2),mheight);
            mFilter.onOutputSizeChanged(mwidth,mheight);
        }
        else
        {
            mOutputWidth = width;
            mOutputHeight = height;
            GLES20.glViewport(0,width,height);
            mFilter.onOutputSizeChanged(width,height);
        }
        // GLES20.glViewport(20,-20,height);
        GLES20.gluseProgram(mFilter.getProgram());
        adjustimageScaling();
        synchronized (mSurfaceChangedWaiter) {
            mSurfaceChangedWaiter.notifyAll();
        }
    }

    @Override
    public void onDrawFrame(final GL10 gl) {
        GLES20.glClear(GLES20.GL_COLOR_BUFFER_BIT | GLES20.GL_DEPTH_BUFFER_BIT);
        runAll(mRunOnDraw);
        mFilter.onDraw(mGLTextureId,mGLCubeBuffer,mGLTextureBuffer);
        runAll(mRunOnDrawEnd);
        if (mSurfaceTexture != null) {
            mSurfaceTexture.updateTexImage();
        }
    }

    private void runAll(Queue<Runnable> queue) {
        synchronized (queue) {
            while (!queue.isEmpty()) {
                queue.poll().run();
            }
        }
    }

    @Override
    public void onPreviewFrame(final byte[] data,final Camera camera) {
        final Size previewSize = camera.getParameters().getPreviewSize();
        if (mglrgbBuffer == null) {
            mglrgbBuffer = IntBuffer.allocate(previewSize.width * previewSize.height);
        }
        if (mRunOnDraw.isEmpty()) {
            runOnDraw(new Runnable() {
                @Override
                public void run() {
                    GPUImageNativeLibrary.YUVtoRBGA(data,previewSize.width,previewSize.height,mglrgbBuffer.array());
                    mGLTextureId = Openglutils.loadTexture(mglrgbBuffer,previewSize,mGLTextureId);
                    camera.addCallbackBuffer(data);

                    if (mImageWidth != previewSize.width) {
                        mImageWidth = previewSize.width;
                        mImageHeight = previewSize.height;
                        adjustimageScaling();
                    }
                }
            });
        }
    }

    public void setUpSurfaceTexture(final Camera camera) {
        runOnDraw(new Runnable() {
            @Override
            public void run() {
                int[] textures = new int[1];
                GLES20.glGenTextures(1,textures,0);
                mSurfaceTexture = new SurfaceTexture(textures[0]);
                try {
                    camera.setPreviewTexture(mSurfaceTexture);
                    camera.setPreviewCallback(GPUImageRenderer.this);
                    camera.startPreview();
                } catch (IOException e) {
                    e.printstacktrace();
                }
            }
        });
    }

    public void setFilter(final GPUImageFilter filter) {
        runOnDraw(new Runnable() {

            @Override
            public void run() {
                final GPUImageFilter oldFilter = mFilter;
                mFilter = filter;
                if (oldFilter != null) {
                    oldFilter.destroy();
                }
                mFilter.init();
                GLES20.gluseProgram(mFilter.getProgram());
                mFilter.onOutputSizeChanged(mOutputWidth,mOutputHeight);
            }
        });
    }
    public void setFilter3(final GPUImageFilter filter) {
        runOnDraw(new Runnable() {

            @Override
            public void run() {
                final GPUImageFilter oldFilter = mFilter;
                mFilter = filter;
//                if (oldFilter != null) {
//                    oldFilter.destroy();
//                }
                mFilter.init();
                GLES20.gluseProgram(mFilter.getProgram());
                mFilter.onOutputSizeChanged(mOutputWidth,mOutputHeight);
            }
        });
    }

    public void deleteImage() {
        runOnDraw(new Runnable() {

            @Override
            public void run() {
                GLES20.glDeleteTextures(1,new int[]{
                        mGLTextureId
                },0);
                mGLTextureId = NO_IMAGE;
            }
        });
    }

    public void setimageBitmap(final Bitmap bitmap) {
        setimageBitmap(bitmap,true);
    }

    public void setimageBitmap(final Bitmap bitmap,final boolean recycle) {
        if (bitmap == null) {
            return;
        }

        runOnDraw(new Runnable() {

            @Override
            public void run() {
                Bitmap resizedBitmap = null;
                if (bitmap.getWidth() % 2 == 1) {
                    resizedBitmap = Bitmap.createBitmap(bitmap.getWidth() + 1,bitmap.getHeight(),Bitmap.Config.ARGB_8888);
                    Canvas can = new Canvas(resizedBitmap);
                    can.drawARGB(0x00,0x00,0x00);
                    can.drawBitmap(bitmap,null);
                    mAddedPadding = 1;
                } else {
                    mAddedPadding = 0;
                }

                mGLTextureId = Openglutils.loadTexture(
                        resizedBitmap != null ? resizedBitmap : bitmap,mGLTextureId,recycle);
                if (resizedBitmap != null) {
                    resizedBitmap.recycle();
                }
                mImageWidth = bitmap.getWidth();
                mImageHeight = bitmap.getHeight();
                adjustimageScaling();
            }
        });
    }

    public void setScaleType(GPUImage.ScaleType scaleType) {
        mScaleType = scaleType;
    }

    protected int getFrameWidth() {
        return mOutputWidth;
    }

    protected int getFrameHeight() {
        return mOutputHeight;
    }

    private void adjustimageScaling() {
        float outputWidth = mOutputWidth;
        float outputHeight = mOutputHeight;
        if (mRotation == Rotation.ROTATION_270 || mRotation == Rotation.ROTATION_90) {
            outputWidth = mOutputHeight;
            outputHeight = mOutputWidth;
        }

        float ratio1 = outputWidth / mImageWidth;
        float ratio2 =outputHeight / mImageHeight;
        float ratioMax = Math.max(ratio1,ratio2);
        int imageWidthNew = (Math.round(mImageWidth * ratioMax));
        int imageHeightNew = (Math.round(mImageHeight * ratioMax));

        float ratioWidth = imageWidthNew / (outputWidth);
        float ratioHeight = imageHeightNew / (outputHeight);

        float[] cube = CUBE;
        float[] textureCords = TextureRotationUtil.getRotation(mRotation,mFlipHorizontal,mFlipVertical);
        if (mScaleType == GPUImage.ScaleType.CENTER_CROP) {
            float distHorizontal = (1 - 1 / ratioWidth) / 2;
            float distVertical = (1 - 1 / ratioHeight) / 2;
            textureCords = new float[]{
                    adddistance(textureCords[0],distHorizontal),adddistance(textureCords[1],distVertical),adddistance(textureCords[2],adddistance(textureCords[3],adddistance(textureCords[4],adddistance(textureCords[5],adddistance(textureCords[6],adddistance(textureCords[7],};
        } else {
            cube = new float[]{
                    CUBE[0] * ratioWidth,CUBE[1] * ratioHeight,CUBE[2] * ratioWidth,CUBE[3] * ratioHeight,CUBE[4] * ratioWidth,CUBE[5] * ratioHeight,CUBE[6] * ratioWidth,CUBE[7] * ratioHeight,};
        }

        mGLCubeBuffer.clear();
        mGLCubeBuffer.put(cube).position(0);
        mGLTextureBuffer.clear();
        mGLTextureBuffer.put(textureCords).position(0);
    }


    private float adddistance(float coordinate,float distance) {
        return coordinate == 0.0f ? distance : 1 - distance;
    }

    public void setRotationCamera(final Rotation rotation,final boolean flipHorizontal,final boolean flipVertical) {
        setRotation(rotation,flipVertical,flipHorizontal);
    }

    public void setRotation(final Rotation rotation,final boolean flipVertical) {
        mRotation = rotation;
        mFlipHorizontal = flipHorizontal;
        mFlipVertical = flipVertical;
        adjustimageScaling();
    }

    public Rotation getRotation() {
        return mRotation;
    }

    public boolean isFlippedHorizontally() {
        return mFlipHorizontal;
    }

    public boolean isFlippedVertically() {
        return mFlipVertical;
    }

    protected void runOnDraw(final Runnable runnable) {
        synchronized (mRunOnDraw) {
            mRunOnDraw.add(runnable);
        }
    }

    protected void runOnDrawEnd(final Runnable runnable) {
        synchronized (mRunOnDrawEnd) {
            mRunOnDrawEnd.add(runnable);
        }
    }
}

如何在android中使用没有缩放的GPUImage的更多相关文章

  1. ios – 如何使用GPUImage实现GPUImageMaskFilter

    我需要使用掩码从完整图像剪切并创建被屏蔽的图像.=我试过以下:但是,我生成的输出图像是:请大家携手共进干杯.另外,谢谢BradLarson.解决方法掩码是第二个目标,如在滤镜着色器代码中可以看到的.然后,您需要在黑色背景上“反转”您的面具:白色心脏,因为过滤器使用RGB像素值的“重量”来设置目标图像上的alpha值.所以你的代码应该是和你的面具像预期结果.

  2. ios – GPUImage为每个RGB通道添加色调/颜色调整(调整红色以更加粉红色或橙色)

    试图调整特定频道的色调.看着色调过滤器,我想也许我可以通过评论绿色和蓝色修饰符,影响到只有红色通道的变化:但是,这张照片就是灰色/蓝色,被冲洗掉或是紫色的绿色.我在正确的轨道上吗?

  3. ios – 使用GPUImage和GPUImageHoughTransformLineDetector检测突出显示的文本边界框

    我正在使用GPUImageHoughTransformlineDetector来尝试检测图像中突出显示的文本:我使用以下代码来尝试检测边界蓝框线:无论edgeThreshold还是1023行,每次运行此命令时,结果输出如下所示:我不清楚为什么改变门槛没有做任何事情,但我确信我误解了一些事情.任何人对如何做到这一点有任何想法?解决方法我刚刚在框架中对Hough变换线检测器进行了一些改进,这将对此有所

  4. ios – 使用OpenGL的神秘app崩溃

    我正在使用GPUIImage库来开发iOS相机应用程序.有时,当应用程序在2-3分钟后暂停时,Xcode会在应用程序上发生崩溃,指向方法中的行:可能是这次崩溃的原因是什么?我有一个非常长的摄像头设置,代码本身在GPUImageContext类中.我在这里做错了什么?

  5. swift – 使用Cocoapods与应用程序扩展

    我试图在Xcode6Beta-6中使用cocoapods库构建照片应用程序扩展。Xcode为照片扩展创建的桥接头无法从Cocopapod查看任何内容。唯一的例外是,对于像SVProgressHUD这样的简单pod,以下丑陋的可怕的黑客工程:#import“../Pods/SVProgressHUD/SVProgressHUD/SVProgressHUD.h”。此外,thisSOquestion中描述的问题可能有关,但我反问这个问题,以防我的问题是特定于应用程式额外资讯。正确的方法是更新您的podfile只

  6. 如何在android中使用没有缩放的GPUImage

    如何在不调整原始图像大小的情况下使用GPUImage库,我需要为整个GPUImageView申请像Pixelate或Blur这样的过滤器.我想用GPUImage,但我不知道怎么做.解决方法您更改GPUImage库GPUImageRendering类下面的代码是

  7. 使用GPUImage Android进行视频处理

    我想使用GPUImageAndroid实时处理视频.我看到使用不同的过滤器创建图片的示例,但我没有找到任何使用过滤器录制视频的示例.这是可能的GPUImageAndroid?

  8. ios – “GPUImage.h”未找到

    我正在尝试在一个项目中设置GPUImage,但是我无法追踪为什么我收到错误:“GPUImage.h”未找到.我添加了框架,设置了目标依赖关系,将HeaderSearch路径添加为:framework,并添加了其他链接器标志-ObjC.还没有运气如果有人想看看,我包括了我的超简单测试项目hereandlinkedbelow.我知道这必须是文件和基本的,但是我在GitHub上进行了搜索,但没有找到对这

  9. 使用GPUImage重新创建iOS 7玻璃效果

    我试图在我的玻璃杯中使用iOS7风格的玻璃效果,将图像效果应用于MKMapView的屏幕截图.ThisUIImagecategory,由苹果提供,是我用作基准.该方法使源图像饱和,应用色彩,并使用输入值大量模糊:这产生了我正在寻找的效果,但需要太长时间–在iPhone4之间渲染时间为.3和.5秒.我想使用优秀的GPUImage,因为我的初步尝试速度已经快了约5-10倍,但是我似乎无法理解.这产生一

  10. ios – GPUImage过滤视频

    这是以前的后续跟踪,但是仅仅是相关的question我正在使用GPUImage库来应用过滤器到我的相机应用程序中的静态照片和视频.几乎一切都很好.我还没有解决的其余一个问题如下:>我捕获一个GPUImageMovie>我把它写入文件系统>我从文件系统读取它并应用一个新的过滤器>我将其写入文件系统中的其他URL保存到该新URL的是具有正确持续时间但没有移动的视频.当我打的时候,它只是静止的图像,我认

随机推荐

  1. bluetooth-lowenergy – Altbeacon库无法在Android 5.0上运行

    昨天我在Nexus4上获得了Android5.0的更新,并且altbeacon库停止了检测信标.似乎在监视和测距时,didEnterRegion和didRangeBeaconsInRegion都没有被调用.即使RadiusNetworks的Locate应用程序现在表现不同,一旦检测到信标的值,它们就不再得到更新,并且通常看起来好像信标超出了范围.我注意到的一点是,现在在logcat中出现以下行“B

  2. android – react-native动态更改响应者

    我正在使用react-native进行Android开发.我有一个视图,如果用户长按,我想显示一个可以拖动的动画视图.我可以使用PanResponder实现这一点,它工作正常.但我想要做的是当用户长按时,用户应该能够继续相同的触摸/按下并拖动新显示的Animated.View.如果您熟悉Google云端硬盘应用,则它具有类似的功能.当用户长按列表中的任何项目时,它会显示可拖动的项目.用户可以直接拖

  3. android – 是否有可能通过使用与最初使用的证书不同的证书对其进行签名来发布更新的应用程序

    是否可以通过使用与最初使用的证书不同的证书进行签名来发布Android应用程序的更新?我知道当我们尝试将这样的构建上传到市场时,它通常会给出错误消息.但有没有任何出路,比如将其标记为主要版本,指定市场中的某个地方?解决方法不,你不能这样做.证书是一种工具,可确保您是首次上传应用程序的人.所以总是备份密钥库!

  4. 如何检测Android中是否存在麦克风?

    ..所以我想在让用户访问语音输入功能之前检测麦克风是否存在.如何检测设备上是否有麦克风.谢谢.解决方法AndroidAPI参考:hasSystemFeature

  5. Android – 调用GONE然后VISIBLE使视图显示在错误的位置

    我有两个视图,A和B,视图A在视图B上方.当我以编程方式将视图A设置为GONE时,它将消失,并且它正下方的视图将转到视图A的位置.但是,当我再次将相同的视图设置为VISIBLE时,它会在视图B上显示.我不希望这样.我希望视图B回到原来的位置,这是我认为会发生的事情.我怎样才能做到这一点?编辑–代码}这里是XML:解决方法您可以尝试将两个视图放在RelativeLayout中并相对于彼此设置它们的位置.

  6. android – 获得一首歌的流派

    我如何阅读与歌曲相关的流派?我可以读这首歌,但是如何抓住这首歌的流派,它存放在哪里?解决方法检查此代码:

  7. android – 使用textShadow折叠工具栏

    我有一个折叠工具栏的问题,在展开状态我想在文本下面有一个模糊的阴影,我使用这段代码:用:我可以更改textColor,它可以工作,但阴影不起作用.我为阴影尝试了很多不同的值.是否可以为折叠文本投射阴影?

  8. android – 重用arm共享库

    我已经建立了armarm共享库.我有兴趣重用一个函数.我想调用该函数并获得返回值.有可能做这样的事吗?我没有任何头文件.我试过这个Android.mk,我把libtest.so放在/jni和/libs/armeabi,/lib/armeabi中.此时我的cpp文件编译,但现在是什么?我从objdump知道它的名字编辑:我试图用这个android.mk从hello-jni示例中添加prebuild库:它工作,但libtest.so相同的代码显示以下错误(启动时)libtest.so存在于libhello-j

  9. android – 为NumberPicker捕获键盘’Done’

    我有一个AlertDialog只有一些文本,一个NumberPicker,一个OK和一个取消.(我知道,这个对话框还没有做它应该保留暂停和恢复状态的事情.)我想在软键盘或其他IME上执行“完成”操作来关闭对话框,就像按下了“OK”一样,因为只有一个小部件可以编辑.看起来处理IME“Done”的最佳方法通常是在TextView上使用setonEditorActionListener.但我没有任何Te

  10. android – 想要在调用WebChromeClient#onCreateWindow时知道目标URL

    当我点击一个带有target=“_blank”属性的超链接时,会调用WebChromeClient#onCreateWindow,但我找不到新的窗口将打开的新方法?主页url是我唯一能知道的东西?我想根据目标网址更改应用行为.任何帮助表示赞赏,谢谢!

返回
顶部