Python - 在应用内显示网页浏览器/iframe

5 投票
2 回答
8827 浏览
提问于 2025-04-17 21:23

我有一个脚本,主要是为了帮助那些回答问题的人,它使用的是kivy这个工具。我希望在运行这个脚本时,能直接在里面显示一个类似iframe的东西,而不是打开浏览器。比如像这样:

def browser():
    url = "google.com"
    iframe(url)
browser()

显然,这样做是行不通的,因为Python不是HTML。请记住,我并不是想在网上运行这个脚本,而是想在kivy启动器上运行。按照我的想法,它应该不打开网页浏览器,而是直接在脚本里显示一个框,里面放着网页内容。

2 个回答

3

你是在安卓设备上尝试这样做吗?目前没有内置的方法可以做到这一点,但我相信可以通过pyjnius加载一个原生的安卓网页视图。我不太确定现在的情况,但比如说这里有一个示例,展示了怎么做。我在下面粘贴了一些代码,但我建议如果你有任何问题,可以去kivy的邮件列表或者IRC问问,因为这类事情正在讨论和开发中。

from android.runnable import run_on_ui_thread

WebView = autoclass('android.webkit.WebView')
LayoutParams = autoclass('android.view.ViewGroup$LayoutParams')
activity = autoclass('org.renpy.android.PythonActivity').mActivity

class Wv(Widget):
    def __init__(self, **kwargs):
        super(Wv, self).__init__(**kwargs)
        self.create_webview()

    @run_on_ui_thread
    def create_webview(self):
        webview = WebView(activity)
        activity.addContentView(webview, LayoutParams(-1, -1))
        webview.getSettings().setJavaScriptEnabled(True)
        #having some trouble with this one: webview.setBackgroundColor(Color.TRANSPARENT)

        html = "<html><body style='margin:0;padding:0;'>\
            <script type='text/javascript'\
            src='http://ad.leadboltads.net/show_app_ad.js?section_id=ID_HERE'>\
            </script></body></html>"    

        activity.setContentView(webview)
        webview.loadData(html, "text/html", "utf-8")
        layout = LinearLayout(activity)
        layout.addView(activity.mView)
        activity.setContentView(layout)
7

这里有一个实际运行的例子,可以直接在“Kivy Launcher”应用里使用:

import kivy                                                                                     
from kivy.app import App                                                                        
from kivy.lang import Builder                                                                   
from kivy.utils import platform                                                                 
from kivy.uix.widget import Widget                                                              
from kivy.clock import Clock                                                                    
from jnius import autoclass                                                                     
from android.runnable import run_on_ui_thread                                                   

WebView = autoclass('android.webkit.WebView')                                                   
WebViewClient = autoclass('android.webkit.WebViewClient')                                       
activity = autoclass('org.renpy.android.PythonActivity').mActivity                              

class Wv(Widget):                                                                               
    def __init__(self, **kwargs):                                                               
        super(Wv, self).__init__(**kwargs)                                                      
        Clock.schedule_once(self.create_webview, 0)                                             

    @run_on_ui_thread                                                                           
    def create_webview(self, *args):                                                            
        webview = WebView(activity)                                                             
        webview.getSettings().setJavaScriptEnabled(True)                                        
        wvc = WebViewClient();                                                                  
        webview.setWebViewClient(wvc);                                                          
        activity.setContentView(webview)                                                        
        webview.loadUrl('http://www.google.com')

class ServiceApp(App):                                                                          
    def build(self):                                                                            
        return Wv()                                                                             

if __name__ == '__main__':                                                                      
    ServiceApp().run()

撰写回答