Trong quá trình phát triển Android thì mình nhận ra một vấn đề rất lớn của nền tảng mobile có thị phần lớn nhất thế giới đó chính là sự phân mảnh thiết bị, cộng với vô số các kích thước màn hình. Với một newbie thì đây thực sự là cơn ác mộng, đó cũng là lý do các bạn thực tập thường ngại làm với UI/UX.
Vậy thì làm thế nào để có thể hỗ trợ nhiều độ phân giải màn hình cho điện thoại Android, bạn có thể tham khảo bài viết bên dưới nhé.
Bước 1: Tạo file multiscreen.gradle nằm trong thư mục chính của Project
task convertDimens() { def xmlRoot = "${project.rootDir}/app/src/main/res/values" def xmlDimenFileName = "dimens.xml" def xmlFileDefault = xmlRoot + "/" + xmlDimenFileName def xmlFile360 = xmlRoot + "-sw360dp/" + xmlDimenFileName def xmlFile480 = xmlRoot + "-sw480dp/" + xmlDimenFileName def xmlFile540 = xmlRoot + "-sw540dp/" + xmlDimenFileName def xmlFile600 = xmlRoot + "-sw600dp/" + xmlDimenFileName def xmlFile640 = xmlRoot + "-sw640dp/" + xmlDimenFileName def xmlFile720 = xmlRoot + "-sw720dp/" + xmlDimenFileName def xmlFile800 = xmlRoot + "-sw800dp/" + xmlDimenFileName makeFolder(xmlFile360, xmlFile480, xmlFile540, xmlFile600, xmlFile640, xmlFile720, xmlFile800) createOrCloneDefaultData(xmlFileDefault, xmlFile360) def xmlOriginal = new XmlParser().parse(xmlFile360) def xml480 = xmlOriginal.clone() def xml540 = xmlOriginal.clone() def xml600 = xmlOriginal.clone() def xml640 = xmlOriginal.clone() def xml720 = xmlOriginal.clone() def xml800 = xmlOriginal.clone() xml480.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((480 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((480 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } xml540.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((540 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((540 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } xml600.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((600 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((600 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } xml640.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((640 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((640 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } xml720.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((720 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((720 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } xml800.dimen.each { dimen -> def value = dimen.text() if (isSkipCheck(value)) { //skip } else if (value.contains("px")) { def newValue = value.replace("px", "").toFloat() newValue = round((800 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "px" } else { def newValue = value.replace("dp", "").toFloat() newValue = round((800 / 360 * newValue).toFloat(), 1) dimen.value = newValue + "dp" } } new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile480))).print(xml480) new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile540))).print(xml540) new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile600))).print(xml600) new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile640))).print(xml640) new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile720))).print(xml720) new XmlNodePrinter(new PrintWriter(new FileWriter(xmlFile800))).print(xml800) } private static boolean isSkipCheck(String value) { return value.contains("sp") || value.contains("@dimen/") } private static void createOrCloneDefaultData(String xmlFileDefault, String xmlFile360) { def fileDefault = new File(xmlFileDefault) if (!fileDefault.exists()) { fileDefault.createNewFile() StringBuilder content = new StringBuilder("<resources>\n") for (int i = 2; i <= 100; i += 2) { content.append("\t<dimen name=\"dp" + i + "\">" + i + "dp</dimen>\n") } content.append("</resources>") BufferedWriter bw = new BufferedWriter(new FileWriter(xmlFileDefault)) bw.write(content.toString()) bw.close() } def file360 = new File(xmlFile360) if (fileDefault.exists()) { copyFileUsingStream(fileDefault, file360) } } static float round(float d, int decimalPlace) { BigDecimal bd = new BigDecimal(Float.toString(d)) bd = bd.setScale(decimalPlace, BigDecimal.ROUND_HALF_UP) return bd.floatValue() } static void makeFolder(String... paths) { for (int i = 0; i < paths.length; i++) { def folder = new File(new File(paths[i]).getParent()) if (!folder.exists()) { folder.mkdirs() } } } static void copyFileUsingStream(File source, File dest) throws IOException { InputStream is = null OutputStream os = null try { is = new FileInputStream(source) os = new FileOutputStream(dest) byte[] buffer = new byte[1024] int length while ((length = is.read(buffer)) > 0) { os.write(buffer, 0, length) } } finally { if (is != null) { is.close() } if (os != null) { os.close() } } }
Bước 2: Import vào module app
apply from: '../multiscreen.gradle' android { clean.dependsOn convertDimens }
Chúc mừng bạn, việc tích hợp đã hoàn thành!
Kết quả sau khi tích hợp:

Với những giá trị bạn không muốn script can thiệp, bạn có thể bỏ qua bằng cách tạo thêm file fixed_dimens.xml trong folder values là được nha.
Đây là những kinh nghiệm trong quá trình làm việc mà mình và các đồng nghiệp tại tập thể công ty Cổ phần Segu đã tìm ra. Rất mong các bạn ủng hộ.
It s so hard for me personally at this age and stage of my life to pin point what is normal and what could possibly be a side effect priligy canada Sacubitril valsartan improved congestion to a greater extent than did enalapril
Your point of view caught my eye and was very interesting. Thanks. I have a question for you.
I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.
¿Apuestas en casino o apuestas deportivas? ¡Con 1Win,
tienes todo en un única plataforma! Comienza hoy mismo y
disfruta de una experiencia inolvidable.
1win apuestas
Your article helped me a lot, is there any more related content? Thanks!
Your point of view caught my eye and was very interesting. Thanks. I have a question for you.
Your article helped me a lot, is there any more related content? Thanks!
Thank you for your sharing. I am worried that I lack creative ideas. It is your article that makes me full of hope. Thank you. But, I have a question, can you help me?
Can you be more specific about the content of your article? After reading it, I still have some doubts. Hope you can help me.
I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.
I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.
Your article helped me a lot, is there any more related content? Thanks!
Thank you for your sharing. I am worried that I lack creative ideas. It is your article that makes me full of hope. Thank you. But, I have a question, can you help me?
Thanks for sharing. I read many of your blog posts, cool, your blog is very good.
Can you be more specific about the content of your article? After reading it, I still have some doubts. Hope you can help me.
Can you be more specific about the content of your article? After reading it, I still have some doubts. Hope you can help me.
I don’t think the title of your article matches the content lol. Just kidding, mainly because I had some doubts after reading the article.
Your article helped me a lot, is there any more related content? Thanks!
buy priligy generic Interesting to see that it does seem to be an unusual side effect experienced also by others
Can you be more specific about the content of your article? After reading it, I still have some doubts. Hope you can help me.
Thank you for your sharing. I am worried that I lack creative ideas. It is your article that makes me full of hope. Thank you. But, I have a question, can you help me? https://accounts.binance.com/zh-CN/register?ref=VDVEQ78S
Can you be more specific about the content of your article? After reading it, I still have some doubts. Hope you can help me.
Thanks for sharing. I read many of your blog posts, cool, your blog is very good. https://accounts.binance.com/ar/register-person?ref=V2H9AFPY
Získejte přístup k konkurenceschopným kurzům a užijte si bezpečné
prostředí.
Mostbet Colombia – una plataforma líder para juegos de casino en Colombia.
Descarga la app y obtén acceso a estadísticas en tiempo real .
Înscrieți-vă acum și obțineți bonus de bun venit
300€ .
Mostbet Bangladesh ilə idman mərcləri və kazino əyləncəsi Mostbet BD
Бонус алу – өте қарапайым . Мостбет Кз
Odkryj świat emocji z najlepszym bukmacherem
online . Szeroka gama zakładów sportowych przygotowaliśmy dla Ciebie .
Dołącz do naszej społeczności. mostbet logowanie
Aproveite bónus exclusivos e descubra oportunidades de ganhar grandes prêmios.
Mostbet Casino PT
Mostbet KG – коопсуз жана ишенимдүү.
Mostbet kg
MostBet Casino – loistava pelialusta kokeneille pelaajille .
Mostbet Finland
Plateforme de jeux et paris – une expérience unique
pour parier sur les sports . Visitez Mostbet
mostbet hungary
Mostbet bonusları – ideal variantdır
kazino oyunları oynamaq sevənlər üçün.
mostbet promo kod
Mostbet Pakistan – complete platform for sports betting .
Mostbet Chile – soporte al cliente 24/7 .
Mostbet DE – umfangreiches Angebot für Sportwetten .
Мостбет зеркало сегодня – надежный выбор
для ставок на спорт . mostbet вход
Почніть грати та насолоджуйтесь іграми .
Mostbet Україна
Mostbet Türkiye – güncel giriş adresiyle erişilebilir .
लाइव कैसीनो गेम्स का आनंद लें .
mostbet review
Mostbet – konkurrenskraftiga odds .
Mostbet-এ অংশ গ্রহণ করুন – আপনার জীবনের জন্য Mostbet Bangladesh
Mostbet qeydiyyatı – hər kəs üçün əlçatandır .
mostbet az
Mostbet كازينو