Search code examples
actionscript-3actionscriptflash-builder4.5

actionscript 3 contentHeight not updating properly


I am using Adobe Flash Builder with actionscript to make a desktop application. I am getting some html code from a webpage and putting it into an mx:html element, then attempting to get the content height in order to determine if I should hide the vertical scrollbar or not. However, when using contentHeight it seems to return the height of the previous state of the element, rather than the one just set.

This is the code to fetch the html page

var htmlPageRequest:URLRequest = new URLRequest(url); 
htmlPageRequest.method = URLRequestMethod.GET; //set request's html request method to GET

htmlPageLoader.addEventListener(Event.COMPLETE, onHtmlLoaded); //listen for page load
htmlPageLoader.load(htmlPageRequest);//when loaded continue logic in new function   

This is the function that is run when the page request is complete

private function onHtmlLoaded(e:Event):void { //logic after html page has loaded 
            HtmlElement.data = htmlPageLoader.data; //set content

            //determine if vscroll bar should be visible
            if(HtmlElement.contentHeight > HtmlElement.height) {
                scrollbar.visible = true; 
            }
            else {
                scrollbar.visible = false;
            }

            trace(HtmlElement.height);
            trace(HTMLELEMENT.contentHeight);
        }

Solution

  • I have realised the solution to the problem:

    htmlElement.data = htmlPageLoader.data;
    

    Rendering the HTML takes a certain amount of time - the contentHeight is being accessed before the page has actually rendered, causing the previous value to be returned. In order to fix this, I added an event listener for (htmlRender) in order to not access contentHeight until the rendering is complete.

    private function onHtmlLoaded(e:Event):void { //logic after html page has loaded 
    
            htmlElement.addEventListener(Event.HTML_RENDER, onHtmlRendered); //once the html has rendered, move on
            htmlElement.data = htmlPageLoader.data; //render content                
            }
    
            private function onHtmlRendered(e:Event):void { //logic for after the page has rendered
    
                //if the content of the HTML element is bigger than the box, show the scrollbar
                if(htmlElement.contentHeight > htmlElement.height) {
                    scrollbar.visible = true; 
                }
                else {
                    scrollbar.visible = false;
                }
            }