`
wu.sheng
  • 浏览: 67019 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Android UI入门 (非常用方式,类HTML页面展现技术探索)

阅读更多

     开始的时候,要首先声明一下,这边文章,是一个以扫除开发技术障碍为目标的学习经验。并不适合正统的Android UI功能开发。我们知道,正统的页面开发,会使用layout的xml描述页面、自动生成类R来完成资源定位。能够给我们的UI开发带来强大的功能,也符合MVC的开发模式。而我现在要做的,是让页面生成、布局、内容显示、事件都用Java代码来完成。这样的目的其实也很明显,想通过自己的框架代码控制UI显示,可以用于服务端配置控制客户端显示,完成类似HTML的功能。

     首先,根据常规,我们建立ActivityMain的主Activity。

     然后,可以通过下面的代码的方式,设置UI控件;进行页面布局;利用反射进行事件绑定。

package org.studio.crusoe.sample.android;

import org.studio.crusoe.sample.android.util.Reflection;

import android.app.Activity;
import android.graphics.Color;
import android.os.Bundle;
import android.text.InputType;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;

public class ActivityMain extends Activity {
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        ScrollView sv = new ScrollView(this);
        LinearLayout layout = new LinearLayout(this); // 线性布局方式
        layout.setOrientation(LinearLayout.VERTICAL); // 控件对其方式为垂直排列
        layout.setBackgroundColor(Color.GRAY);

        TextView tv = new TextView(ActivityMain.this);
        tv.setId(12341);
        tv.setText("用户名:");
        layout.addView(tv);

        EditText et = new EditText(ActivityMain.this);
        et.setId(12342);
        et.setText("");
        et.setSingleLine();
        layout.addView(et);

        TextView tv1 = new TextView(ActivityMain.this);
        tv1.setId(12343);
        tv1.setText("密码:");
        layout.addView(tv1);

        EditText et1 = new EditText(ActivityMain.this);
        et1.setId(12344);
        et1.setSingleLine();
        et1.setInputType(InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);
        et1.setText("");
        layout.addView(et1);

        Button b = new Button(ActivityMain.this);
        b.setId(12345);
        b.setText("登录");
        layout.addView(b);
        try {
            b.setOnClickListener((OnClickListener) Reflection
                    .createInstance("org.studio.crusoe.sample.android.ButtonClickListener"));
        } catch (Exception e) {
            // TODO: handle exception
        }

        layout.setBackgroundColor(0xff00ffff); 
        sv.addView(layout);
        setContentView(sv);
    }
}

 

在事件处理中,可以实现页面的变化和数据的传递

package org.studio.crusoe.sample.android;

import android.content.Context;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.TextView;

public class ButtonClickListener implements OnClickListener{

    public void onClick(View v) {
        Context context = v.getContext();
        LinearLayout layout = (LinearLayout)v.getParent();
        
        EditText et = (EditText)layout.findViewById(12342);
        layout.removeAllViews();
        
        TextView tv = new TextView(context);
        tv.setText("欢迎你:" + et.getText());
        layout.addView(tv);
    }

}

 

由于Activity作为页面载体,目前掌握到信息,必须要在AndroidManifest.xml中声明,这样会影响自身框架的灵活性。目前的思路是选择确定数量的Activity,通过框架代码来完成页面展现。技术上应该问题不大。

现在有一个隐患,从现在情况来看,通过layout的配置方式,功能十分强大,比代码执行更好,这个让我想到了C#中WPF的XAML的思路。

另外的遗留问题是,需要规划设置多少个主Activity,并且实现对应的Intents,才能实现框架的灵活性。

 

页面效果:

1.初始化

 

 

2.跳转页面

 

 

2
0
分享到:
评论

相关推荐

    《Android UI设计》PDF

    许多开发人员需要一本Android UI设计入门级教程,其能够同时针对移动UI的设计模式和碎片化解决方案进行深入分析。 《Android UI设计》面向创建移动应用的产品经理、设计师和开发者,系统讲解了从事Android UI设计...

    android UI设计技巧

    使用Jetpack Compose进行UI构建是现代Android开发的新趋势,它允许开发者以声明式的方式编写界面,提高了开发效率。 5、**图标和准则** 图标在UI设计中扮演着重要的角色。Android提供了Material图标库,包括多种...

    Android UI基础教程 高清带标签pdf

     《AndroidUI基础教程》是一本Android用户界面设计的基础入门图书。全书从最基础的技术概念开始介绍,深入讨论了UI设计的各项技术,涵盖了为应用程序创建UI的所有内容。本书不仅会告诉读者创建灵活布局的最佳方法,...

    Android UI开发专题

    Android作为全球最广泛使用的移动操作系统之一,其UI开发能力备受关注。本次Android UI开发专题旨在深入探讨Android平台上UI设计的关键技术和实践方法。 #### 二、资源管理:`android.content.res.Resources` **1....

    android ui基础教程

    ### Android UI基础教程...综上所述,Android UI设计是一项综合性的工作,不仅需要掌握各种控件和技术细节,还需要考虑到用户的实际需求和使用习惯。通过不断学习和实践,开发者可以打造出既美观又实用的应用程序界面。

    android UI大全

    "android UI大全"这个资源包,显然集成了多种Android用户界面元素的源码和示例,旨在帮助初学者快速入门,并为面试做准备。让我们深入探讨一下其中可能包含的知识点。 1. **Android Widgets**: 文件名中的Widgets...

    Android UI试练 微信UIDemo

    这个项目不仅包含了完整的微信UI实现,还提供了一个实践平台,让开发者可以深入理解并应用Android UI设计的各种技术。 首先,我们要了解Android UI的基本构成。在Android中,UI主要由布局(Layouts)和视图(Views...

    android UI界面设计

    4. 主要的 UI 交互方式(触屏还是使用 D-pad/trackball):在设计 UI 界面时,需要考虑到主要的 UI 交互方式。 5. 软键盘还是物理键盘:在设计 UI 界面时,需要考虑到软键盘还是物理键盘。 6. 了解不同设备之间的相...

    android UI 特效集合

    在Android开发中,UI特效是提升用户体验和应用吸引力的关键元素。这个"android UI 特效集合"可能包含了一系列精心设计的界面动态效果、过渡动画以及交互式设计,旨在帮助开发者们构建更加生动、吸引人的应用程序。...

    android UI 各种小例子

    在Android中,我们可以使用动画库(如ObjectAnimator、ValueAnimator)来创建平移、旋转、缩放等效果,或者使用SlideToggle等技术实现滑动菜单效果。 5. **UI-XML+JAVA**: 这个例子可能展示了如何结合XML布局文件...

    安卓Android源码——UI界面源码.zip

    1. **Android UI框架**:Android UI系统基于View和 ViewGroup两大类。View是UI的基本元素,如按钮、文本框等,而ViewGroup是容器,用于组织和布局多个View,如LinearLayout、RelativeLayout和FrameLayout等。 2. **...

    移植Android的UI组件到Web端以Android的方式来制作高性能优体验的WebApp

    AndroidUI4Web正是这样一款框架,它旨在将Android的UI组件移植到Web端,从而让开发者能够以Android的方式创建高性能且用户体验优秀的WebApp。 AndroidUI4Web的核心理念是复用Android的UI设计思想和组件模型,使得...

    ANDROID UI设计工具

    它拥有强大的原型制作功能,允许团队成员实时共享和编辑设计,对Android UI设计非常友好。 5. **InVision**: InVision主要用于交互式原型设计和协作,可以帮助设计师将静态设计转化为可点击的交互原型,便于测试...

    Android UI demo(远程医疗)

    在Android平台上,UI设计与实现是构建任何应用的基础,尤其是对于远程医疗这样的应用程序,用户界面的设计至关重要,因为它直接影响到用户的体验和效率。本项目“Android UI demo(远程医疗)”主要展示了如何在...

    QQUI android QQUI

    QQUI可能会使用高效的图像处理技术,如使用VectorDrawable减少内存消耗,或者使用AsyncTask进行后台数据加载,确保界面在复杂操作下也能保持流畅。 总之,QQUI作为一个模仿QQ界面的Android应用,它在UI设计上展示了...

    Android新手UI集合全

    在Android开发领域,UI设计是至关重要的一环,它直接影响到应用程序的用户体验和视觉吸引力。"Android新手UI集合全"这个资源包,显然为初学者提供了一整套的UI设计元素,帮助他们快速理解和实践Android应用界面的...

Global site tag (gtag.js) - Google Analytics