core image几个滤镜样例 oc版本号和swift版本号

oc版本号

//万花筒模式
+ (CGImageRef) getKaleidoscope:(CIContext *)context
{
    CIImage * image =
    [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];

    CIFilter * kaleidoscope = [CIFilter filterWithName:@"CIKaleidoscope"];
    [kaleidoscope setDefaults];
    [kaleidoscope setValue:image forKey:kCIInputImageKey];
    [kaleidoscope setValue:[CIVector vectorWithX:5 Y:0] forKey:kCIInputCenterKey];
    CIImage * result = [kaleidoscope valueForKey:kCIOutputImageKey];

    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];

    return cgImage;
}

//凹凸变形
+ (CGImageRef) getBumpDistortion:(CIContext *)context
{
    CIImage * image =
    [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * bumpDistortion = [CIFilter filterWithName:@"CIBumpDistortion"];
    [bumpDistortion setDefaults];
    [bumpDistortion setValue:image forKey:kCIInputImageKey];
    [bumpDistortion setValue:[CIVector vectorWithX:10 Y:5] forKey:kCIInputCenterKey];
    [bumpDistortion setValue:@55.0f forKey:kCIInputRadiusKey];
    [bumpDistortion setValue:@(3.0f) forKey:kCIInputScaleKey];
    CIImage * result = [bumpDistortion valueForKey:kCIOutputImageKey];

    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//色调调整
+ (CGImageRef) getHueAdjust:(CIContext *)context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * hueAdjust = [CIFilter filterWithName:@"CIHueAdjust"];
    [hueAdjust setValue:image forKey:kCIInputImageKey];
    [hueAdjust setValue:@2.094f forKey:kCIInputAngleKey];
    CIImage * result = [hueAdjust valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//变暗
+ (CGImageRef) getGloom:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * gloom = [CIFilter filterWithName:@"CIGloom"];
    [gloom setDefaults];
    [gloom setValue:image forKey:kCIInputImageKey];
    [gloom setValue:@5.0f forKey:kCIInputRadiusKey];
    [gloom setValue:@1.0f forKey:kCIInputIntensityKey];
    CIImage * result = [gloom valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//深褐色调
+ (CGImageRef) getSepiaTone:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * sepiaTone = [CIFilter filterWithName:@"CISepiaTone"];
    [sepiaTone setDefaults];
    [sepiaTone setValue:image forKey:kCIInputImageKey];
    [sepiaTone setValue:@0.8f forKey:kCIInputIntensityKey];
    CIImage * result = [sepiaTone valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//合成
+ (CGImageRef) getAdditionCompositing:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];

    CIImage * image1 = [CIImage imageWithCGImage:[UIImage imageNamed:@"ren"].CGImage];

    CIFilter * accordionFoldTransition = [CIFilter filterWithName:@"CIAdditionCompositing"];
    [accordionFoldTransition setDefaults];
    [accordionFoldTransition setValue:image forKey:kCIInputImageKey];
    [accordionFoldTransition setValue:image1 forKey:kCIInputBackgroundImageKey];
    CIImage * result = [accordionFoldTransition valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}
//高斯模糊
+ (CGImageRef) getGaussianBlur:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * gaussianBlur = [CIFilter filterWithName:@"CIGaussianBlur"];
    [gaussianBlur setDefaults];
    [gaussianBlur setValue:image forKey:kCIInputImageKey];
    [gaussianBlur setValue:@5.0f forKey:kCIInputRadiusKey];

    CIImage * result = [gaussianBlur valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//变焦模糊
+ (CGImageRef) getZoomBlur:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * zoomBlur = [CIFilter filterWithName:@"CIZoomBlur"];
    [zoomBlur setDefaults];
    [zoomBlur setValue:image forKey:kCIInputImageKey];
    [zoomBlur setValue:@10.0f forKey:@"inputAmount"];
    [zoomBlur setValue:[CIVector vectorWithCGPoint:CGPointMake(10, 10)] forKey:kCIInputCenterKey];

    CIImage * result = [zoomBlur valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//白点调整
+ (CGImageRef) getWhitePointAdjust:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * zoomBlur = [CIFilter filterWithName:@"CIWhitePointAdjust"];
    [zoomBlur setDefaults];
    [zoomBlur setValue:image forKey:kCIInputImageKey];
    [zoomBlur setValue:[CIColor colorWithRed:1.0 green:0.5 blue:1.0 alpha:1.0] forKey:@"inputColor"];

    CIImage * result = [zoomBlur valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//标签效应
+ (CGImageRef) getVignetteEffect:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * zoomBlur = [CIFilter filterWithName:@"CIVignetteEffect"];
    [zoomBlur setDefaults];
    [zoomBlur setValue:image forKey:kCIInputImageKey];
    [zoomBlur setValue:[CIVector vectorWithCGPoint:CGPointMake(10, 10)] forKey:kCIInputCenterKey];
    [zoomBlur setValue:@0.5f forKey:@"inputFalloff"];
    [zoomBlur setValue:@1.0f forKey:@"inputIntensity"];
    [zoomBlur setValue:@100.0f forKey:@"inputRadius"];

    CIImage * result = [zoomBlur valueForKey:kCIOutputImageKey];
    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

//多个效果合成
+ (CGImageRef) getMix:(CIContext *) context
{
    CIImage * image = [CIImage imageWithCGImage:[UIImage imageNamed:@"Icon"].CGImage];
    CIFilter * zoomBlur = [CIFilter filterWithName:@"CIVignetteEffect"];
    [zoomBlur setDefaults];
    [zoomBlur setValue:image forKey:kCIInputImageKey];
    [zoomBlur setValue:[CIVector vectorWithCGPoint:CGPointMake(10, 10)] forKey:kCIInputCenterKey];
    [zoomBlur setValue:@0.5f forKey:@"inputFalloff"];
    [zoomBlur setValue:@1.0f forKey:@"inputIntensity"];
    [zoomBlur setValue:@100.0f forKey:@"inputRadius"];

    CIImage * result = [zoomBlur valueForKey:kCIOutputImageKey];

    CIFilter * gaussianBlur = [CIFilter filterWithName:@"CIGaussianBlur"];
    [gaussianBlur setDefaults];
    [gaussianBlur setValue:result forKey:kCIInputImageKey];
    [gaussianBlur setValue:@5.0f forKey:kCIInputRadiusKey];

    result = [gaussianBlur valueForKey:kCIOutputImageKey];

    CGRect extent = [result extent];
    CGImageRef cgImage = [context createCGImage:result fromRect:extent];
    return cgImage;
}

以上介绍了几个滤镜模式,假设想查询系统内置了多少种滤镜,能够运行下面代码查看:

//查看全部内置滤镜

NSArray *filterNames=[CIFilterfilterNamesInCategory:kCICategoryBuiltIn];
    for (NSString *filterNamein filterNames) {
        CIFilter *filter=[CIFilterfilterWithName:filterName];
        NSLog(@"\rfilter:%@\rattributes:%@",filterName,[filterattributes]);
    }

以下截取控制台输出的部分滤镜消息。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" >

就拿CIZoomBlur滤镜模式来说。打印出来的信息。能够看到,里面定义了一些属性(每种滤镜,所含有的属性会有区别。在使用的时候,特别要注意)。

属性名称能够使用定义好的结构体成员kCIInputImageKey。或者直接@"inputImage"调用,都是表示输入的图片。

inputImage相应的value里面定义了这个属性是什么类型的。属性描写叙述等。

假设须要其它滤镜模式的能够去查看。

swift版本号

//万花筒模式
    static func getKaleidoscope(context: CIContext) -> CGImageRef {

        let imageName = UIImage(named:"Icon")?

.CGImage

        let image = CIImage(CGImage: (imageName)!)

        let kaleidoscope  = CIFilter(name:"CIKaleidoscope");
        kaleidoscope?

.setDefaults();
        kaleidoscope?.setValue(image, forKey: kCIInputImageKey);
        kaleidoscope?.setValue(CIVector(x: 5, y: 0), forKey: kCIInputCenterKey);

        let result  = kaleidoscope?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;

        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //凹凸变形
    static func getBumpDistortion(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?

.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let bumpDistortion = CIFilter(name: "CIBumpDistortion")
        bumpDistortion?.setDefaults()
        bumpDistortion?.setValue(image, forKey: kCIInputImageKey)
        bumpDistortion?

.setValue(CIVector(x: 10, y: 5), forKey: kCIInputCenterKey)
        bumpDistortion?

.setValue(55.0, forKey: kCIInputRadiusKey)
        bumpDistortion?.setValue(3.0, forKey: kCIInputScaleKey)
        let result  = bumpDistortion?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //色调调整
    static func getHueAdjust(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?

.CGImage
        let image = CIImage(CGImage: (imageName)!)
        let hueAdjust = CIFilter(name: "CIHueAdjust")
        hueAdjust?.setValue(image, forKey: kCIInputImageKey)
        hueAdjust?.setValue(2.094, forKey:kCIInputAngleKey)

        let result  = hueAdjust?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //变暗
    static func getGloom(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let gloom = CIFilter(name: "CIGloom")
        gloom?.setDefaults()
        gloom?.setValue(image, forKey: kCIInputImageKey)
        gloom?.setValue(5.0, forKey: kCIInputRadiusKey)
        gloom?.setValue(1.0, forKey: kCIInputIntensityKey)

        let result  = gloom?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //深褐色调
    static func getSepiaTone(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let sepiaTone = CIFilter(name: "CISepiaTone")
        sepiaTone?.setDefaults()
        sepiaTone?.setValue(image, forKey: kCIInputImageKey)
        sepiaTone?.setValue(0.8, forKey: kCIInputIntensityKey)

        let result  = sepiaTone?

.valueForKey(kCIOutputImageKey);

        let extent = result?

.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //合成
    static func getAdditionCompositing(context: CIContext) -> CGImageRef {

        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)
        let image1 = CIImage(CGImage: (UIImage(named:"ren")?.CGImage)!)

        let accordionFoldTransition = CIFilter(name: "CIAdditionCompositing");
        accordionFoldTransition?

.setDefaults()
        accordionFoldTransition?.setValue(image, forKey: kCIInputImageKey)
        accordionFoldTransition?.setValue(image1, forKey: kCIInputBackgroundImageKey)

        let result  = accordionFoldTransition?

.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //高斯模糊
    static func getGaussianBlur(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let gaussianBlur = CIFilter(name: "CIGaussianBlur")
        gaussianBlur?.setDefaults()
        gaussianBlur?

.setValue(image, forKey: kCIInputImageKey)
        gaussianBlur?.setValue(5.0, forKey: kCIInputRadiusKey)

        let result  = gaussianBlur?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //变焦模糊
    static func getZoomBlur(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let zoomBlur = CIFilter(name: "CIZoomBlur")
        zoomBlur?.setDefaults()
        zoomBlur?

.setValue(image, forKey: kCIInputImageKey)
        zoomBlur?.setValue(10.0, forKey: "inputAmount")
        zoomBlur?.setValue(CIVector(x: 10, y: 10), forKey: kCIInputCenterKey)

        let result  = zoomBlur?

.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //白点调整
    static func getWhitePointAdjust(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?

.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let whitePointAdjust = CIFilter(name: "CIWhitePointAdjust")
        whitePointAdjust?.setDefaults()
        whitePointAdjust?.setValue(image, forKey: kCIInputImageKey)
        whitePointAdjust?.setValue(CIColor(red: 1.0, green: 0.5, blue: 1.0, alpha: 1.0), forKey: "inputColor")

        let result  = whitePointAdjust?.valueForKey(kCIOutputImageKey);

        let extent = result?

.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //标签效应
    static func getVignetteEffect(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)
        let vignetteEffect = CIFilter(name: "CIVignetteEffect")
        vignetteEffect?.setDefaults()
        vignetteEffect?.setValue(image, forKey: kCIInputImageKey)
        vignetteEffect?.setValue(CIVector(x: 10, y: 10), forKey: kCIInputCenterKey)
        vignetteEffect?

.setValue(0.5, forKey: "inputFalloff")
        vignetteEffect?

.setValue(1.0, forKey: "inputIntensity")
        vignetteEffect?.setValue(100.0, forKey: "inputRadius")

        let result  = vignetteEffect?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

    //多个效果合成
    static func getMix(context: CIContext) -> CGImageRef {
        let imageName = UIImage(named:"Icon")?.CGImage
        let image = CIImage(CGImage: (imageName)!)

        let vignetteEffect = CIFilter(name: "CIVignetteEffect")
        vignetteEffect?.setDefaults()
        vignetteEffect?.setValue(image, forKey: kCIInputImageKey)
        vignetteEffect?

.setValue(0.5, forKey: "inputFalloff")
        vignetteEffect?.setValue(1.0, forKey: "inputIntensity")
        vignetteEffect?

.setValue(100.0, forKey: "inputRadius")

        var result  = vignetteEffect?.valueForKey(kCIOutputImageKey);

        let gaussianBlur = CIFilter(name: "CIGaussianBlur")
        gaussianBlur?

.setDefaults()
        gaussianBlur?.setValue(result, forKey: kCIInputImageKey)
        gaussianBlur?

.setValue(5.0, forKey: kCIInputRadiusKey)

        result = gaussianBlur?.valueForKey(kCIOutputImageKey);

        let extent = result?.extent;
        let cgImage = context.createCGImage(result as! CIImage, fromRect: extent!)
        return cgImage
    }

以上介绍了几个滤镜模式,假设想查询系统内置了多少种滤镜。能够运行下面代码查看:

//查看全部内置滤镜

let filterNames = CIFilter.filterNamesInCategory(kCICategoryBuiltIn)

        for filterName in filterNames {
            let filter = CIFilter(name: filterName)
            print("\rfilter:\(filterName)\rattributes:\(filter?.attributes)")
        }

以下截取控制台输出的部分滤镜消息。

就拿CIZoomBlur滤镜模式来说,打印出来的信息,能够看到,里面定义了一些属性(每种滤镜,所含有的属性会有区别。在使用的时候,特别要注意)。

属性名称能够使用定义好的结构体成员kCIInputImageKey,或者直接"inputImage"调用,都是表示输入的图片。

inputImage相应的value里面定义了这个属性是什么类型的。属性描写叙述等。假设须要其它滤镜模式的能够去查看。

project下载地址:http://download.csdn.net/detail/xiaopingping1234567/9458261

时间: 2024-08-02 17:55:17

core image几个滤镜样例 oc版本号和swift版本号的相关文章

ADF Faces 表格应用基础案例二:动态字段+事件处理【附样例工程】

本文提供一个基于ADF Face组件开发样例工程,实现表格开发中常见的处理: 1.Map对象+Bean对象填充表格的数据行. 2.使用静态列.动态列.嵌套列的实现方法. 3.介绍表格中表单组件的使用方法. 4.介绍表格单行选中事件的处理过程. 本文是基于"ADF Faces 表格应用基础案例一:应用List<Class>填充文本表格"编写的,会省去许多细节部分的介绍. 实现的基本思路: 将样例工程的创建过程分为几个小的阶段,每个阶段实现了不同的目标. 第一阶段: 表格数据:

关于peersim样例配置文件的超详细解读(新手勿喷)

相信很多兄弟一开始接触peersim,对配置文件还是有点不适应,我看了好久的样例的配置文件,一层层去找对应的文件的方法,终于好像悟懂了一点,记下来以后回顾. 贴上代码,一点点分析. 首先要说下所谓的配置文件,其实就是一个txt文件,语法也是非常简单,类似java里的给类里的变量赋值,这也正对应了配置文件的作用,配置文件,当然就是为实验的参数进行配置用的,所以配置文件的主要功能就是配置各类参数,定义一些协议类.控制类.初始化类以及一些常数. 1 # PEERSIM EXAMPLE 1 #配置文件中

Android线程池(二)——ThreadPoolExecutor及其拒绝策略RejectedExecutionHandler使用演示样例

MainActivity例如以下: package cc.vv; import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.ThreadPoolExecutor; import java.util.concurrent.TimeUnit; import android.os.Bundle; import android.app.Activity; /** * Demo描写叙述: * 线程池(Threa

在Eclipse下使用Maven创建SpringMVC样例项目

1,新建maven项目,项目名起为:MavenSpringMVC. 具体步骤参见我的上一篇博客:在eclipse下使用Maven创建Struts2项目样例 2,配置pom.xml文件,引入依赖包(当然,我也不是一开始就知道需要引入哪些包的,我一开始也只是引入了Spring的核心包,后面发现缺包了就再补上) <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/200

.Net Native 系列《三》:.NET Native部署测试方案及样例

之前一文<c++的性能, c#的产能?!鱼和熊掌可以兼得,.NET NATIVE初窥> 获得很多朋友支持和鼓励,也更让我坚定做这项技术的推广者,希望能让更多的朋友了解这项技术,于是先从官方信息的翻译开始做起. 此系列系小九的学堂原创翻译,翻译自微软官方开发向导,一共分为六个主题.本文是第三个主题:.NET Native部署测试及样例. 向导文链接:<C++的性能C#的产能?! - .Net Native 系列:开发向导> [小九的学堂,致力于以平凡的语言描述不平凡的技术.如要转载,

最简单的基于FFmpeg的移动端样例:Windows Phone HelloWorld

===================================================== 最简单的基于FFmpeg的移动端样例系列文章列表: 最简单的基于FFmpeg的移动端样例:Android HelloWorld 最简单的基于FFmpeg的移动端样例:Android 视频解码器 最简单的基于FFmpeg的移动端样例:Android 视频解码器-单个库版 最简单的基于FFmpeg的移动端样例:Android 推流器 最简单的基于FFmpeg的移动端样例:Android 视频转

最简单的基于FFmpeg的AVDevice样例(读取摄像头)

=====================================================最简单的基于FFmpeg的AVDevice样例文章列表: 最简单的基于FFmpeg的AVDevice样例(读取摄像头) 最简单的基于FFmpeg的AVDevice样例(屏幕录制)===================================================== FFmpeg中有一个和多媒体设备交互的类库:Libavdevice. 使用这个库能够读取电脑(或者其它设备上

Swift - 自动布局库SnapKit的使用详解1(配置、使用方法、样例)

为了适应各种屏幕尺寸,iOS 6后引入了自动布局(Auto Layout)的概念,通过使用各种 Constraint(约束)来实现页面自适应弹性布局. 在 StoryBoard 中使用约束实现自动布局很方便,但如果用纯代码来设置约束就很麻烦了.这里向大家推荐一个好用的第三方布局库:SnapKit(其前身是 Masonry,一个OC版的布局库) 1.SnapKit介绍 SnapKit是一个优秀的第三方自适应布局库,它可以让iOS.OS X应用更简单地实现自动布局(Auto Layout).GtiH

最简单的基于FFmpeg的移动端样例附件:SDL Android HelloWorld

===================================================== 最简单的基于FFmpeg的移动端样例系列文章列表: 最简单的基于FFmpeg的移动端样例:Android HelloWorld 最简单的基于FFmpeg的移动端样例:Android 视频解码器 最简单的基于FFmpeg的移动端样例:Android 视频解码器-单个库版 最简单的基于FFmpeg的移动端样例:Android 推流器 最简单的基于FFmpeg的移动端样例:Android 视频转