Re: How to adjust a GWT frame height to get no scrollbars (100% of body content)?
<ui:UiBinder xmlns:ui='urn:ui:com.google.gwt.uibinder'
xmlns:g="urn:import:com.google.gwt.user.client.ui"
xmlns:mgtouch="urn:import:com.googlecode.mgwt.ui.client.widget.touch"
xmlns:mgwt='urn:import:com.googlecode.mgwt.ui.client.widget'>
<ui:style>
.background {
background-color: black;
}
.absoluteFull {
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}
.header {
position: absolute;
left: 10px;
right: 10px;
top: 10px;
height: 30px;
background-color: red;
}
.body {
position: absolute;
left: 10px;
right: 10px;
top: 35px;
bottom: 10px;
background-color: green;
overflow: hidden;
}
.frame {
height: 1000px;
width: 100%;
border: none;
width: auto;
}
.htmlPanel {
position: relative;
width: 700px;
}
.clickKeeper {
position: absolute;
width: 100%;
height: 1000px;
}
</ui:style>
<mgwt:LayoutPanel styleName="{style.absoluteFull} {style.background}">
<g:HTMLPanel styleName="{style.header}">
Not Scrolling
</g:HTMLPanel>
<mgwt:LayoutPanel styleName="{style.body}">
<mgwt:ScrollPanel styleName="{style.absoluteFull}" autoHandleResize="true" hideScrollBar="false"
scrollingEnabledX="false">
<mgtouch:TouchPanel>
<g:HTMLPanel styleName="{style.htmlPanel}">
<iframe src="stuff.html" class="{style.frame}" scrolling="no"/>
<!-- sits over the frame and keeps the clicks for the scroll panel-->
<div class="{style.clickKeeper}"/>
</g:HTMLPanel>
</mgtouch:TouchPanel>
</mgwt:ScrollPanel>
</mgwt:LayoutPanel>
</mgwt:LayoutPanel>
</ui:UiBinder>
Well, it's a mixed bag. After investigating more, I would probably recommend just letting the frames scroll themselves like you demonstrated earlier with your sample html file.
That said, I managed to come up with a hack for you that might work, but probably won't for your case. I'm hoping it might get you started on something that does work for you. I've attached a ui builder file, the associated class didn't do anything. So, it should be easy enough for you to just dump it in a new ui builder file. You could also translate it into "regular" code.
There are two problems, I think you've alluded to them both but I'll put them in my own words, maybe an alternate perspective will help. The first problem is iframes have no ability to adjust their size based to fit their content. This means that the mgwt scroll panel can't really scroll them. The only solution I can come up with for this is what is already in this topic. That is, figure out a way to adjust the height of the iframe after the contents have been loaded.
The other problem is once this is done, the iframe will eat all the events it gets. This makes sense because the iframe needs to deal with everything a browser needs to deal with. What I have attached here is a ui builder that overlays an invisible div over the iframe. This means that mgwt is able to receive the events and scroll that page, which happens to mean that it scrolls the iframe with the invisible div. The bad news is, the iframe underneath will not receive any events. In some extremely limited cases this might be okay.
Further research into how to get events to the containing page from the iframe might help.
I'll post any new ideas if the pop into my head.
On Tuesday, January 21, 2014 3:07:13 AM UTC-6, marian lux wrote:
It seems to be a mgwt problem?
I have three attachments:.) working_mobile_scroll.htmlmy View-Class where the gwt-frame-widget is defined
displays a normal html with an iframe and I am able to scroll everywhere on mobile browser (e.g. on Android Google Chrome)
.) FrameViewGwtImpl.java
.) Bildschirmfoto ....
a screenshot of the dom when running in development-mode
=> I am always able to scroll with two fingers (touchpad) on desktop browser but one finger scroll on mobile browser only works on my test-html "working_mobile_scroll.html" and not in my mgwt-application.
In my mgwt-application: If i tap inside the frame and want to scroll, nothing happens. Only scrolling outside the frame on left or right side with one finger is working.
Am Donnerstag, 16. Januar 2014 18:59:56 UTC+1 schrieb Wayne Rasmuss:You're right, there's no frames there, but you should be able to make them behave like other content I think.I saw you are using mgwt. Are you using the mgwt scroll panel? It can probably work either way, but it would help to know.Can you point me to a live url, or maybe capture the DOM using inspect element in chrome or something so I can see exactly what's going? Providing the GWT classes that are responsible for each element would be helpful too.
On Thursday, January 16, 2014 11:11:43 AM UTC-6, marian lux wrote:Hi Wayne,
thank you! It would be very nice if you could help me with some CSS tweaks.
Your application has a good looking design and it is a good, innovative idea :-)
But I did not see any frames there, so I hope you can help me with my problem:
I want the same scrolling experience on my gwt-frame as with a gwt-html widget (scrolling with one finger on the content if it does not fit the client size - height)
Thank you in advance!
Am Donnerstag, 16. Januar 2014 14:18:16 UTC+1 schrieb Wayne Rasmuss:Admittedly, I didn't look too closely at your use case, but I believe I've accomplished similar things using css with mgwt. You can check out my app at app.carellaborate.com.One thing that hung my up was in mgwt the scroll panel has to be a direct child of touch panel, or something like that anyway.
If you like the idea of using css instead, I should have more time to help with an example later
You received this message because you are subscribed to the Google Groups "Google Web Toolkit" group.
To unsubscribe from this group and stop receiving emails from it, send an email to google-web-toolkit+unsubscribe@googlegroups.com.
To post to this group, send email to google-web-toolkit@googlegroups.com.
Visit this group at http://groups.google.com/group/google-web-toolkit.
For more options, visit https://groups.google.com/groups/opt_out.
0 Comments:
Post a Comment
Subscribe to Post Comments [Atom]
<< Home