source-engine/public/vgui/IHTML.h

202 lines
7.6 KiB
C
Raw Permalink Normal View History

2020-04-22 16:56:21 +00:00
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================//
#ifndef IHTML_H
#define IHTML_H
#ifdef _WIN32
#pragma once
#endif
#include <vgui/VGUI.h>
#include <vgui/MouseCode.h>
#include <vgui/KeyCode.h>
#include <vgui/Cursor.h>
#include <vgui/IImage.h>
namespace vgui
{
//-----------------------------------------------------------------------------
// Purpose: basic interface for a HTML window
//-----------------------------------------------------------------------------
class IHTML
{
public:
// open a new page
virtual void OpenURL(const char *)=0;
// stops the existing page from loading
virtual bool StopLoading()=0;
// refreshes the current page
virtual bool Refresh()=0;
// display the control -- deprecated !! Use SetVisible() instead!
virtual bool Show(bool shown)=0;
// return the currently opened page
virtual const char *GetOpenedPage()=0;
// called when the browser needs to be resized
virtual void Obsolete_OnSize(int x,int y, int w,int h)=0;
// returns the width and height (in pixels) of the HTML full page (not just the displayed region)
virtual void GetHTMLSize(int &wide,int &tall) = 0;
// clear the text in an existing control
virtual void Clear()=0;
// add text to the browser control (as a HTML formated string)
virtual void AddText(const char *text)=0;
enum MOUSE_STATE { UP,DOWN,MOVE,DBLCLICK };
// unused functions we keep around so the vtable layout is binary compatible
virtual void Obsolete_OnMouse(MouseCode code,MOUSE_STATE s,int x,int y)=0;
virtual void Obsolete_OnChar(wchar_t unichar)=0;
virtual void Obsolete_OnKeyDown(KeyCode code)=0;
virtual vgui::IImage *GetBitmap()=0;
virtual void SetVisible( bool state ) = 0;
virtual void SetSize( int wide,int tall )=0;
virtual void OnMouse(MouseCode code,MOUSE_STATE s,int x,int y, bool bPopupMenuMenu )=0;
virtual void OnChar(wchar_t unichar, bool bPopupMenu)=0;
virtual void OnKeyDown(KeyCode code, bool bPopupMenu)=0;
virtual void ScrollV( int nPixels ) = 0;
virtual void ScrollH( int nPixels ) = 0;
virtual void OnMouseWheeled( int delta, bool bPopupMenu )= 0;
// called when the browser needs to be resized
virtual void OnKeyUp(KeyCode code, bool bPopupMenu)=0;
// open a URL with the provided POST data (which can be much larger than the max URL of 512 chars)
// NOTE - You CANNOT have get params (i.e a "?" ) in pchURL if pchPostData is set (due to an IE bug)
virtual void PostURL( const char *pchURL, const char *pchPostData ) = 0;
// Run javascript within the browser control
virtual void RunJavascript( const char *pchScript ) = 0;
virtual void SetMousePosition( int x, int y, bool bPopupMenu ) = 0;
virtual void SetUserAgentInfo( const wchar_t *pwchUserAgent ) = 0;
// can't add custom headers to IE
virtual void AddHeader( const char *pchHeader, const char *pchValue ) = 0;
virtual void SetFileDialogChoice( const char *pchFileName ) = 0;
// we are hiding the popup, so make sure webkit knows
virtual void HidePopup() = 0;
virtual void SetHTMLFocus() = 0;
virtual void KillHTMLFocus() = 0;
// ask webkit about the size of any scrollbars it wants to render
virtual void HorizontalScrollBarSize( int &x, int &y, int &wide, int &tall) = 0;
virtual void VerticalScrollBarSize( int &x, int &y, int &wide, int &tall) = 0;
virtual int HorizontalScroll() = 0;
virtual int VerticalScroll() = 0;
virtual int HorizontalScrollMax() =0;
virtual int VerticalScrollMax() =0;
virtual bool IsHorizontalScrollBarVisible() =0;
virtual bool IsVeritcalScrollBarVisible() =0;
virtual void SetHorizontalScroll( int scroll ) =0;
virtual void SetVerticalScroll( int scroll ) =0;
virtual void ViewSource() = 0;
virtual void Copy() = 0;
virtual void Paste() = 0;
// IE specific calls
virtual bool IsIERender() = 0;
virtual void GetIDispatchPtr( void **pIDispatch ) = 0;
virtual void GetHTMLScroll( int &top, int &left ) = 0;
};
//-----------------------------------------------------------------------------
// Purpose: possible load errors when you open a url in the web browser
//-----------------------------------------------------------------------------
enum EWebPageLoadError
{
eLoadErrorNone = 0,
eMimeTypeNotSupported, // probably trying to download an exe or something
eCacheMiss, // Usually caused by navigating to a page with POST data via back or forward buttons
eBadURL, // bad url passed in (invalid hostname, malformed)
eConnectionProblem, // network connectivity problem, server offline or user not on internet
eProxyConnectionProblem, // User is configured to use proxy, but we can't use it
eLoadErrorUnknown, // not a load type we classify right now, check out cef_handler_errorcode_t for the full list we could translate
};
//-----------------------------------------------------------------------------
// Purpose: basic callback interface for a HTML window
//-----------------------------------------------------------------------------
class IHTMLEvents
{
public:
// unused functions we keep around so the vtable layout is binary compatible
virtual bool Obsolete_OnStartURL(const char *url, const char *target, bool first)=0;
virtual void Obsolete_OnFinishURL(const char *url)=0;
virtual void Obsolete_OnProgressURL(long current, long maximum)=0;
virtual void Obsolete_OnSetStatusText(const char *text) =0;
virtual void Obsolete_OnUpdate() =0;
virtual void Obsolete_OnLink()=0;
virtual void Obsolete_OffLink()=0;
// call backs for events
// when the top level browser is changing the page they are looking at (not sub iframes or the like loading)
virtual void OnURLChanged( const char *url, const char *pchPostData, bool bIsRedirect ) = 0;
// the control has finished loading a request, could be a sub request in the page
virtual void OnFinishRequest( const char *url, const char *pageTitle ) = 0;
// the lower html control wants to load a url, do we allow it?
virtual bool OnStartRequestInternal( const char *url, const char *target, const char *pchPostData, bool bIsRedirect ) = 0;
// show a popup menu for this html control
virtual void ShowPopup( int x, int y, int wide, int tall ) = 0;
// hide any popup menu you are showing
virtual void HidePopup() = 0;
// show an external html window at this position and side
virtual bool OnPopupHTMLWindow( const char *pchURL, int x, int y, int wide, int tall ) = 0;
// the browser is telling us the title it would like us to show
virtual void SetHTMLTitle( const char *pchTitle ) = 0;
// the browser is loading a sub url for a page, usually an image or css
virtual void OnLoadingResource( const char *pchURL ) = 0;
// the browser is telling us the user is hovering a url or the like
virtual void OnSetStatusText(const char *text) =0;
// the browser wants the cursor changed please
virtual void OnSetCursor( vgui::CursorCode cursor ) = 0;
// the browser wants to ask the user to select a local file and tell it about it
virtual void OnFileLoadDialog( const char *pchTitle, const char *pchInitialFile ) = 0;
// show and hide tooltip text
virtual void OnShowToolTip( const char *pchText ) = 0;
virtual void OnUpdateToolTip( const char *pchText ) = 0;
virtual void OnHideToolTip() = 0;
// IE only code
virtual bool BOnCreateNewWindow( void **ppDispatch ) = 0;
virtual void OnLink()=0;
virtual void OffLink()=0;
virtual void OnCloseWindow() = 0;
virtual void OnUpdate() =0;
virtual void OnProgressRequest(long current, long maximum)=0;
// new Chrome calls
virtual bool OnOpenNewTab( const char *pchURL, bool bForeground ) = 0;
};
}
#endif // IHTML_H