- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我浏览了不同的来源,发现我们可以使用 fragment 着色器绘制虚线。因为我是 OpenGL 新手,所以无法理解。
任何人都可以分享一些使用 fragment 着色器和 GL_LINE_STRIP
绘制点线或虚线的代码示例吗?在 Android 中。
引用文献:
最佳答案
OpenGL ES 不支持线条点画。
如果您使用 OpenGL ES 1.00,那么您可以使用 OpenGL ES - Dashed Lines 的答案中提供的方法。 .
您必须创建一个 1 维纹理(2 维 Nx1 纹理),并将纹理包裹在线条上。纹理的 Alpha channel 中编码有点画图案。 Alpha test 会丢弃破折号之间的空格。 .
如果您使用 OpenGL ES 2.00 或更高版本 (OpenGL ES 3.x),则无法使用 Alpha 测试,因为它已被弃用。您必须使用 fragment 着色器并按 discard
跳过 fragment 。关键字。
创建仅具有红色 channel 的纹理。点画图案在红色 channel 中编码,但该代码与 OpenGL ES - Dashed Lines 中的代码非常相似。 ,除了您必须使用 GL10.GL_RED
的事实之外对于内部纹理格式(而不是 GL10.GL_ALPHA
):
byte arr[] = new byte[] { 255, 0, 0, 255 };
ByteBuffer textureBuffer = ByteBuffer.wrap(arr);
gl.glGenTextures(1, texture_id_, stippleTexObj);
gl.glBindTexture(GLES20.GL_TEXTURE_2D, stippleTexObj);
gl.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MIN_FILTER, GLES20.GL_NEAREST);
gl.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_MAG_FILTER, GLES20.GL_NEAREST);
gl.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_WRAP_S, GLES20.GL_REPEAT);
gl.glTexParameteri(GLES20.GL_TEXTURE_2D, GLES20.GL_TEXTURE_WRAP_T, GLES20.GL_REPEAT);
gl.glTexImage2D(GLES20.GL_TEXTURE_2D, 0, GLES20.GL_RED, 4, 1, 0,
GLES20.GL_RED, GLES20.GL_UNSIGNED_BYTE, textureBuffer);
当您绘制线条时,您必须使用着色器程序,该程序会丢弃依赖于纹理的红色 channel 的 fragment 。一个非常简单的 GLSL ES 1.00 着色器(适用于 OpenGL ES 3.00)可能如下所示:
顶点着色器:
attribute vec2 inPos;
attribute float inU;
varying float vU;
void main()
{
outU = inU;
gl_Position = vec4( inPos.xy, 0.0, 1.0 );
}
fragment 着色器:
precision mediump float;
varying float vU;
uniform sampler2D u_stippleTexture;
void main()
{
float stipple = texture2D(u_stippleTexture, vec2(vU, 0.0)).r;
if (stipple < 0.5)
discard;
gl_FragColor = vec4(1.0);
}
绘制线条时,确保与顶点关联的纹理坐标与整数值对齐,这会导致线条以破折号开头和结尾:
例如左下角为 (-0.5 -0.5) 、右下角为 (0.5, 0.5) 且纹理坐标在 [0, 5] 范围内的四边形:
x y u
-0.5f -0.5f 0.0f
0.5f -0.5f 5.0f
0.5f 0.5f 0.0f
-0.5f 0.5f 5.0f
由于换行函数是 GL_REPEAT
并且纹理坐标在 [0, 5] 范围内,点画图案的 5 次重复被包裹到四边形的每个边缘。
<子>您还可以在 fragment 着色器中生成点画,而不是使用纹理。查看桌面OpenGL cor配置文件的解决方案:
glLineStipple deprecated in OpenGL 3.1
Dashed line in OpenGL3?
关于java - 使用 fragment 着色器和GL_LINE_STRIP在OpenGL GLES20 android中绘制简单的虚线或短划线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60293538/
最近,我在各种俄罗斯Web 2.0网站中看到了点缀和虚线超链接的广泛使用。通常,此类链接(在其下方具有虚线或虚线,而不是普通的实线)不会将用户引导至另一页面,而是在同一页面上执行操作而不重新加载该页面
Google 没有帮助我找到问题的解决方案。 (据我所知...)。 我想知道是否可以在 Android 上画一 strip 有 9 个补丁功能的虚线。 我的目标是从一个布局到另一个布局画一条虚线。 我
有没有办法将多条线段视为一条线? IE:我将鼠标悬停在一个上,两个都突出显示,切换图例中的可见性将隐藏两个部分。 http://jsfiddle.net/rayholland/HSvBj/2/ ser
我在我的 C# WinForms 应用程序中使用 .net 4.0 的图表控件。我有两个系列的数据显示为折线图。 我绘制的基本上是作为时间函数的供求关系图。我希望需求是某种颜色的实线,供应是相同颜色的
如何在窗口调整大小期间避免线划线调整大小?考虑下图: http://leprastuff.ru/data/img/20130315/b83eea4a7a3f07ca53a0e118ddbb9230.G
我正在尝试使用纯 webgl 创建虚线。我知道这已经有一个问题,也许我很笨,但我不知道如何让它发挥作用。我理解这个概念,但我不知道如何在着色器中获取沿路径的距离。以前的答案有以下行: varying
我们应该在序列图中的哪些步骤中使用返回线? )没有返回箭头,因为它们隐式返回实例化对象 编辑 2 针对您更新的问题: 我不会有用户操作的返回箭头,例如 login(),因为结果不会以与对象相同的方式
我正在尝试使用 gnuplot v4.4 绘制一个包含虚线和连续线的图形。代码是: set term postscript eps enhanced color set style line 1 li
我正在尝试创建一个 React nivo 折线图,其中包含虚线而不是实线。我研究过图案,但不知道如何制作图案。感谢您的帮助。 最佳答案 nivo 在库中提供了自定义图层功能,您可以使用它来自定义从实线
我正在尝试创建一个 React nivo 折线图,其中包含虚线而不是实线。我研究过图案,但不知道如何制作图案。感谢您的帮助。 最佳答案 nivo 在库中提供了自定义图层功能,您可以使用它来自定义从实线
我使用一些通过的点创建虚线 UIBezierPath。 let pathLayer = CAShapeLayer() pathLayer.strokeColor = UIColor.blue.cgCo
我有以下问题。我必须从很多距离太近的点画一个圆。您可以在下面的 jsfiddle 链接中看到它: http://jsfiddle.net/L6e5oz3L/
我是 CSS 的新手,正在网上寻找自动重新压缩图像的代码,我发现的代码可以完美地做到这一点。但正确的是,它重新调整图像周围的一些红色虚线,当我尝试编辑时,整个图像消失了。可以请有人帮我解决图像显示时如
已将 Firebase Analytics 集成到我的 Android 项目中,它上个月运行正常,现在它只显示虚线并且用户数为 0。 不确定为什么会这样,我哪里错了?由于它之前工作正常,我相信我已经按
我正在使用 OpenGl ES 1.0 开发我的 Android 游戏,我想绘制虚线现在我使用这段代码来画我的线: gl.glColor4f(1.0f, 0.0f, 0.0f, 1.0f); // g
我正在尝试绘制 1 像素的虚线,但它总是绘制 2 像素的线。当前解决方案: let shapelayer = CAShapeLayer() let path = UIBezierPath() path
我这里有一个用 html 编码的菜单,但我需要一条虚线来跨越名称和价格,我将如何在这里做呢?我有点迷路了哈哈。 你可以在这里看到它。 http://mystycs.com/menu/menuifram
是否可以在 Chart.js 折线图上制作虚线?并使图表全宽?见附件样机。 这是我当前的代码(只是简单的例子): var ctx = document.getElementById("main
如何删除 JTabbedPane 上当前选定选项卡周围的虚线。 例如: 看到它周围的虚线了吗? 最佳答案 我刚刚找到了一个更好的方法: component.setFocusable(false); 关
我正在尝试使用 rgl 绘制一些 3d 形状,但我想使用虚线/虚线连接我的点。我怎样才能做到这一点?目前我有 require(rgl) p1 <- c(0,0,0) p2 <- c(1,0,0) p3
我是一名优秀的程序员,十分优秀!