|
43 | 43 | { |
44 | 44 | "definition": "অর্গানাইজেশন/প্রতিষ্ঠানের নাম সেট করতে", |
45 | 45 | "code": "flutter create --org com.yourorg your_project" |
| 46 | + }, |
| 47 | + { |
| 48 | + "definition": "প্রোজেক্ট টেম্পলেট সেট করতে", |
| 49 | + "code": "flutter create --template=(app|package|plugin|module) <project_name>" |
| 50 | + }, |
| 51 | + { |
| 52 | + "definition": "পূর্বে এক্সপোর্টকৃত ফাইলসমূহ ডিলিট করতে", |
| 53 | + "code": "flutter clean" |
46 | 54 | } |
47 | 55 | ] |
48 | 56 | }, |
|
143 | 151 | "code": "”fvm flutter pub get”, “fvm flutter run”" |
144 | 152 | }, |
145 | 153 | { |
| 154 | + "definition": "FVM ভার্সন ^3.0.0 আপগ্রেড", |
| 155 | + "code": "FVM এর নতুন ভার্সনগুলোতে বেশ কিছু চেইঞ্জ এসেছে। \n প্রথমেই প্রজেক্টের টার্মিনালে dart pub global activate fvm রান করুন। এতে আপনার মেশিনের FVM, লেটেস্ট ভার্সনে আপডেট হয়ে যাবে।" |
| 156 | + }, |
| 157 | + { |
| 158 | + "definition": "FVM v^3.0.0 এর কনফিগ", |
| 159 | + "code": "ভার্সন ^3.0.0 এর পর থেকে আগের .fvm ফোল্ডারটির সাথেসাথে প্রজেক্টের রুট-এ .fvmrc ফাইল তৈরি হবে। এতে প্রোজেক্ট স্পেসিফিক কনফিগারেশনের ইনফরমেশন থাকবে।" |
| 160 | + }, |
| 161 | + { |
| 162 | + "definition": "FVM v^3.0.0 এর সুবিধা", |
| 163 | + "code": "ভার্সন ^3.0.0 এর থেকে, ফ্লাটারের ব্যাসিক কমান্ডগুলোর জন্য আগের মতো শুরুতে fvm ব্যবহার না করলেও হবে। \n আগে: fvm flutter pub get \n এখন: flutter pub get" |
| 164 | + }, |
| 165 | + { |
146 | 166 | "definition": "অফিসিয়াল সাইট", |
147 | 167 | "code": "https://fvm.app" |
148 | 168 | } |
|
330 | 350 | "code": "flutter gen-l10n" |
331 | 351 | } |
332 | 352 | ] |
333 | | - }, |
| 353 | + }, |
| 354 | + { |
| 355 | + "title": "ফ্লাটার WebRTC (Implementing WebRTC in Flutter)", |
| 356 | + "items": [ |
| 357 | + { |
| 358 | + "definition": "WebRTC কি?", |
| 359 | + "code": "WebRTC হলো একটি ফ্রি এবং ওপেন সোর্স প্রজেক্ট। এটা দিয়ে খুব সহজেই, কোনো সার্ভার ছাড়াই ওয়েব ব্রাউজার বা মোবাইল অ্যাপে অডিও, ভিডিও কলের মতো রিয়েল টাইম কম্যুনিকেশন সেট করা যায়।" |
| 360 | + }, |
| 361 | + { |
| 362 | + "definition": "WebRTC কানেকশনের ব্যাসিক আইডিয়া", |
| 363 | + "code": "WebRTC কনেকশনে ২টা peer (ডিভাইস) থাকে। একটা ইনিশিয়েটর(কল করে), অন্যটা রিসিভার(কল রিসিভ করে)। এই দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি হতে হলে, উভয়ের ডিটেইলস(SDP, Ice Candidates) একে অন্যের কাছে পাঠাতে হবে। এইটাকে Signaling বলে।" |
| 364 | + }, |
| 365 | + { |
| 366 | + "definition": "SDP (Session Description Protocol) কি?", |
| 367 | + "code": "সহজ ভাষায় SDP হলো একটি অবজেক্ট, যার ভিতরে দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি করার জন্য প্রয়োজনীয় সব ইনফরমেশন থাকে।" |
| 368 | + }, |
| 369 | + { |
| 370 | + "definition": "ICE (Interactive Connectivity Establishment) কি?", |
| 371 | + "code": "ICE হলো একটি প্রোটোকল, যার মাধ্যমে দুইটা ডিভাইসের মধ্যে কানেকশন তৈরি করা হয়।" |
| 372 | + }, |
| 373 | + { |
| 374 | + "definition": "STUN (Session Traversal Utilities for NAT) কি?", |
| 375 | + "code": "দুইটা ডিভাইসের পাবলিক IP খুজে বের করার জন্য STUN সার্ভার ব্যবহার করা হয়।" |
| 376 | + }, |
| 377 | + { |
| 378 | + "definition": "TURN (Traversal Using Relays around NAT) কি?", |
| 379 | + "code": "খুব সিকিউর কানেকশনে পাবলিক IP খুজে বের করার জন্য TURN সার্ভার ব্যবহার করা হয়।" |
| 380 | + }, |
| 381 | + { |
| 382 | + "definition": "ফ্লাটারে কিভাবে WebRTC ইমপ্লিমেন্ট করবেন?", |
| 383 | + "code": "নেটিভ API ব্যবহার করে অথবা, Agora / ZegoCloud এর মতো বিল্টইন সলিউশন ব্যাবহার করে ফ্লাটারে WebRTC ইমপ্লিমেন্ট করা যায়।" |
| 384 | + }, |
| 385 | + { |
| 386 | + "definition": "নেটিভ API ব্যবহার করে WebRTC ডিপেন্ডেন্সি যোগ করতে -", |
| 387 | + "code": "dependencies:\n flutter_webrtc: ^0.11.7" |
| 388 | + }, |
| 389 | + { |
| 390 | + "definition": "androidmanifest.xml এ প্রয়োজনীয় পারমিশন যোগ করুন (Android)", |
| 391 | + "code": "<uses-feature android:name=\"android.hardware.camera\" />\n<uses-feature android:name=\"android.hardware.camera.autofocus\" />\n<uses-permission android:name=\"android.permission.CAMERA\" />\n<uses-permission android:name=\"android.permission.RECORD_AUDIO\" />\n<uses-permission android:name=\"android.permission.ACCESS_NETWORK_STATE\" />\n<uses-permission android:name=\"android.permission.CHANGE_NETWORK_STATE\" />\n<uses-permission android:name=\"android.permission.MODIFY_AUDIO_SETTINGS\" />" |
| 392 | + }, |
| 393 | + { |
| 394 | + "definition": "প্রয়োজনীয় পারমিশন যোগ করুন (iOS)", |
| 395 | + "code": "<key>NSCameraUsageDescription</key>\n<string>Camera permission description</string>\n<key>NSMicrophoneUsageDescription</key>\n<string>Microphone permission description</string>" |
| 396 | + }, |
| 397 | + { |
| 398 | + "definition": "RTCPeerConnection তৈরি করুন", |
| 399 | + "code": "final Map<String, dynamic> configuration = {\n 'iceServers': [\n {'urls': 'stun:stun.l.google.com:19302'},\n ]\n};\nfinal pc = await createPeerConnection(configuration);" |
| 400 | + }, |
| 401 | + { |
| 402 | + "definition": "লোকাল মিডিয়া স্ট্রিম যোগ করুন", |
| 403 | + "code": "final Map<String, dynamic> mediaConstraints = {\n 'audio': true,\n 'video': {\n 'facingMode': 'user',\n }\n};\nMediaStream stream = await navigator.mediaDevices.getUserMedia(mediaConstraints);\nawait pc.addStream(stream);" |
| 404 | + }, |
| 405 | + { |
| 406 | + "definition": "Offer তৈরি করুন", |
| 407 | + "code": "RTCSessionDescription offer = await pc.createOffer();\nawait pc.setLocalDescription(offer);\n// Send this offer to the remote peer via your signaling server" |
| 408 | + }, |
| 409 | + { |
| 410 | + "definition": "Answer রিসিভ করুন", |
| 411 | + "code": "// Assume 'answer' is received from the remote peer\nawait pc.setRemoteDescription(answer);" |
| 412 | + }, |
| 413 | + { |
| 414 | + "definition": "ICE Candidate পাঠান", |
| 415 | + "code": "pc.onIceCandidate = (candidate) {\n // Send this candidate to the remote peer via your signaling server\n};" |
| 416 | + }, |
| 417 | + { |
| 418 | + "definition": "রিমোট স্ট্রিম রিসিভ করুন", |
| 419 | + "code": "pc.onAddStream = (stream) {\n // Use this stream to display video/play audio from remote peer\n};" |
| 420 | + }, |
| 421 | + { |
| 422 | + "definition": "কানেকশন বন্ধ করুন", |
| 423 | + "code": "await pc.close();\nawait stream.dispose();" |
| 424 | + }, |
| 425 | + { |
| 426 | + "definition": "WebRTC ডিবাগিং", |
| 427 | + "code": "// Enable debug logging\nwebrtc.debugger.enabled = true;\n\n// For more detailed logging\nwebrtc.debugger.onEvent.listen((e) {\n print(e);\n});" |
| 428 | + }, |
| 429 | + { |
| 430 | + "definition": "WebRTC শেখার কিছু রিসোর্স", |
| 431 | + "code": "https://webrtc.org\nhttps://codelabs.developers.google.com/codelabs/webrtc-web\nhttps://www.w3.org/TR/webrtc\n\nhttps://pub.dev/packages/flutter_webrtc" |
| 432 | + } |
| 433 | + ] |
| 434 | + }, |
| 435 | + { |
| 436 | + "title": "Flutter টেস্টিং (Flutter Testing)", |
| 437 | + "items": [ |
| 438 | + { |
| 439 | + "definition": "ফ্লাটারে ৩ ধরনের টেস্ট রান করা যায়", |
| 440 | + "code": "১. ইউনিট টেস্ট (Unit Test)\n২. উইজেট টেস্ট (Widget Test)\n৩. ইন্টিগ্রেশন টেস্ট (Integration Test)" |
| 441 | + }, |
| 442 | + { |
| 443 | + "definition": "Unit Test কি?", |
| 444 | + "code": "কোনো একটা ফাংশন, মেথড বা ক্লাস টেস্ট করার জন্য ইউনিট টেস্ট ব্যবহার করা হয়।" |
| 445 | + }, |
| 446 | + { |
| 447 | + "definition": "Widget Test কি?", |
| 448 | + "code": "উইজেট টেস্টিং হলো নির্দিষ্ট উইজেট বা উইজেটের কোনো পার্ট টেস্ট করা।" |
| 449 | + }, |
| 450 | + { |
| 451 | + "definition": "Integration Test কি?", |
| 452 | + "code": "ইন্টিগ্রেশন টেস্টিং এর মাধ্যমে একটি এপের কমপ্লিট ফাংশনালিটি টেস্ট করা হয়। একে এন্ড টু এন্ড টেস্টও বলা হয়।" |
| 453 | + }, |
| 454 | + { |
| 455 | + "definition": "টেস্টিং রিলেটেড প্যাকেজ যোগ করতে -", |
| 456 | + "code": "dev_dependencies:\n flutter_test:\n sdk: flutter\n integration_test:\n sdk: flutter\n mockito: ^5.0.0" |
| 457 | + }, |
| 458 | + { |
| 459 | + "definition": "ইউনিট টেস্ট রান করতে -", |
| 460 | + "code": "flutter test test/unit_test.dart" |
| 461 | + }, |
| 462 | + { |
| 463 | + "definition": "উইজেট টেস্ট রান করতে -", |
| 464 | + "code": "flutter test test/widget_test.dart" |
| 465 | + }, |
| 466 | + { |
| 467 | + "definition": "ইন্টিগ্রেশন টেস্ট রান করতে -", |
| 468 | + "code": "flutter test integration_test/app_test.dart" |
| 469 | + }, |
| 470 | + { |
| 471 | + "definition": "সকল টেস্ট রান করতে -", |
| 472 | + "code": "flutter test" |
| 473 | + }, |
| 474 | + { |
| 475 | + "definition": "ইউনিট টেস্ট উদাহরণ", |
| 476 | + "code": "void main() {\n test('String.split() splits the string on the delimiter', () {\n var string = 'foo,bar,baz';\n expect(string.split(','), equals(['foo', 'bar', 'baz']));\n });\n}" |
| 477 | + }, |
| 478 | + { |
| 479 | + "definition": "উইজেট টেস্ট উদাহরণ", |
| 480 | + "code": "void main() {\n testWidgets('MyWidget has a title and message', (WidgetTester tester) async {\n await tester.pumpWidget(MyWidget(title: 'T', message: 'M'));\n final titleFinder = find.text('T');\n final messageFinder = find.text('M');\n expect(titleFinder, findsOneWidget);\n expect(messageFinder, findsOneWidget);\n });\n}" |
| 481 | + }, |
| 482 | + { |
| 483 | + "definition": "ইন্টিগ্রেশন টেস্ট উদাহরণ", |
| 484 | + "code": "void main() {\n IntegrationTestWidgetsFlutterBinding.ensureInitialized();\n testWidgets('tap on the floating action button, verify counter',\n (WidgetTester tester) async {\n app.main();\n await tester.pumpAndSettle();\n expect(find.text('0'), findsOneWidget);\n final Finder fab = find.byTooltip('Increment');\n await tester.tap(fab);\n await tester.pumpAndSettle();\n expect(find.text('1'), findsOneWidget);\n });\n}" |
| 485 | + }, |
| 486 | + { |
| 487 | + "definition": "মক অবজেক্ট তৈরি করেন (Mockito ব্যবহার করে)", |
| 488 | + "code": "import 'package:mockito/mockito.dart';\n\nclass MockYourClass extends Mock implements YourClass {}\n\nvoid main() {\n final mock = MockYourClass();\n when(mock.someMethod()).thenReturn('mocked value');\n}" |
| 489 | + }, |
| 490 | + { |
| 491 | + "definition": "টেস্ট কভারেজ রিপোর্ট জেনারেট করেন", |
| 492 | + "code": "flutter test --coverage\n# কভারেজ রিপোর্ট coverage/lcov.info ফাইলে জেনারেট হবে\n# HTML রিপোর্ট জেনারেট করতে lcov ইনস্টল করেন এবং নিচের কমান্ড চালান:\n# genhtml coverage/lcov.info -o coverage/html" |
| 493 | + } |
| 494 | + ] |
| 495 | + }, |
334 | 496 | { |
335 | 497 | "title": "কিছু ইম্পরট্যান্ট ফ্লাটার শীট", |
336 | 498 | "items": [ |
|
0 commit comments