- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
当一些基于 QML Item 的组件转换发生变化时,如何订阅每次触发的事件?我的意思是,当更改以下任何一项时:x、y、宽度、高度、比例、旋转、变换,所有层次结构中任何父节点的任何此字段。可能存在某种方式来制作支持此功能的 C++ 代码。我需要这个来制作在其他组件转换更改时重新计算某些字段的组件。
我需要以下代码才能正常工作:
import QtQuick 2.9
import Mirror 1.0
import QtGraphicalEffects 1.0
ShaderEffect {
id: se
property var imageSource
property var maskSource
property var faceSource
x: imageSource.x
y: imageSource.y
width: imageSource.width
height: imageSource.height
rotation: imageSource.rotation
scale: imageSource.scale
//transform: imageSource.transform
property real px
property real py
property real ux
property real uy
property real vx
property real vy
Connections {
target: face
onFaceChangeFinish: {
se.px = (se.mapToItem(maskSource, 0, 0).x) / maskSource.width;
se.py = (se.mapToItem(maskSource, 0, 0).y) / maskSource.height;
se.ux = (se.mapToItem(maskSource, se.width, 0).x) / maskSource.width - se.px;
se.uy = (se.mapToItem(maskSource, se.width, 0).y) / maskSource.height - se.py;
se.vx = (se.mapToItem(maskSource, 0, se.height).x) / maskSource.width - se.px;
se.vy = (se.mapToItem(maskSource, 0, se.height).y) / maskSource.height - se.py;
}
}
property var source : ShaderEffectSource {
sourceItem: imageSource
}
property var bodyMask : ShaderEffectSource {
sourceItem: maskSource
}
fragmentShader:
"
varying highp vec2 qt_TexCoord0;
uniform sampler2D source;
uniform sampler2D bodyMask;
uniform float px;
uniform float py;
uniform float ux;
uniform float uy;
uniform float vx;
uniform float vy;
void main() {
vec2 p = vec2(px, py);
vec2 u = vec2(ux, uy);
vec2 v = vec2(vx, vy);
vec2 uv = p + u * qt_TexCoord0.x + v * qt_TexCoord0.y;
gl_FragColor =
texture2D(source, qt_TexCoord0) *
(1.0 - texture2D(bodyMask, uv).w);
}
"
}
这是支持任何转换或层次结构的 OpacityMask 代码。我需要用一些东西替换“连接”部分,以处理所有更改蒙版或源图像转换的情况。属性绑定(bind)在这种情况下没有帮助,因为 mapToItem 是函数。
最佳答案
您可以在 onPropertyChanged{} 中捕获 QML 对象的任何属性的变化。然后你可以从 C++ 对象发送 nofity 信号或调用槽:
ShaderEffect {
id: root
signal objectChanged
onXChanged: root.objectChanged()
onYChanged: objectFromContext.someSlot()
}
关于c++ - QML 如何捕捉组件转换变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49427333/
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如何在 qml 文件之间发送变量或信号? http://i.stack.imgur.com/MChCG.png Mainwindow -> 创建组件Item2.qml MainWindow -> 创建
我正在做一些事情,我有一个名为“FloatingMenu”的类(它应该在 C++ 中管理菜单)及其在文件 FloatingMenu.qml 中用于 GUI 的 QML alter-ego。我有一个文件
我正在尝试做一些看似简单的事情,但失败了:定义一个简单的内联文本格式组件,然后用不同的文本多次实例化它。这是代码 Item { . . . Component { id: favButtonL
我可以在页面中使用 InvokeActionItem 轻松共享项目,但我需要能够在 ListView 项目中调用它。我设法触发了一个调用,但我不知道如何在触发它时添加数据。我不断收到错误消息 Invo
我如何在 QML 中检测 Window {} 之外的点击? Rectangle { id: topLevel height: 400; width: 400 Window {
我试过 : var child = grid.children[slot1]; grid.children[slot1] = grid.children[slot2]; grid.children[s
例如,我希望创建一个包含 100 个文本编辑器的 qml 窗口,如何在循环中创建它?那可能吗? 最佳答案 循环是命令式代码,所以它不是 QML,而是 Javascript 或 C++。所以当然,你可以
这是我的 QML 文件,其中包含一个文本组件: import QtQuick 2.0 Item { id: idItmWrapText Text { id: idTxt
我正在寻找一种方法来显示一个文本提示,说明预期的输入作为对用户的建议。以谷歌搜索栏为例: 是否有我缺少的属性,或者这是必须通过脚本来实现的? 最佳答案 Qt Quick 输入项上不存在该属性。您可以为
为 qml 项设置背景的最简单方法是让子矩形的 anchor 完全填满父项: Item { width: 320 height: 240 Rectangle {
我想将属性动态添加到 QML 元素: Item { id: dynamicProperty; property int first; Component.onCompleted: { /*
我用 PySide 和 QML 编写了某种安装程序。按照设计,它必须是多页的。而且我想将要从 QML 表单调用的插槽划分为不同的对象(理想情况下,划分为模块,但据我了解,带有插槽的对象必须继承 QOb
QML 中有没有办法用 opacity: 0 创建一个矩形?仍然有可见的边界?如果没有,有关如何解决它的任何建议? 谢谢 最佳答案 不,不透明度适用于项目的完整视觉方面(并且不透明度:0 使项目完全不
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我在 SO 上查看了大量关于 QML 内容边距的问题,但所有答案都指向缺少 spacing: 0 属性。我已经完成了所有这些,但仍然有一些我无法消除的奇怪空间。任何人都可以解释为什么这个 QML 代码
我有一个用于样式定义的 QML 单例,定义如下: pragma Singleton import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQu
这是以下代码的结果: 主.qml import QtQuick 2.8 Item { Reusable { index: 1234 // reusable with
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我是一名优秀的程序员,十分优秀!