स्पंदन - लेखन Android विशिष्ट कोड

स्पंदन मंच विशिष्ट सुविधा का उपयोग करने के लिए एक सामान्य ढांचा प्रदान करता है। यह प्लेटफ़ॉर्म विशिष्ट कोड का उपयोग करके डेवलपर को फ़्लटर फ्रेमवर्क की कार्यक्षमता का विस्तार करने में सक्षम बनाता है । प्लेटफ़ॉर्म विशिष्ट कार्यक्षमता जैसे कैमरा, बैटरी स्तर, ब्राउज़र, आदि को फ्रेमवर्क के माध्यम से आसानी से एक्सेस किया जा सकता है।

प्लेटफ़ॉर्म विशिष्ट कोड तक पहुंचने का सामान्य विचार सरल मैसेजिंग प्रोटोकॉल के माध्यम से है। स्पंदन कोड, क्लाइंट और प्लेटफ़ॉर्म कोड और होस्ट एक आम संदेश चैनल से जुड़ता है। क्लाइंट संदेश चैनल के माध्यम से होस्ट को संदेश भेजता है। संदेश चैनल पर होस्ट सुनता है, संदेश प्राप्त करता है और आवश्यक कार्यक्षमता करता है और अंत में, संदेश चैनल के माध्यम से क्लाइंट को परिणाम देता है।

प्लेटफ़ॉर्म विशिष्ट कोड आर्किटेक्चर नीचे दिए गए ब्लॉक आरेख में दिखाया गया है -

मैसेजिंग प्रोटोकॉल एक मानक संदेश कोडक (StandardMessageCodec वर्ग) का उपयोग करता है जो कि JSON जैसे मूल्यों जैसे कि संख्याओं, तारों, बूलियन, आदि का समर्थन करता है। क्रमांकन और डी-क्रमांकन क्लाइंट और होस्ट के बीच पारदर्शी रूप से काम करता है।

आइए हम एंड्रॉइड एसडीके का उपयोग करके एक ब्राउज़र खोलने के लिए एक सरल एप्लिकेशन लिखें और समझें कि कैसे

  • एंड्रॉइड स्टूडियो में एक नया फ़्लटर एप्लिकेशन बनाएं, flutter_browser_app

  • नीचे दिए गए कोड के साथ main.dart कोड बदलें -

import 'package:flutter/material.dart'; 
void main() => runApp(MyApp()); 
class MyApp extends StatelessWidget { 
   @override 
   Widget build(BuildContext context) {
      return MaterialApp(
         title: 'Flutter Demo', 
         theme: ThemeData( 
            primarySwatch: Colors.blue, 
         ), 
         home: MyHomePage(title: 'Flutter Demo Home Page'),
      );
   }
}
class MyHomePage extends StatelessWidget { 
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
   
   @override 
   Widget build(BuildContext context) {
      return Scaffold(
         appBar: AppBar(
            title: Text(this.title), 
         ), 
         body: Center(
            child: RaisedButton( 
               child: Text('Open Browser'), 
               onPressed: null, 
            ), 
         ), 
      ); 
   }
}
  • यहां, हमने ब्राउज़र खोलने के लिए एक नया बटन बनाया है और इसकी ऑनपेड विधि को शून्य के रूप में सेट किया है।

  • अब, निम्नलिखित पैकेज आयात करें -

import 'dart:async'; 
import 'package:flutter/services.dart';
  • यहाँ, प्लेटफ़ॉर्म विशिष्ट कोड को लागू करने के लिए services.dart में कार्यक्षमता शामिल है।

  • MyHomePage विजेट में एक नया संदेश चैनल बनाएं।

static const platform = const 
MethodChannel('flutterapp.tutorialspoint.com/browser');
  • संदेश चैनल के माध्यम से मंच विशिष्ट विधि, ओपनब्रोसर विधि को लागू करने के लिए एक विधि, _openBrowser लिखें।

Future<void> _openBrowser() async { 
   try {
      final int result = await platform.invokeMethod(
         'openBrowser', <String, String>{ 
            'url': "https://flutter.dev" 
         }
      ); 
   } 
   on PlatformException catch (e) { 
      // Unable to open the browser 
      print(e); 
   }
}

यहां, हमने openBrowser (आने वाले चरणों में समझाया गया है) को लागू करने के लिए platform.invokeMethod का उपयोग किया है। OpenBrowser में एक तर्क है, एक विशिष्ट url खोलने के लिए url।

  • RaisedButton की onPressed प्रॉपर्टी के मूल्य को null से _openBrowser में बदलें।

onPressed: _openBrowser,
  • ओपन मेनएक्टिविटी.जावा (एंड्रॉइड फोल्डर के अंदर) और आवश्यक लाइब्रेरी आयात करें -

import android.app.Activity; 
import android.content.Intent; 
import android.net.Uri; 
import android.os.Bundle; 

import io.flutter.app.FlutterActivity; 
import io.flutter.plugin.common.MethodCall; 
import io.flutter.plugin.common.MethodChannel; 
import io.flutter.plugin.common.MethodChannel.MethodCallHandler; 
import io.flutter.plugin.common.MethodChannel.Result; 
import io.flutter.plugins.GeneratedPluginRegistrant;
  • ब्राउज़र को खोलने के लिए एक विधि, ओपनब्रोसर लिखें

private void openBrowser(MethodCall call, Result result, String url) { 
   Activity activity = this; 
   if (activity == null) { 
      result.error("ACTIVITY_NOT_AVAILABLE", 
      "Browser cannot be opened without foreground 
      activity", null); 
      return; 
   } 
   Intent intent = new Intent(Intent.ACTION_VIEW); 
   intent.setData(Uri.parse(url)); 
   
   activity.startActivity(intent); 
   result.success((Object) true); 
}
  • अब, MainActivity class में चैनल का नाम सेट करें -

private static final String CHANNEL = "flutterapp.tutorialspoint.com/browser";
  • OnCreate पद्धति में संदेश हैंडलिंग सेट करने के लिए Android विशिष्ट कोड लिखें -

new MethodChannel(getFlutterView(), CHANNEL).setMethodCallHandler( 
   new MethodCallHandler() { 
   @Override 
   public void onMethodCall(MethodCall call, Result result) { 
      String url = call.argument("url"); 
      if (call.method.equals("openBrowser")) {
         openBrowser(call, result, url); 
      } else { 
         result.notImplemented(); 
      } 
   } 
});

यहाँ, हमने मेसेजचैन क्लास का उपयोग करके एक संदेश चैनल बनाया है और मैसेज को संभालने के लिए मेथडकैन्डलर क्लास का उपयोग किया है। onMethodCall वास्तविक विधि है जो संदेश की जाँच करके सही प्लेटफ़ॉर्म विशिष्ट कोड को कॉल करने के लिए जिम्मेदार है। onMethodCall मेथड से url को मैसेज से निकालता है और फिर ओपनब्रोसर को तभी इनवाइट करता है जब मेथड कॉल ओपनरब्राउजर हो। अन्यथा, यह लागू विधि वापस लौटाता है।

आवेदन का पूरा स्रोत कोड इस प्रकार है -

main.dart

MainActivity.java

package com.tutorialspoint.flutterapp.flutter_browser_app; 

import android.app.Activity; 
import android.content.Intent; 
import android.net.Uri; 
import android.os.Bundle; 
import io.flutter.app.FlutterActivity; 
import io.flutter.plugin.common.MethodCall; 
import io.flutter.plugin.common.MethodChannel.Result; 
import io.flutter.plugins.GeneratedPluginRegistrant; 

public class MainActivity extends FlutterActivity { 
   private static final String CHANNEL = "flutterapp.tutorialspoint.com/browser"; 
   @Override 
   protected void onCreate(Bundle savedInstanceState) { 
      super.onCreate(savedInstanceState); 
      GeneratedPluginRegistrant.registerWith(this); 
      new MethodChannel(getFlutterView(), CHANNEL).setMethodCallHandler(
         new MethodCallHandler() {
            @Override 
            public void onMethodCall(MethodCall call, Result result) {
               String url = call.argument("url"); 
               if (call.method.equals("openBrowser")) { 
                  openBrowser(call, result, url); 
               } else { 
                  result.notImplemented(); 
               }
            }
         }
      ); 
   }
   private void openBrowser(MethodCall call, Result result, String url) {
      Activity activity = this; if (activity == null) {
         result.error(
            "ACTIVITY_NOT_AVAILABLE", "Browser cannot be opened without foreground activity", null
         ); 
         return; 
      } 
      Intent intent = new Intent(Intent.ACTION_VIEW); 
      intent.setData(Uri.parse(url)); 
      activity.startActivity(intent); 
      result.success((Object) true); 
   }
}

main.dart

import 'package:flutter/material.dart'; 
import 'dart:async'; 
import 'package:flutter/services.dart'; 

void main() => runApp(MyApp()); 
class MyApp extends StatelessWidget {
   @override 
   Widget build(BuildContext context) {
      return MaterialApp(
         title: 'Flutter Demo', 
         theme: ThemeData( 
            primarySwatch: Colors.blue, 
         ), 
         home: MyHomePage(
            title: 'Flutter Demo Home Page'
         ), 
      ); 
   }
}
class MyHomePage extends StatelessWidget {
   MyHomePage({Key key, this.title}) : super(key: key); 
   final String title; 
   static const platform = const MethodChannel('flutterapp.tutorialspoint.com/browser'); 
   Future<void> _openBrowser() async {
      try {
         final int result = await platform.invokeMethod('openBrowser', <String, String>{ 
            'url': "https://flutter.dev" 
         });
      }
      on PlatformException catch (e) { 
         // Unable to open the browser print(e); 
      } 
   }
   @override 
   Widget build(BuildContext context) {
      return Scaffold( 
         appBar: AppBar( 
            title: Text(this.title), 
         ), 
         body: Center(
            child: RaisedButton( 
               child: Text('Open Browser'), 
               onPressed: _openBrowser, 
            ), 
         ),
      );
   }
}

एप्लिकेशन चलाएं और ओपन ब्राउज़र बटन पर क्लिक करें और आप देख सकते हैं कि ब्राउज़र लॉन्च हो गया है। ब्राउज़र ऐप - होम पेज को यहाँ स्क्रीनशॉट में दिखाया गया है -