THẢO LUẬN

Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 4:20 SA

@bacode mình viết nhầm k với n ở vài chỗ. mình mới sửa lại rồi rồi.

0
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 4:15 SA

@NgHoang mình chưa hiểu đoạn xử lý trong mọi trường hợp lắm.

0

Rất đáng để học tập

0
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 3:46 SA

@NgHoang đoạn dưới mình chưa hiểu n với k lắm. Bạn muốn chia ra slide 1 thì 1 bài, slide 2 thì 2 bài, slide 3 thì 3 bài, ..., slide thứ k thì có k bài. Suy ra trong một cụm k slide liên tiếp thì có tổng cộng n ∗ ( n + 1 ) 2 2 n∗(n+1) ​ bài.

0
thg 10 5, 2020 3:44 SA

@thanhnam4698 bajn có thể tìm hiểu thư viện này: DocumentFormat.OpenXml.Wordprocessing

0
thg 10 5, 2020 3:14 SA

Cảm ơn anh. Nâng cao hơn 1 chút thì theo như những gì e tìm hiểu thì một đoạn trong word sẽ được biểu diễn trong thẻ <w:p></w:p>., bên trong sẽ có chứa các thẻ <w:r></w:r>. Vậy thì mình có cách nào để truy cập vào từng thẻ <w:r> k ạ

0

Bạn mò theo đường dẫn này, để vào file gradle-wrapper.properties sửa con số 5.6.2 thành 6.6 hoặc 6.6.1

Screen Shot 2020-10-05 at 10.03.19.png

0

Íntall java15 như link bạn cho. Vẫn báo lỗi. Lần này hơi khác 1 chút.

6039249C-E3DD-4F68-939E-9EABAC3199D9.jpeg

0
thg 10 5, 2020 2:45 SA

mình góp ý chút : bạn nên để lại link của bài trước và bài sau của mỗi bài học

0
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 2:29 SA

@bacode thư viện có sẵn thì mình không biết, bạn thử Google xem. Còn ý tưởng thì bạn có thể làm theo hướng này:

  • Mảng của bạn có n bài.
  • Bạn muốn chia ra slide 1 thì 1 bài, slide 2 thì 2 bài, slide 3 thì 3 bài. Suy ra trong một cụm 3 slide liên tiếp thì có tổng cộng 6 bài.

Bạn lấy n chia cho 6 sẽ ra số cụm 3 bài liên tiếp là:

  • Chia hết thì số slide là: [n6]3[\frac{n}{6}] * 3 (kí hiệu [n6][\frac{n}{6}] là ám chỉ lấy phần nguyên của phép chia n6\frac{n}{6})
  • Chia dư 1 thì số slide là: [n6]3+1[\frac{n}{6}] * 3 + 1 (vì dư 1 bài cuối sẽ cần 1 slide nữa cho bài này)
  • Chia dư 2 thì số slide là: [n6]3+1+1[\frac{n}{6}] * 3 + 1 + 1 (Cần thêm 1 + 1 = 2 slide. Vì dư 2 bài, nhưng slide tiếp theo sau cụm n63\frac{n}{6} * 3 slide kia chỉ chứa được 1 bài, vẫn còn bài thứ 2 phải nhét vào slide tiếp nữa). Bạn cũng có thể quy định trường hợp này thì sẽ nhét chung vào 1 slide thay vì chia đơn ra thành 2 slide.
  • ....

Cứ thế xét các trường hợp số dư thôi. Tất nhiên cách này có hạn chế là nếu bạn muốn slide 1 bài rồi tới slide 2 bài rồi 3 bài rồi 4 bài ... thì xét trường hợp sẽ rất cực.

Ví dụ trên cho bạn dễ hiểu, để đơn giản hơn trong mọi trường hợp thì bạn có thể dùng cách dưới:

  • mảng của bạn có n bài
  • Bạn muốn chia ra slide 1 thì 1 bài, slide 2 thì 2 bài, slide 3 thì 3 bài, ..., slide thứ k thì có k bài. Suy ra trong một cụm k slide liên tiếp thì có tổng cộng k(k+1)2\frac{k*(k+1)}{2} bài.
  • Và trong trường hợp trên thì một slide bất kì sẽ chứa nhiều nhất là k bài.

Bạn vẫn lấy n chia cho k(k+1)2\frac{k*(k+1)}{2}, nhưng lần này chỉ xét 2 trường hợp:

  • Nếu số dư của phép chia trên mà bé hơn k thì bạn nhét hết chúng vào 1 slide luôn. Nên sẽ có ([n:k(k+1)2]k)+1([n : \frac{k*(k+1)}{2}] * k) + 1 slide. (kí hiệu [n:k(k+1)2][n : \frac{k*(k+1)}{2}] là ám chỉ lấy phần nguyên của phép chia n:k(k+1)2n : \frac{k*(k+1)}{2})
  • Nếu số dư của phép chia trên (kí hiệu là là SD) mà lớn hơn k thì phần dư bạn chia ra thành 2 slide, slide đầu sẽ chứa k bài trong phần dư, phần còn lại là (SD - k) bài thì nhét nốt vào 1 slide nữa. Vậy sẽ có ([n:k(k+1)2]k)+2([n : \frac{k*(k+1)}{2}] * k) + 2 slide.

Cách này có thể áp dụng trong mọi trường hợp của k vì ta chỉ cần xét 2 trường hợp con thôi. Và nếu số bài của bạn nhiều thì việc nhét không theo thứ tự kia vào cuối cùng thì cũng chả ảnh hưởng lắm đến trải nghiệm người dùng, người ta cũng ít khi kéo xuống dưới cùng lắm.

+1

Bạn đang nhắc đến đoạn nào vậy nhỉ. Vì mình thay source của bạn vào source của mình nó vẫn chạy ngon lành mà 😄

import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  
  Widget build(BuildContext context) {
    return MaterialApp(
      // trong constructor của MyHomePage truyền thêm param myChild
      home: MyHomePage(myChild: MyCenterWidget()),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({this.myChild}); // thêm dòng này

  final Widget myChild; // thêm dòng này

  
  MyHomePageState createState() => MyHomePageState();
}

class MyHomePageState extends State<MyHomePage> {
  int counter = 0;
  
  Widget build(BuildContext context) {
    return Scaffold(
      body: MyInheritedWidget(
        child: MyText(), // Dùng MyText thay cho MyCenterWidget
        myData: counter,
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          setState(() {
            counter++;
          });
        },
        child: Icon(Icons.add),
      ),
    );
  }
}

class MyCenterWidget extends StatelessWidget {
  
  Widget build(BuildContext context) {
    print('2. log build MyCenterWidget');
    return Center(
      child: MyText(),
    );
  }
}

class MyText extends StatelessWidget {
  
  Widget build(BuildContext context) {
    final counter = MyInheritedWidget.of(context).myData;
    print('3. log build MyText với counter = $counter');
    return Text('Tui là widget Text. Data của tui hiện tại là: $counter');
  }
}

class MyInheritedWidget extends InheritedWidget {
  MyInheritedWidget({Widget child, this.myData}) : super(child: child);

  final int myData;

  
  bool updateShouldNotify(MyInheritedWidget oldWidget) {
    return myData !=
        oldWidget
            .myData; // nếu data thay đổi thì return true để rebuild các widget con phụ thuộc
  }

  static MyInheritedWidget of(BuildContext context) {
    return context.dependOnInheritedWidgetOfExactType<MyInheritedWidget>();
  }
}
0
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 1:42 SA

@NgHoang làm sao mà biết đc có bnhieu slide con nhỉ? với có thư viện nào hỗ trợ cho việc cútom để tính toán kiểu ý ko b?

0

Have a good day.

Mất rất nhìu time để install AS, flutter, dart trên macbook. Cài đặt device màn hình ảo cho phone. Chỉ định PATH cho flutter SDK path... cuối cùng run main.dart mẫu ra thông báo lỗi này. Hic!

Bạn cho hỏi thông báo lỗi này nói gì và cách sửa nó. Tks

C79EAAB5-56B4-4C92-931F-E2A322008F1E.jpeg

+1
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 5, 2020 1:30 SA

@bacode Bạn lấy thứ tự của div slide con ra. nếu thứ tự (ví dụ tính từ 0) chia hết cho 3 thì là 1 bài, chia 3 dư 1 thì là 2 bài, chia 3 dư 2 thì là 3 bài.

0

Cho mình hỏi, Ở đoạn này mình sẽ đặt như thế này thì nó sẽ sai vì sao???

class MyHomePageState extends State<MyHomePage> { int counter = 0;

@override Widget build(BuildContext context) { return Scaffold( body: MyInheritedWidget( child: MyText(), // Dùng MyText thay cho MyCenterWidget myData: counter, ), floatingActionButton: FloatingActionButton( onPressed: () { setState(() { counter++; }); }, child: Icon(Icons.add), ), ); } }

+1

Nai xừ. Mình cũng đang rơi vào vòng luẩn quẩn, có thời gian, nhưng không biết tận dụng sao cho hợp lý 😦

0
Avatar
đã bình luận câu trả lời trong câu hỏi
thg 10 4, 2020 3:52 CH

@NgHoang api là 1 mảng chứa nhiều bài viết. Thì điều kiện sẽ check như nào để chia ra ví dụ slide đầu tiên 1 bài, slide tiếp 2 bài, tiếp theo 3 bài,... r lại lặp lại?

0
thg 10 4, 2020 3:07 CH

bài viết hay quá, cảm ơn tác giả nhiều

0
Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí