mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-08 07:41:04 +01:00
7d3bac19a9
- Implement support for transparency. Change the backing store to use Skia instead of GDI and to keep alpha values. - Implement support for select popups. Requires a patch to Chromium (content_popups.patch). - Implicitly disable accelerated compositing when using off-screen rendering. - Introduce a new CefMouseEvent structure for representing mouse event information passed to CefBrowser methods. - Merge cef_key_event_modifiers_t into cef_event_flags_t. - Add a new argument to CefBrowser::Invalidate telling the browser whether to invalidate the select popup or the main view. - Add a new cefclient "transparent-painting-enabled" command-line flag to test transparent off-screen rendering. - Add a new cefclient "Transparency" test. - Fix the cefclient off-screen rendering rotation effect to work even when the underlying web content is not updating. - Add unit tests for transparent painting and select popups. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@979 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
67 lines
1.9 KiB
C++
67 lines
1.9 KiB
C++
// Copyright (c) 2008-2009 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
// can be found in the LICENSE file.
|
|
|
|
#include "cefclient/resource_util.h"
|
|
#include "include/cef_stream.h"
|
|
#include "include/wrapper/cef_byte_read_handler.h"
|
|
#include "cefclient/util.h"
|
|
|
|
#if defined(OS_WIN)
|
|
|
|
bool LoadBinaryResource(int binaryId, DWORD &dwSize, LPBYTE &pBytes) {
|
|
extern HINSTANCE hInst;
|
|
HRSRC hRes = FindResource(hInst, MAKEINTRESOURCE(binaryId),
|
|
MAKEINTRESOURCE(256));
|
|
if (hRes) {
|
|
HGLOBAL hGlob = LoadResource(hInst, hRes);
|
|
if (hGlob) {
|
|
dwSize = SizeofResource(hInst, hRes);
|
|
pBytes = (LPBYTE)LockResource(hGlob);
|
|
if (dwSize > 0 && pBytes)
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
CefRefPtr<CefStreamReader> GetBinaryResourceReader(int binaryId) {
|
|
DWORD dwSize;
|
|
LPBYTE pBytes;
|
|
|
|
if (LoadBinaryResource(binaryId, dwSize, pBytes)) {
|
|
return CefStreamReader::CreateForHandler(
|
|
new CefByteReadHandler(pBytes, dwSize, NULL));
|
|
}
|
|
|
|
ASSERT(FALSE); // The resource should be found.
|
|
return NULL;
|
|
}
|
|
|
|
CefRefPtr<CefStreamReader> GetBinaryResourceReader(const char* resource_name) {
|
|
// Map of resource labels to BINARY id values.
|
|
static struct _resource_map {
|
|
char* name;
|
|
int id;
|
|
} resource_map[] = {
|
|
{"binding.html", IDS_BINDING},
|
|
{"dialogs.html", IDS_DIALOGS},
|
|
{"domaccess.html", IDS_DOMACCESS},
|
|
{"localstorage.html", IDS_LOCALSTORAGE},
|
|
{"performance.html", IDS_PERFORMANCE},
|
|
{"transparency.html", IDS_TRANSPARENCY},
|
|
{"xmlhttprequest.html", IDS_XMLHTTPREQUEST},
|
|
};
|
|
|
|
for (int i = 0; i < sizeof(resource_map)/sizeof(_resource_map); ++i) {
|
|
if (!strcmp(resource_map[i].name, resource_name))
|
|
return GetBinaryResourceReader(resource_map[i].id);
|
|
}
|
|
|
|
ASSERT(FALSE); // The resource should be found.
|
|
return NULL;
|
|
}
|
|
|
|
#endif // OS_WIN
|