summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--demos/declarative/calculator/calculator.qml10
-rw-r--r--demos/declarative/contacts/Contact.qml2
-rw-r--r--demos/declarative/flickr/content/LikeOMeter.qml2
-rw-r--r--demos/declarative/webbrowser/fieldtext/FieldText.qml5
-rw-r--r--demos/declarative/webbrowser/webbrowser.qml9
-rw-r--r--doc/src/declarative/elements.qdoc6
-rw-r--r--examples/declarative/border-image/example.qml2
-rw-r--r--examples/declarative/easing/easing.qml2
-rw-r--r--examples/declarative/fonts/fonts.qml2
-rw-r--r--examples/declarative/layouts/positioners.qml6
-rw-r--r--examples/declarative/listview/highlight.qml2
-rw-r--r--examples/declarative/listview/itemlist.qml2
-rw-r--r--examples/declarative/listview/listview.qml2
-rw-r--r--examples/declarative/listview/recipes.qml4
-rw-r--r--examples/declarative/listview/sections.qml2
-rw-r--r--examples/declarative/modules/installed-version.qml2
-rw-r--r--examples/declarative/modules/local-qualified.qml2
-rw-r--r--examples/declarative/smooth/rect-painting.qml2
-rw-r--r--examples/declarative/snow/snow.qml2
-rw-r--r--examples/declarative/tutorials/contacts/1_Drawing_and_Animation/1_Drawing_and_animation.qml2
-rw-r--r--examples/declarative/tutorials/contacts/2_Reuse/2_Reuse.qml2
-rw-r--r--examples/declarative/tutorials/contacts/2_Reuse/3/Contact.qml2
-rw-r--r--examples/declarative/tutorials/contacts/2_Reuse/4/Contact.qml2
-rw-r--r--examples/declarative/tutorials/contacts/3_Collections/3_Collections.qml2
-rw-r--r--examples/declarative/tutorials/contacts/3_Collections/lib/Contact.qml2
-rw-r--r--examples/declarative/tutorials/helloworld/t2/tutorial2.qml2
-rw-r--r--examples/declarative/tutorials/helloworld/t3/tutorial3.qml2
-rw-r--r--examples/declarative/velocity/velocity.qml2
-rw-r--r--examples/declarative/webview/autosize.qml2
-rw-r--r--examples/declarative/webview/content/FieldText.qml163
-rw-r--r--examples/declarative/webview/content/SpinSquare.qml4
-rw-r--r--examples/declarative/webview/content/pics/cancel.pngbin0 -> 1038 bytes
-rw-r--r--examples/declarative/webview/content/pics/ok.pngbin0 -> 655 bytes
-rw-r--r--src/declarative/QmlChanges.txt15
-rw-r--r--src/declarative/fx/qfxitem.h2
-rw-r--r--src/declarative/fx/qfxpositioners.cpp120
-rw-r--r--src/declarative/fx/qfxpositioners.h24
-rw-r--r--src/declarative/fx/qfxtext.cpp4
-rw-r--r--src/declarative/fx/qfxtextedit.cpp2
-rw-r--r--src/declarative/fx/qfxwebview.cpp44
-rw-r--r--src/declarative/fx/qfxwebview.h7
-rw-r--r--src/declarative/util/qmllistmodel.cpp8
-rw-r--r--tests/auto/declarative/layouts/data/grid-spacing.qml2
-rw-r--r--tests/auto/declarative/layouts/data/grid.qml2
-rw-r--r--tests/auto/declarative/layouts/data/horizontal-spacing.qml2
-rw-r--r--tests/auto/declarative/layouts/data/horizontal.qml2
-rw-r--r--tests/auto/declarative/layouts/data/vertical-spacing.qml2
-rw-r--r--tests/auto/declarative/layouts/data/vertical.qml2
-rw-r--r--tools/qmldebugger/engines.qml2
49 files changed, 344 insertions, 149 deletions
diff --git a/demos/declarative/calculator/calculator.qml b/demos/declarative/calculator/calculator.qml
index 24c3e69..b95cc7ab 100644
--- a/demos/declarative/calculator/calculator.qml
+++ b/demos/declarative/calculator/calculator.qml
@@ -7,7 +7,7 @@ Rectangle {
SystemPalette { id: Palette; colorGroup: Qt.Active }
Script { source: "calculator.js" }
- VerticalPositioner {
+ Column {
x: 2; spacing: 10;
Rectangle {
@@ -56,7 +56,7 @@ Rectangle {
CalcButton { operation: "C"; id: C; width: 76 }
CalcButton { operation: "AC"; id: AC; x: 78; width: 76 }
- GridPositioner {
+ Grid {
id: NumKeypad; y: 32; spacing: 2; columns: 3
CalcButton { operation: "7" }
@@ -70,7 +70,7 @@ Rectangle {
CalcButton { operation: "3" }
}
- HorizontalPositioner {
+ Row {
y: 128; spacing: 2
CalcButton { operation: "0"; width: 50 }
@@ -78,7 +78,7 @@ Rectangle {
CalcButton { operation: "="; id: Equals; x: 77; width: 102 }
}
- VerticalPositioner {
+ Column {
id: SimpleOperations
x: 156; y: 0; spacing: 2
@@ -89,7 +89,7 @@ Rectangle {
}
}
- GridPositioner {
+ Grid {
id: AdvancedButtons
x: 350; spacing: 2; columns: 2; opacity: 0
diff --git a/demos/declarative/contacts/Contact.qml b/demos/declarative/contacts/Contact.qml
index d02157c..91510c7 100644
--- a/demos/declarative/contacts/Contact.qml
+++ b/demos/declarative/contacts/Contact.qml
@@ -80,7 +80,7 @@ Item {
function remove() {
removeContactQuery.exec();
}
- VerticalPositioner {
+ Column {
id: layout
width: contents.width
height:contents.height
diff --git a/demos/declarative/flickr/content/LikeOMeter.qml b/demos/declarative/flickr/content/LikeOMeter.qml
index 0ba79b1..754dbb1 100644
--- a/demos/declarative/flickr/content/LikeOMeter.qml
+++ b/demos/declarative/flickr/content/LikeOMeter.qml
@@ -5,7 +5,7 @@ Item {
property int rating: 2
- HorizontalPositioner {
+ Row {
Star {
rating: 0
onClicked: { Container.rating = rating }
diff --git a/demos/declarative/webbrowser/fieldtext/FieldText.qml b/demos/declarative/webbrowser/fieldtext/FieldText.qml
index 976785b..fe55185 100644
--- a/demos/declarative/webbrowser/fieldtext/FieldText.qml
+++ b/demos/declarative/webbrowser/fieldtext/FieldText.qml
@@ -60,7 +60,7 @@ Item {
opacity: 0
}
- LineEdit {
+ TextInput {
id: textEdit
text: fieldText.text
focus: false
@@ -72,8 +72,7 @@ Item {
color: "black"
font.bold: true
readOnly: true
- Keys.onEnterPressed: confirm()
- Keys.onReturnPressed: confirm()
+ onAccepted: confirm()
Keys.onEscapePressed: reset()
}
diff --git a/demos/declarative/webbrowser/webbrowser.qml b/demos/declarative/webbrowser/webbrowser.qml
index 232871f..ec3a2a0 100644
--- a/demos/declarative/webbrowser/webbrowser.qml
+++ b/demos/declarative/webbrowser/webbrowser.qml
@@ -133,13 +133,6 @@ Item {
id: EditUrl
mouseGrabbed: parent.mouseGrabbed
- /*<<<<<<< HEAD:demos/declarative/webbrowser/webbrowser.qml
- text: MyWebView.url == '' ? ' ' : MyWebView.url
- wrap: false
- font.pointSize: 11
- color: "#555555"
- focusOnPress: true
- =======*/
text: WebBrowser.urlString
label: "url:"
onConfirmed: { print ('OnConfirmed: '+EditUrl.text); WebBrowser.urlString = EditUrl.text; print (EditUrl.text); MyWebView.focus=true }
@@ -207,7 +200,7 @@ Item {
idealHeight: Flick.height/scale
scale: (width > 0) ? Flick.width/width*zoomedOut+(1-zoomedOut) : 1
- onUrlChanged: { print ('OnUrlChanged: '+url.toString()); WebBrowser.urlString = url.toString(); print ('Moved to url: ' + WebBrowser.urlString) }
+ onUrlChanged: { if (url != null) { WebBrowser.urlString = url.toString(); } }
onDoubleClick: { toggleZoom() }
property real zoomedOut : 1
diff --git a/doc/src/declarative/elements.qdoc b/doc/src/declarative/elements.qdoc
index 6a285ba..ffa5494 100644
--- a/doc/src/declarative/elements.qdoc
+++ b/doc/src/declarative/elements.qdoc
@@ -132,9 +132,9 @@ The following table lists the QML elements provided by the Qt Declarative module
\o
\list
-\o \l VerticalPositioner
-\o \l HorizontalPositioner
-\o \l GridPositioner
+\o \l Column
+\o \l Row
+\o \l Grid
\endlist
\o
diff --git a/examples/declarative/border-image/example.qml b/examples/declarative/border-image/example.qml
index 8f974e1..87d3f37 100644
--- a/examples/declarative/border-image/example.qml
+++ b/examples/declarative/border-image/example.qml
@@ -5,7 +5,7 @@ Rectangle {
color: "white"
width: 520; height: 280
- HorizontalPositioner {
+ Row {
anchors.centerIn: parent
spacing: 50
//! [0]
diff --git a/examples/declarative/easing/easing.qml b/examples/declarative/easing/easing.qml
index f15b3fb..60c2040 100644
--- a/examples/declarative/easing/easing.qml
+++ b/examples/declarative/easing/easing.qml
@@ -51,7 +51,7 @@ Rectangle {
ListElement { type: "easeOutInBounce" }
}
- VerticalPositioner {
+ Column {
id: Layout
anchors.left: Window.left
anchors.right: Window.right
diff --git a/examples/declarative/fonts/fonts.qml b/examples/declarative/fonts/fonts.qml
index 2aa4851..f7ed494 100644
--- a/examples/declarative/fonts/fonts.qml
+++ b/examples/declarative/fonts/fonts.qml
@@ -16,7 +16,7 @@ Rectangle {
FontLoader { id: WebFont; source: "http://www.princexml.com/fonts/steffmann/Starburst.ttf" }
FontLoader { id: WebFont2; source: "http://wrong.address.org" }
- VerticalPositioner {
+ Column {
anchors.fill: parent
anchors.leftMargin: 10; anchors.rightMargin: 10
Text {
diff --git a/examples/declarative/layouts/positioners.qml b/examples/declarative/layouts/positioners.qml
index add46a4..fe28105 100644
--- a/examples/declarative/layouts/positioners.qml
+++ b/examples/declarative/layouts/positioners.qml
@@ -1,6 +1,6 @@
import Qt 4.6
Rectangle { width: 420; height: 420; id:page; color:"white"
- VerticalPositioner { id: layout1; y:0; //width: 100; height:250;
+ Column { id: layout1; y:0; //width: 100; height:250;
move: Transition{ NumberAnimation {properties: "y"; easing: "easeOutBounce" }}
add: Transition{ NumberAnimation { properties: "y"; from: 500; duration:500; easing: "easeOutQuad"}}
remove: Transition { NumberAnimation { properties:"y"; to: 500; duration:500; easing: "easeInQuad"}}
@@ -14,7 +14,7 @@ Rectangle { width: 420; height: 420; id:page; color:"white"
}
Rectangle { color: "orange"; width: 100; height: 50; border.color: "black"; radius: 15 }
}
- HorizontalPositioner { id: layout2; y:300;
+ Row { id: layout2; y:300;
move: Transition{ NumberAnimation {properties: "x"; easing: "easeOutBounce" }}
add: Transition{ NumberAnimation { properties: "x"; from: 500; duration:500; easing: "easeOutQuad"}
NumberAnimation { properties: "opacity"; from: 0; duration: 500;}}
@@ -32,7 +32,7 @@ Rectangle { width: 420; height: 420; id:page; color:"white"
Button { text: "Add"; icon: "add.png"; x: 145; y:140;
onClicked: {blueH2.opacity=1; blueH1.opacity=1; blueV1.opacity=1; blueV2.opacity=1; blueG1.opacity=1; blueG2.opacity=1; blueG3.opacity=1;}
}
- GridPositioner { x:260; y:0; columns:3
+ Grid { x:260; y:0; columns:3
remove: Transition { NumberAnimation{ properties: "opacity"; from: 1; to: 0; duration: 500}
NumberAnimation{properties: "x,y"; easing: "easeOutBounce"} }
move: Transition { NumberAnimation{ properties: "x,y"; easing: "easeOutBounce" }}
diff --git a/examples/declarative/listview/highlight.qml b/examples/declarative/listview/highlight.qml
index 3506ad7..2bf3a9f 100644
--- a/examples/declarative/listview/highlight.qml
+++ b/examples/declarative/listview/highlight.qml
@@ -14,7 +14,7 @@ Rectangle {
Item {
id: Wrapper
width: 200; height: 50
- VerticalPositioner {
+ Column {
Text { text: 'Name: ' + name }
Text { text: 'Type: ' + type }
Text { text: 'Age: ' + age }
diff --git a/examples/declarative/listview/itemlist.qml b/examples/declarative/listview/itemlist.qml
index bf1184f..c25ee59 100644
--- a/examples/declarative/listview/itemlist.qml
+++ b/examples/declarative/listview/itemlist.qml
@@ -40,7 +40,7 @@ Rectangle {
height: 30
width: 240
- HorizontalPositioner {
+ Row {
anchors.centerIn: parent
spacing: 20
Repeater {
diff --git a/examples/declarative/listview/listview.qml b/examples/declarative/listview/listview.qml
index 1e2de65..0f197b4 100644
--- a/examples/declarative/listview/listview.qml
+++ b/examples/declarative/listview/listview.qml
@@ -14,7 +14,7 @@ Rectangle {
Item {
id: Wrapper
width: 200; height: 50
- VerticalPositioner {
+ Column {
Text { text: 'Name: ' + name }
Text { text: 'Type: ' + type }
Text { text: 'Age: ' + age }
diff --git a/examples/declarative/listview/recipes.qml b/examples/declarative/listview/recipes.qml
index b4ad4d5..eac8bb5 100644
--- a/examples/declarative/listview/recipes.qml
+++ b/examples/declarative/listview/recipes.qml
@@ -37,7 +37,7 @@ Rectangle {
// Layout the page. Picture, title and ingredients at the top, method at the
// bottom. Note that elements that should not be visible in the list
// mode have their opacity set to wrapper.detailsOpacity.
- HorizontalPositioner {
+ Row {
id: topLayout
x: 10; y: 10; height: recipePic.height; width: parent.width
spacing: 10
@@ -45,7 +45,7 @@ Rectangle {
id: recipePic
source: picture; width: 48; height: 48
}
- VerticalPositioner {
+ Column {
height: recipePic.height; width: background.width-recipePic.width-20
spacing: 5
Text { id: name; text: title; font.bold: true; font.pointSize: 16 }
diff --git a/examples/declarative/listview/sections.qml b/examples/declarative/listview/sections.qml
index 1b51a43..ddb4931 100644
--- a/examples/declarative/listview/sections.qml
+++ b/examples/declarative/listview/sections.qml
@@ -36,7 +36,7 @@ Rectangle {
x: 5
height: Layout.height + 4
anchors.top: Separator.bottom
- VerticalPositioner {
+ Column {
id: Layout
y: 2
Text { text: 'Name: ' + name }
diff --git a/examples/declarative/modules/installed-version.qml b/examples/declarative/modules/installed-version.qml
index 0d3fa09..d90375dd 100644
--- a/examples/declarative/modules/installed-version.qml
+++ b/examples/declarative/modules/installed-version.qml
@@ -2,7 +2,7 @@ import Qt 4.6
import com.nokia.Foo 1.6
import com.nokia.Foo 1.7 as NewFoo
-VerticalPositioner {
+Column {
Bar { }
Baz { }
NewFoo.Bar { }
diff --git a/examples/declarative/modules/local-qualified.qml b/examples/declarative/modules/local-qualified.qml
index f321738..d3532af 100644
--- a/examples/declarative/modules/local-qualified.qml
+++ b/examples/declarative/modules/local-qualified.qml
@@ -3,7 +3,7 @@ import Qt 4.6
import "local" as X
import "local/SubLib" as Y
-VerticalPositioner {
+Column {
X.Foo { }
Y.Bar { }
}
diff --git a/examples/declarative/smooth/rect-painting.qml b/examples/declarative/smooth/rect-painting.qml
index 0f3eb6e..4b6e223 100644
--- a/examples/declarative/smooth/rect-painting.qml
+++ b/examples/declarative/smooth/rect-painting.qml
@@ -12,7 +12,7 @@ Rectangle {
color: "#eeeeee"
}
- GridPositioner {
+ Grid {
anchors.centerIn: parent
columns: 8; rows:4; spacing: 30
diff --git a/examples/declarative/snow/snow.qml b/examples/declarative/snow/snow.qml
index 985f913..b6781c3 100644
--- a/examples/declarative/snow/snow.qml
+++ b/examples/declarative/snow/snow.qml
@@ -22,7 +22,7 @@ Rectangle {
Item {
anchors.centerIn: parent
- HorizontalPositioner {
+ Row {
id: MyLayout
property real targetX: -(selectedX + imageWidth / 2)
diff --git a/examples/declarative/tutorials/contacts/1_Drawing_and_Animation/1_Drawing_and_animation.qml b/examples/declarative/tutorials/contacts/1_Drawing_and_Animation/1_Drawing_and_animation.qml
index ecc5635..050f05f 100644
--- a/examples/declarative/tutorials/contacts/1_Drawing_and_Animation/1_Drawing_and_animation.qml
+++ b/examples/declarative/tutorials/contacts/1_Drawing_and_Animation/1_Drawing_and_animation.qml
@@ -5,7 +5,7 @@ Rectangle {
width: layout.width
height: layout.height
color: "white"
- VerticalPositioner {
+ Column {
id: layout
width: childrenRect.width
GroupBox {
diff --git a/examples/declarative/tutorials/contacts/2_Reuse/2_Reuse.qml b/examples/declarative/tutorials/contacts/2_Reuse/2_Reuse.qml
index 885a3a1..a913dda 100644
--- a/examples/declarative/tutorials/contacts/2_Reuse/2_Reuse.qml
+++ b/examples/declarative/tutorials/contacts/2_Reuse/2_Reuse.qml
@@ -5,7 +5,7 @@ Rectangle {
width: layout.width
height: layout.height
color: "white"
- GridPositioner {
+ Grid {
id: layout
columns: 2
rows: 4
diff --git a/examples/declarative/tutorials/contacts/2_Reuse/3/Contact.qml b/examples/declarative/tutorials/contacts/2_Reuse/3/Contact.qml
index 8c54cd6..3516cee 100644
--- a/examples/declarative/tutorials/contacts/2_Reuse/3/Contact.qml
+++ b/examples/declarative/tutorials/contacts/2_Reuse/3/Contact.qml
@@ -14,7 +14,7 @@ Item {
onEmailChanged: { emailField.value = email }
onPhoneChanged: { phoneField.value = phone }
- VerticalPositioner {
+ Column {
id: layout
anchors.fill: parent
spacing: 5
diff --git a/examples/declarative/tutorials/contacts/2_Reuse/4/Contact.qml b/examples/declarative/tutorials/contacts/2_Reuse/4/Contact.qml
index 37fd8d3..83988ab 100644
--- a/examples/declarative/tutorials/contacts/2_Reuse/4/Contact.qml
+++ b/examples/declarative/tutorials/contacts/2_Reuse/4/Contact.qml
@@ -17,7 +17,7 @@ Item {
onEmailChanged: { emailField.value = email }
onPhoneChanged: { phoneField.value = phone }
- VerticalPositioner {
+ Column {
id: layout
anchors.fill: parent
spacing: 5
diff --git a/examples/declarative/tutorials/contacts/3_Collections/3_Collections.qml b/examples/declarative/tutorials/contacts/3_Collections/3_Collections.qml
index 4cc16a4..a7764ed 100644
--- a/examples/declarative/tutorials/contacts/3_Collections/3_Collections.qml
+++ b/examples/declarative/tutorials/contacts/3_Collections/3_Collections.qml
@@ -11,7 +11,7 @@ Rectangle {
}
// relies on the current focus behavior whereby setting focus=true on a
// component removes focus from any previous element
- GridPositioner {
+ Grid {
id: layout
width: childrenRect.width
height: childrenRect.height
diff --git a/examples/declarative/tutorials/contacts/3_Collections/lib/Contact.qml b/examples/declarative/tutorials/contacts/3_Collections/lib/Contact.qml
index 6f40e24..d00bf05 100644
--- a/examples/declarative/tutorials/contacts/3_Collections/lib/Contact.qml
+++ b/examples/declarative/tutorials/contacts/3_Collections/lib/Contact.qml
@@ -13,7 +13,7 @@ Item {
onEmailChanged: { emailField.value = email }
onPhoneChanged: { phoneField.value = phone }
- VerticalPositioner {
+ Column {
id: layout
anchors.fill: parent
spacing: 5
diff --git a/examples/declarative/tutorials/helloworld/t2/tutorial2.qml b/examples/declarative/tutorials/helloworld/t2/tutorial2.qml
index 32e9369..458e302 100644
--- a/examples/declarative/tutorials/helloworld/t2/tutorial2.qml
+++ b/examples/declarative/tutorials/helloworld/t2/tutorial2.qml
@@ -13,7 +13,7 @@ Rectangle {
y: 30
anchors.horizontalCenter: Page.horizontalCenter
}
- GridPositioner {
+ Grid {
id: ColorPicker
x: 0
anchors.bottom: Page.bottom
diff --git a/examples/declarative/tutorials/helloworld/t3/tutorial3.qml b/examples/declarative/tutorials/helloworld/t3/tutorial3.qml
index daf32d5..81e1f6a 100644
--- a/examples/declarative/tutorials/helloworld/t3/tutorial3.qml
+++ b/examples/declarative/tutorials/helloworld/t3/tutorial3.qml
@@ -40,7 +40,7 @@ Rectangle {
]
}
MouseRegion { id: MouseRegion; anchors.fill: HelloText }
- GridPositioner {
+ Grid {
id: ColorPicker
x: 0
anchors.bottom: Page.bottom
diff --git a/examples/declarative/velocity/velocity.qml b/examples/declarative/velocity/velocity.qml
index 088532e..c2425da 100644
--- a/examples/declarative/velocity/velocity.qml
+++ b/examples/declarative/velocity/velocity.qml
@@ -98,7 +98,7 @@ Rectangle {
id: Flick
anchors.fill: parent
viewportWidth: Lay.width
- HorizontalPositioner {
+ Row {
id: Lay
Repeater {
dataSource: List
diff --git a/examples/declarative/webview/autosize.qml b/examples/declarative/webview/autosize.qml
index 0099f37..13004a8 100644
--- a/examples/declarative/webview/autosize.qml
+++ b/examples/declarative/webview/autosize.qml
@@ -7,7 +7,7 @@ Rectangle {
color: "white"
width: 200
height: Layout.height
- VerticalPositioner {
+ Column {
id: Layout
spacing: 2
WebView {
diff --git a/examples/declarative/webview/content/FieldText.qml b/examples/declarative/webview/content/FieldText.qml
new file mode 100644
index 0000000..fe55185
--- /dev/null
+++ b/examples/declarative/webview/content/FieldText.qml
@@ -0,0 +1,163 @@
+import Qt 4.6
+
+Item {
+ id: fieldText
+ height: 30
+ property string text: ""
+ property string label: ""
+ property bool mouseGrabbed: false
+ signal confirmed
+ signal cancelled
+ signal startEdit
+
+ resources: [
+ Script {
+
+ function edit() {
+ if (!mouseGrabbed) {
+ fieldText.startEdit();
+ fieldText.state='editing';
+ mouseGrabbed=true;
+ }
+ }
+
+ function confirm() {
+ fieldText.state='';
+ fieldText.text = textEdit.text;
+ mouseGrabbed=false;
+ fieldText.confirmed();
+ }
+
+ function reset() {
+ textEdit.text = fieldText.text;
+ fieldText.state='';
+ mouseGrabbed=false;
+ fieldText.cancelled();
+ }
+
+ }
+ ]
+
+ Image {
+ id: cancelIcon
+ width: 22
+ height: 22
+ anchors.right: parent.right
+ anchors.rightMargin: 4
+ anchors.verticalCenter: parent.verticalCenter
+ source: "pics/cancel.png"
+ opacity: 0
+ }
+
+ Image {
+ id: confirmIcon
+ width: 22
+ height: 22
+ anchors.left: parent.left
+ anchors.leftMargin: 4
+ anchors.verticalCenter: parent.verticalCenter
+ source: "pics/ok.png"
+ opacity: 0
+ }
+
+ TextInput {
+ id: textEdit
+ text: fieldText.text
+ focus: false
+ anchors.left: parent.left
+ anchors.leftMargin: 0
+ anchors.right: parent.right
+ anchors.rightMargin: 0
+ anchors.verticalCenter: parent.verticalCenter
+ color: "black"
+ font.bold: true
+ readOnly: true
+ onAccepted: confirm()
+ Keys.onEscapePressed: reset()
+ }
+
+ Text {
+ id: textLabel
+ x: 5
+ width: parent.width-10
+ anchors.verticalCenter: parent.verticalCenter
+ horizontalAlignment: "AlignHCenter"
+ color: fieldText.state == "editing" ? "#505050" : "#AAAAAA"
+ font.italic: true
+ font.bold: true
+ text: label
+ opacity: textEdit.text == '' ? 1 : 0
+ opacity: Behavior {
+ NumberAnimation {
+ property: "opacity"
+ duration: 250
+ }
+ }
+ }
+
+ MouseRegion {
+ anchors.fill: cancelIcon
+ onClicked: { reset() }
+ }
+
+ MouseRegion {
+ anchors.fill: confirmIcon
+ onClicked: { confirm() }
+ }
+
+ MouseRegion {
+ id: editRegion
+ anchors.fill: textEdit
+ onClicked: { edit() }
+ }
+
+ states: [
+ State {
+ name: "editing"
+ PropertyChanges {
+ target: confirmIcon
+ opacity: 1
+ }
+ PropertyChanges {
+ target: cancelIcon
+ opacity: 1
+ }
+ PropertyChanges {
+ target: textEdit
+ color: "black"
+ readOnly: false
+ focus: true
+ selectionStart: 0
+ selectionEnd: -1
+ }
+ PropertyChanges {
+ target: editRegion
+ opacity: 0
+ }
+ PropertyChanges {
+ target: textEdit.anchors
+ leftMargin: 34
+ }
+ PropertyChanges {
+ target: textEdit.anchors
+ rightMargin: 34
+ }
+ }
+ ]
+
+ transitions: [
+ Transition {
+ from: ""
+ to: "*"
+ reversible: true
+ NumberAnimation {
+ properties: "opacity,leftMargin,rightMargin"
+ duration: 200
+ }
+ ColorAnimation {
+ property: "color"
+ duration: 150
+ }
+ }
+ ]
+}
diff --git a/examples/declarative/webview/content/SpinSquare.qml b/examples/declarative/webview/content/SpinSquare.qml
index 57ad697..6d5ada3 100644
--- a/examples/declarative/webview/content/SpinSquare.qml
+++ b/examples/declarative/webview/content/SpinSquare.qml
@@ -1,8 +1,8 @@
import Qt 4.6
Item {
- properties var period : 250
- properties var color : "black"
+ property var period : 250
+ propert var color : "black"
id: Root
Item {
diff --git a/examples/declarative/webview/content/pics/cancel.png b/examples/declarative/webview/content/pics/cancel.png
new file mode 100644
index 0000000..ecc9533
--- /dev/null
+++ b/examples/declarative/webview/content/pics/cancel.png
Binary files differ
diff --git a/examples/declarative/webview/content/pics/ok.png b/examples/declarative/webview/content/pics/ok.png
new file mode 100644
index 0000000..5795f04
--- /dev/null
+++ b/examples/declarative/webview/content/pics/ok.png
Binary files differ
diff --git a/src/declarative/QmlChanges.txt b/src/declarative/QmlChanges.txt
index da290b7..f886466 100644
--- a/src/declarative/QmlChanges.txt
+++ b/src/declarative/QmlChanges.txt
@@ -11,9 +11,12 @@ API Changes
Renamed Elements:
LineEdit -> TextInput
-VerticalLayout -> VerticalPositioner
-HorizontalLayout -> HorizontalPositioner
-GridLayout -> GridPositioner
+VerticalLayout -> Column
+HorizontalLayout -> Row
+VerticalPositioner -> Column
+HorizontalPositioner -> Row
+GridLayout -> Grid
+GridPositioner -> Grid
Rect -> Rectangle
FocusRealm -> FocusScope
FontFamily -> FontLoader
@@ -46,9 +49,9 @@ MouseRegion: add "pressedButtons" property
Timer: add start() and stop() slots
Deletions:
-VerticalPositioner: lost "margins" property
-HorizontalPositioner: lost "margins" property
-GridPositioner: lost "margins" property
+Column/VerticalPositioner: lost "margins" property
+Row/HorizontalPositioner: lost "margins" property
+Grid/Positioner/Layout: lost "margins" property
Other Changes:
Drag: axis becomes an enum with values "XAxis", "YAxis", "XandYAxis"
diff --git a/src/declarative/fx/qfxitem.h b/src/declarative/fx/qfxitem.h
index 3485985..89c2cf1 100644
--- a/src/declarative/fx/qfxitem.h
+++ b/src/declarative/fx/qfxitem.h
@@ -155,8 +155,6 @@ public:
void setKeepMouseGrab(bool);
Q_SIGNALS:
- void xChanged();
- void yChanged();
void widthChanged();
void heightChanged();
void childrenRectChanged();
diff --git a/src/declarative/fx/qfxpositioners.cpp b/src/declarative/fx/qfxpositioners.cpp
index 7f731cf..bad4944 100644
--- a/src/declarative/fx/qfxpositioners.cpp
+++ b/src/declarative/fx/qfxpositioners.cpp
@@ -318,22 +318,22 @@ void QFxBasePositioner::applyRemove(const QList<QPair<QString, QVariant> >& chan
applyTransition(changes,target, d->removeActions);
}
-QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,VerticalPositioner,QFxVerticalPositioner)
+QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,Column,QFxColumn)
/*!
- \qmlclass VerticalPositioner
- \brief The VerticalPositioner item lines up its children vertically.
+ \qmlclass Column
+ \brief The Column item lines up its children vertically.
\inherits Item
- The VerticalPositioner item positions its child items so that they are vertically
+ The Column item positions its child items so that they are vertically
aligned and not overlapping. Spacing between items can be added.
- The below example positions differently shaped rectangles using a VerticalPositioner.
+ The below example positions differently shaped rectangles using a Column.
\table
\row
\o \image verticalpositioner_example.png
\o
\qml
-VerticalPositioner {
+Column {
spacing: 2
Rectangle { color: "red"; width: 50; height: 50 }
Rectangle { color: "green"; width: 20; height: 50 }
@@ -342,7 +342,7 @@ VerticalPositioner {
\endqml
\endtable
- VerticalPositioner also provides for transitions to be set when items are added, moved,
+ Column also provides for transitions to be set when items are added, moved,
or removed in the positioner. Adding and removing apply both to items which are deleted
or have their position in the document changed so as to no longer be children of the positioner,
as well as to items which have their opacity set to or from zero so as to appear or disappear.
@@ -352,7 +352,7 @@ VerticalPositioner {
\o \image verticalpositioner_transition.gif
\o
\qml
-VerticalPositioner {
+Column {
spacing: 2
remove: ...
add: ...
@@ -365,7 +365,7 @@ VerticalPositioner {
*/
/*!
- \qmlproperty Transition VerticalPositioner::remove
+ \qmlproperty Transition Column::remove
This property holds the transition to apply when removing an item from the positioner. The transition is only applied to the removed items.
Removed can mean that either the object has been deleted or reparented, and thus is now longer a child of the positioner, or that the object has had its opacity set to zero, and thus is no longer visible.
@@ -377,7 +377,7 @@ VerticalPositioner {
\o \image positioner-remove.gif
\o
\qml
-VerticalPositioner {
+Column {
remove: Transition {
NumberAnimation {
properties: "opacity"
@@ -392,7 +392,7 @@ VerticalPositioner {
*/
/*!
- \qmlproperty Transition VerticalPositioner::add
+ \qmlproperty Transition Column::add
This property holds the transition to be applied when adding an item to the positioner. The transition will only be applied to the added item(s).
Added can mean that either the object has been created or reparented, and thus is now a child or the positioner, or that the object has had its opacity increased from zero, and thus is now visible.
@@ -402,7 +402,7 @@ VerticalPositioner {
\o \image positioner-add.gif
\o
\qml
-VerticalPositioner {
+Column {
add: Transition {
NumberAnimation {
properties: "opacity"
@@ -417,7 +417,7 @@ VerticalPositioner {
*/
/*!
- \qmlproperty Transition VerticalPositioner::move
+ \qmlproperty Transition Column::move
This property holds the transition to apply when moving an item within the positioner.
This can happen when other items are added or removed from the positioner, or when items resize themselves.
@@ -427,7 +427,7 @@ VerticalPositioner {
\o \image positioner-move.gif
\o
\qml
-VerticalPositioner {
+Column {
move: Transition {
NumberAnimation {
properties: "y"
@@ -439,12 +439,12 @@ VerticalPositioner {
\endtable
*/
/*!
- \qmlproperty int VerticalPositioner::spacing
+ \qmlproperty int Column::spacing
spacing is the amount in pixels left empty between each adjacent
item, and defaults to 0.
- The below example places a GridPositioner containing a red, a blue and a
+ The below example places a Grid containing a red, a blue and a
green rectangle on a gray background. The area the grid positioner
occupies is colored white. The top positioner has the default of no spacing,
and the bottom positioner has its spacing set to 2.
@@ -455,16 +455,16 @@ VerticalPositioner {
*/
/*!
\internal
- \class QFxVerticalPositioner
- \brief The QFxVerticalPositioner class lines up items vertically.
+ \class QFxColumn
+ \brief The QFxColumn class lines up items vertically.
\ingroup group_positioners
*/
-QFxVerticalPositioner::QFxVerticalPositioner(QFxItem *parent)
+QFxColumn::QFxColumn(QFxItem *parent)
: QFxBasePositioner(Vertical, parent)
{
}
-void QFxVerticalPositioner::doPositioning()
+void QFxColumn::doPositioning()
{
int voffset = 0;
@@ -500,13 +500,13 @@ void QFxVerticalPositioner::doPositioning()
}
}
-QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,HorizontalPositioner,QFxHorizontalPositioner)
+QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,Row,QFxRow)
/*!
- \qmlclass HorizontalPositioner
- \brief The HorizontalPositioner item lines up its children horizontally.
+ \qmlclass Row
+ \brief The Row item lines up its children horizontally.
\inherits Item
- The HorizontalPositioner item positions its child items so that they are
+ The Row item positions its child items so that they are
horizontally aligned and not overlapping. Spacing can be added between the
items, and a margin around all items can also be added. It also provides for
transitions to be set when items are added, moved, or removed in the
@@ -515,9 +515,9 @@ QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,HorizontalPositioner,QFxHorizont
positioner, as well as to items which have their opacity set to or from zero
so as to appear or disappear.
- The below example lays out differently shaped rectangles using a HorizontalPositioner.
+ The below example lays out differently shaped rectangles using a Row.
\qml
-HorizontalPositioner {
+Row {
spacing: 2
Rectangle { color: "red"; width: 50; height: 50 }
Rectangle { color: "green"; width: 20; height: 50 }
@@ -528,7 +528,7 @@ HorizontalPositioner {
*/
/*!
- \qmlproperty Transition HorizontalPositioner::remove
+ \qmlproperty Transition Row::remove
This property holds the transition to apply when removing an item from the positioner.
The transition will only be applied to the removed item(s).
@@ -537,7 +537,7 @@ HorizontalPositioner {
Note that if the item counts as removed because its opacity is zero it will not be visible during the transition unless you set the opacity in the transition, like in the below example.
\qml
-HorizontalPositioner {
+Row {
remove: Transition {
NumberAnimation {
properties: "opacity"
@@ -551,14 +551,14 @@ HorizontalPositioner {
*/
/*!
- \qmlproperty Transition HorizontalPositioner::add
+ \qmlproperty Transition Row::add
This property holds the transition to apply when adding an item to the positioner.
The transition will only be applied to the added item(s).
Added can mean that either the object has been created or reparented, and thus is now a child or the positioner, or that the object has had its opacity increased from zero, and thus is now visible.
\qml
-HorizontalPositioner {
+Row {
add: Transition {
NumberAnimation {
properties: "opacity"
@@ -572,13 +572,13 @@ HorizontalPositioner {
*/
/*!
- \qmlproperty Transition HorizontalPositioner::move
+ \qmlproperty Transition Row::move
This property holds the transition to apply when moving an item within the positioner.
This can happen when other items are added or removed from the positioner, or when items resize themselves.
\qml
-HorizontalPositioner {
+Row {
id: positioner
move: Transition {
NumberAnimation {
@@ -591,12 +591,12 @@ HorizontalPositioner {
*/
/*!
- \qmlproperty int HorizontalPositioner::spacing
+ \qmlproperty int Row::spacing
spacing is the amount in pixels left empty between each adjacent
item, and defaults to 0.
- The below example places a GridPositioner containing a red, a blue and a
+ The below example places a Grid containing a red, a blue and a
green rectangle on a gray background. The area the grid positioner
occupies is colored white. The top positioner has the default of no spacing,
and the bottom positioner has its spacing set to 2.
@@ -607,16 +607,16 @@ HorizontalPositioner {
*/
/*!
\internal
- \class QFxHorizontalPositioner
- \brief The QFxHorizontalPositioner class lines up items horizontally.
+ \class QFxRow
+ \brief The QFxRow class lines up items horizontally.
\ingroup group_positioners
*/
-QFxHorizontalPositioner::QFxHorizontalPositioner(QFxItem *parent)
+QFxRow::QFxRow(QFxItem *parent)
: QFxBasePositioner(Horizontal, parent)
{
}
-void QFxHorizontalPositioner::doPositioning()
+void QFxRow::doPositioning()
{
int hoffset = 0;
@@ -651,14 +651,14 @@ void QFxHorizontalPositioner::doPositioning()
}
}
-QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,GridPositioner,QFxGridPositioner)
+QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,Grid,QFxGrid)
/*!
- \qmlclass GridPositioner QFxGridPositioner
- \brief The GridPositioner item positions its children in a grid.
+ \qmlclass Grid QFxGrid
+ \brief The Grid item positions its children in a grid.
\inherits Item
- The GridPositioner item positions its child items so that they are
+ The Grid item positions its child items so that they are
aligned in a grid and are not overlapping. Spacing can be added
between the items. It also provides for transitions to be set when items are
added, moved, or removed in the positioner. Adding and removing apply
@@ -667,7 +667,7 @@ QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,GridPositioner,QFxGridPositioner
well as to items which have their opacity set to or from zero so
as to appear or disappear.
- The GridPositioner defaults to using four columns, and as many rows as
+ The Grid defaults to using four columns, and as many rows as
are necessary to fit all the child items. The number of rows
and/or the number of columns can be constrained by setting the rows
or columns properties. The grid positioner calculates a grid with
@@ -681,7 +681,7 @@ QML_DEFINE_TYPE(Qt,4,6,(QT_VERSION&0x00ff00)>>8,GridPositioner,QFxGridPositioner
\o \image gridLayout_example.png
\o
\qml
-GridPositioner {
+Grid {
columns: 3
spacing: 2
Rectangle { color: "red"; width: 50; height: 50 }
@@ -694,7 +694,7 @@ GridPositioner {
\endtable
*/
/*!
- \qmlproperty Transition GridPositioner::remove
+ \qmlproperty Transition Grid::remove
This property holds the transition to apply when removing an item from the positioner.
The transition is only applied to the removed item(s).
@@ -708,7 +708,7 @@ GridPositioner {
the opacity in the transition, like in the below example.
\qml
-GridPositioner {
+Grid {
remove: Transition {
NumberAnimation {
properties: "opacity"
@@ -722,7 +722,7 @@ GridPositioner {
*/
/*!
- \qmlproperty Transition GridPositioner::add
+ \qmlproperty Transition Grid::add
This property holds the transition to apply when adding an item to the positioner.
The transition is only applied to the added item(s).
@@ -732,7 +732,7 @@ GridPositioner {
visible.
\qml
-GridPositioner {
+Grid {
add: Transition {
NumberAnimation {
properties: "opacity"
@@ -746,14 +746,14 @@ GridPositioner {
*/
/*!
- \qmlproperty Transition GridPositioner::move
+ \qmlproperty Transition Grid::move
This property holds the transition to apply when moving an item within the positioner.
This can happen when other items are added or removed from the positioner, or
when items resize themselves.
\qml
-GridPositioner {
+Grid {
move: Transition {
NumberAnimation {
properties: "x,y"
@@ -765,12 +765,12 @@ GridPositioner {
*/
/*!
- \qmlproperty int GridPositioner::spacing
+ \qmlproperty int Grid::spacing
spacing is the amount in pixels left empty between each adjacent
item, and defaults to 0.
- The below example places a GridPositioner containing a red, a blue and a
+ The below example places a Grid containing a red, a blue and a
green rectangle on a gray background. The area the grid positioner
occupies is colored white. The top positioner has the default of no spacing,
and the bottom positioner has its spacing set to 2.
@@ -781,12 +781,12 @@ GridPositioner {
*/
/*!
\internal
- \class QFxGridPositioner
- \brief The QFxGridPositioner class lays out items in a grid.
+ \class QFxGrid
+ \brief The QFxGrid class lays out items in a grid.
\ingroup group_layouts
*/
-QFxGridPositioner::QFxGridPositioner(QFxItem *parent) :
+QFxGrid::QFxGrid(QFxItem *parent) :
QFxBasePositioner(Both, parent)
{
_columns=-1;
@@ -794,24 +794,24 @@ QFxGridPositioner::QFxGridPositioner(QFxItem *parent) :
}
/*!
- \qmlproperty int GridPositioner::columns
+ \qmlproperty int Grid::columns
This property holds the number of columns in the grid.
- When the columns property is set the GridPositioner will always have
+ When the columns property is set the Grid will always have
that many columns. Note that if you do not have enough items to
fill this many columns some columns will be of zero width.
*/
/*!
- \qmlproperty int GridPositioner::rows
+ \qmlproperty int Grid::rows
This property holds the number of rows in the grid.
- When the rows property is set the GridPositioner will always have that
+ When the rows property is set the Grid will always have that
many rows. Note that if you do not have enough items to fill this
many rows some rows will be of zero width.
*/
-void QFxGridPositioner::doPositioning()
+void QFxGrid::doPositioning()
{
int c=_columns,r=_rows;//Actual number of rows/columns
int numVisible = items()->size() + newItems()->size();
diff --git a/src/declarative/fx/qfxpositioners.h b/src/declarative/fx/qfxpositioners.h
index 9560925..9c18452 100644
--- a/src/declarative/fx/qfxpositioners.h
+++ b/src/declarative/fx/qfxpositioners.h
@@ -111,35 +111,35 @@ private:
Q_DECLARE_PRIVATE_D(QGraphicsItem::d_ptr, QFxBasePositioner)
};
-class Q_DECLARATIVE_EXPORT QFxVerticalPositioner : public QFxBasePositioner
+class Q_DECLARATIVE_EXPORT QFxColumn : public QFxBasePositioner
{
Q_OBJECT
public:
- QFxVerticalPositioner(QFxItem *parent=0);
+ QFxColumn(QFxItem *parent=0);
protected Q_SLOTS:
virtual void doPositioning();
private:
- Q_DISABLE_COPY(QFxVerticalPositioner)
+ Q_DISABLE_COPY(QFxColumn)
};
-class Q_DECLARATIVE_EXPORT QFxHorizontalPositioner: public QFxBasePositioner
+class Q_DECLARATIVE_EXPORT QFxRow: public QFxBasePositioner
{
Q_OBJECT
public:
- QFxHorizontalPositioner(QFxItem *parent=0);
+ QFxRow(QFxItem *parent=0);
protected Q_SLOTS:
virtual void doPositioning();
private:
- Q_DISABLE_COPY(QFxHorizontalPositioner)
+ Q_DISABLE_COPY(QFxRow)
};
-class Q_DECLARATIVE_EXPORT QFxGridPositioner : public QFxBasePositioner
+class Q_DECLARATIVE_EXPORT QFxGrid : public QFxBasePositioner
{
Q_OBJECT
Q_PROPERTY(int rows READ rows WRITE setRows)
Q_PROPERTY(int columns READ columns WRITE setcolumns)
public:
- QFxGridPositioner(QFxItem *parent=0);
+ QFxGrid(QFxItem *parent=0);
int rows() const {return _rows;}
void setRows(const int rows){_rows = rows;}
@@ -152,14 +152,14 @@ protected Q_SLOTS:
private:
int _rows;
int _columns;
- Q_DISABLE_COPY(QFxGridPositioner)
+ Q_DISABLE_COPY(QFxGrid)
};
QT_END_NAMESPACE
-QML_DECLARE_TYPE(QFxVerticalPositioner)
-QML_DECLARE_TYPE(QFxHorizontalPositioner)
-QML_DECLARE_TYPE(QFxGridPositioner)
+QML_DECLARE_TYPE(QFxColumn)
+QML_DECLARE_TYPE(QFxRow)
+QML_DECLARE_TYPE(QFxGrid)
QT_END_HEADER
diff --git a/src/declarative/fx/qfxtext.cpp b/src/declarative/fx/qfxtext.cpp
index 69768b3..c60aaf2 100644
--- a/src/declarative/fx/qfxtext.cpp
+++ b/src/declarative/fx/qfxtext.cpp
@@ -229,7 +229,7 @@ QColor QFxText::color() const
Supported text styles are \c Normal, \c Outline, \c Raised and \c Sunken.
\qml
- HorizontalPositioner {
+ Row {
Text { font.pointSize: 24; text: "Normal" }
Text { font.pointSize: 24; text: "Raised"; style: "Raised"; styleColor: "#AAAAAA" }
Text { font.pointSize: 24; text: "Outline"; style: "Outline"; styleColor: "red" }
@@ -363,7 +363,7 @@ void QFxText::setWrap(bool w)
\row
\o
\qml
-VerticalPositioner {
+Column {
TextEdit {
font.pointSize: 24
text: "<b>Hello</b> <i>World!</i>"
diff --git a/src/declarative/fx/qfxtextedit.cpp b/src/declarative/fx/qfxtextedit.cpp
index eaceeeb..c2c418e 100644
--- a/src/declarative/fx/qfxtextedit.cpp
+++ b/src/declarative/fx/qfxtextedit.cpp
@@ -172,7 +172,7 @@ void QFxTextEdit::setText(const QString &text)
\row
\o
\qml
-VerticalPositioner {
+Column {
TextEdit {
font.pointSize: 24
text: "<b>Hello</b> <i>World!</i>"
diff --git a/src/declarative/fx/qfxwebview.cpp b/src/declarative/fx/qfxwebview.cpp
index a7d233f..347c9c2 100644
--- a/src/declarative/fx/qfxwebview.cpp
+++ b/src/declarative/fx/qfxwebview.cpp
@@ -131,6 +131,8 @@ public:
QWebSettings *s;
};
+QML_DECLARE_TYPE(QFxWebSettings)
+QML_DEFINE_NOCREATE_TYPE(QFxWebSettings)
class QFxWebViewPrivate : public QFxPaintedItemPrivate
{
@@ -781,6 +783,27 @@ void QFxWebView::keyReleaseEvent(QKeyEvent* event)
QFxPaintedItem::keyReleaseEvent(event);
}
+bool QFxWebView::sceneEvent(QEvent *event)
+{
+ Q_D(const QFxWebView);
+
+ if (d->interactive) {
+ if (event->type() == QEvent::KeyPress) {
+ QKeyEvent *k = static_cast<QKeyEvent *>(event);
+ if (k->key() == Qt::Key_Tab || k->key() == Qt::Key_Backtab) {
+ if (!(k->modifiers() & (Qt::ControlModifier | Qt::AltModifier))) { //### Add MetaModifier?
+ page()->event(event);
+ if (event->isAccepted())
+ return true;
+ }
+ }
+ }
+ }
+ return QFxPaintedItem::sceneEvent(event);
+}
+
+
+
/*!
\qmlproperty action WebView::back
This property holds the action for causing the previous URL in the history to be displayed.
@@ -951,7 +974,7 @@ QWebPage *QFxWebView::page() const
}
\endqml
*/
-QObject *QFxWebView::settingsObject() const
+QFxWebSettings *QFxWebView::settingsObject() const
{
Q_D(const QFxWebView);
d->settings.s = page()->settings();
@@ -1101,22 +1124,35 @@ public:
QmlEngine *engine = qmlEngine(webview);
component = new QmlComponent(engine, url, this);
item = 0;
- if (component->isReady())
- qmlLoaded();
- else
+ if (component->isLoading())
connect(component, SIGNAL(statusChanged(QmlComponent::Status)), this, SLOT(qmlLoaded()));
+ else
+ qmlLoaded();
}
public Q_SLOTS:
void qmlLoaded()
{
+ if (component->isError()) {
+ // XXX Could instead give these errors to the WebView to handle.
+ foreach (QmlError err, component->errors())
+ qWarning(err.toString().toLatin1());
+ return;
+ }
item = qobject_cast<QFxItem*>(component->create(qmlContext(webview)));
item->setParent(webview);
+ QString jsObjName;
for (int i=0; i<propertyNames.count(); ++i) {
if (propertyNames[i] != QLatin1String("type") && propertyNames[i] != QLatin1String("data")) {
item->setProperty(propertyNames[i].toLatin1(),propertyValues[i]);
+ if (propertyNames[i] == QLatin1String("objectname"))
+ jsObjName = propertyValues[i];
}
}
+ if (!jsObjName.isNull()) {
+ QWebFrame *f = webview->page()->mainFrame();
+ f->addToJavaScriptWindowObject(jsObjName, item);
+ }
resizeEvent(0);
delete component;
component = 0;
diff --git a/src/declarative/fx/qfxwebview.h b/src/declarative/fx/qfxwebview.h
index d619e94..40c86b4 100644
--- a/src/declarative/fx/qfxwebview.h
+++ b/src/declarative/fx/qfxwebview.h
@@ -75,6 +75,8 @@ private:
class QFxWebViewAttached;
+class QFxWebSettings;
+
class Q_DECLARATIVE_EXPORT QFxWebView : public QFxPaintedItem
{
Q_OBJECT
@@ -103,7 +105,7 @@ class Q_DECLARATIVE_EXPORT QFxWebView : public QFxPaintedItem
Q_PROPERTY(QObject* forward READ forwardAction CONSTANT)
Q_PROPERTY(QObject* stop READ stopAction CONSTANT)
- Q_PROPERTY(QObject* settings READ settingsObject CONSTANT)
+ Q_PROPERTY(QFxWebSettings* settings READ settingsObject CONSTANT)
Q_PROPERTY(QmlList<QObject *>* javaScriptWindowObjects READ javaScriptWindowObjects CONSTANT)
@@ -157,7 +159,7 @@ public:
QWebHistory *history() const;
QWebSettings *settings() const;
- QObject *settingsObject() const;
+ QFxWebSettings *settingsObject() const;
QString status() const;
@@ -213,6 +215,7 @@ protected:
virtual void geometryChanged(const QRectF &newGeometry,
const QRectF &oldGeometry);
virtual void focusChanged(bool);
+ virtual bool sceneEvent(QEvent *event);
private:
void init();
diff --git a/src/declarative/util/qmllistmodel.cpp b/src/declarative/util/qmllistmodel.cpp
index e2575ab..98c552f 100644
--- a/src/declarative/util/qmllistmodel.cpp
+++ b/src/declarative/util/qmllistmodel.cpp
@@ -72,7 +72,7 @@ struct ListModelData
\qmlclass ListModel
\brief The ListModel element defines a free-form list data source.
- The ListModel is a simple hierarchy of items containing data roles.
+ The ListModel is a simple hierarchy of elements containing data roles.
For example:
\code
@@ -93,8 +93,8 @@ struct ListModelData
}
\endcode
- Item roles (properties) must begin with a lower-case letter. The above example defines a
- ListModel containing three items, with the roles "name" and "cost".
+ Roles (properties) must begin with a lower-case letter. The above example defines a
+ ListModel containing three elements, with the roles "name" and "cost".
The defined model can be used in views such as ListView:
\code
@@ -153,7 +153,7 @@ struct ListModelData
width: 200; height: 50
Text { id: Name; text: name }
Text { text: '$'+cost; anchors.right: parent.right }
- HorizontalPositioner {
+ Row {
anchors.top: Name.bottom
spacing: 5
Text { text: "Attributes:" }
diff --git a/tests/auto/declarative/layouts/data/grid-spacing.qml b/tests/auto/declarative/layouts/data/grid-spacing.qml
index f8b5620..f9ae204 100644
--- a/tests/auto/declarative/layouts/data/grid-spacing.qml
+++ b/tests/auto/declarative/layouts/data/grid-spacing.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- GridPositioner {
+ Grid {
columns: 3
spacing: 4
Rect {
diff --git a/tests/auto/declarative/layouts/data/grid.qml b/tests/auto/declarative/layouts/data/grid.qml
index 2fbc37c..3861f63 100644
--- a/tests/auto/declarative/layouts/data/grid.qml
+++ b/tests/auto/declarative/layouts/data/grid.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- GridPositioner {
+ Grid {
columns: 3
Rect {
id: one
diff --git a/tests/auto/declarative/layouts/data/horizontal-spacing.qml b/tests/auto/declarative/layouts/data/horizontal-spacing.qml
index 25dad8a..8594ee6 100644
--- a/tests/auto/declarative/layouts/data/horizontal-spacing.qml
+++ b/tests/auto/declarative/layouts/data/horizontal-spacing.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- HorizontalPositioner {
+ Row {
spacing: 10
Rect {
id: one
diff --git a/tests/auto/declarative/layouts/data/horizontal.qml b/tests/auto/declarative/layouts/data/horizontal.qml
index 4bce504..673e77e 100644
--- a/tests/auto/declarative/layouts/data/horizontal.qml
+++ b/tests/auto/declarative/layouts/data/horizontal.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- HorizontalPositioner {
+ Row {
Rect {
id: one
color: "red"
diff --git a/tests/auto/declarative/layouts/data/vertical-spacing.qml b/tests/auto/declarative/layouts/data/vertical-spacing.qml
index aa704be..49bd8c6 100644
--- a/tests/auto/declarative/layouts/data/vertical-spacing.qml
+++ b/tests/auto/declarative/layouts/data/vertical-spacing.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- VerticalPositioner {
+ Column {
spacing: 10
Rect {
id: one
diff --git a/tests/auto/declarative/layouts/data/vertical.qml b/tests/auto/declarative/layouts/data/vertical.qml
index 0a52126..c8d3a11 100644
--- a/tests/auto/declarative/layouts/data/vertical.qml
+++ b/tests/auto/declarative/layouts/data/vertical.qml
@@ -3,7 +3,7 @@ import Qt 4.6
Item {
width: 640
height: 480
- VerticalPositioner {
+ Column {
Rect {
id: one
color: "red"
diff --git a/tools/qmldebugger/engines.qml b/tools/qmldebugger/engines.qml
index 9a96c4b..1652ebd 100644
--- a/tools/qmldebugger/engines.qml
+++ b/tools/qmldebugger/engines.qml
@@ -6,7 +6,7 @@ Item {
signal engineClicked(int id)
signal refreshEngines()
- HorizontalPositioner {
+ Row {
anchors.fill: parent
Repeater {
dataSource: engines