Auto.js java布局 转 UI 布局,自己定义uii.layout()

"ui";
自定义布局()
view=uii.layout(
   <linear orientation="vertical">
      <linear orientation="horizontal">
         <button id="按钮1"text="按钮1"/>
         <button id="按钮2"text="按钮2"/>
      </linear>
      <linear orientation="horizontal">
         <button id="按钮3"text="按钮3"/>
         <button id="按钮4"text="按钮4"/>
      </linear>
      <linear orientation="vertical"w="*">
         <button id="按钮5"text="按钮5"w="*"/>
         <button id="按钮6"text="toast"/>
      </linear>
   </linear>
);
ui.setContentView(view)
uii.按钮6.setOnClickListener(new android.view.View.OnClickListener(){
      onClick:function(p1){
         toast("完成")
      }
});
function 自定义布局(){
   importClass(android.widget.Button);
   importClass(android.widget.LinearLayout);
   importClass(android.content.DialogInterface);
   importClass(android.graphics.Color);
   uii={
      layout:function (xml){
         var bj=xml.toString().split("\n")
         var 主布局  = new LinearLayout(context);
         fenge(bj,0,主布局,0)
         return 主布局;
      }
   }
}
function fenge(bj,j,zbj,c){
   for(var i=j;i<bj.length;i++){
      if(geshi(bj[i])=="<0>"){
         log(c+"进布局"+bj[i])
         var bjc=fenxi(bj[i].replace(/^\s+|\s+$/g,""))//分析控件
         i++;
         i=fenge(bj,i,bjc[0],c+1)
         if(bjc.length==1){
            zbj.addView(bjc[0])
         }else{
            zbj.addView(bjc[0],bjc[1])
         }
      }else if(geshi(bj[i])=="</0>"){
         log(c+"退布局"+bj[i])
         return i
      }else if(geshi(bj[i])=="<0/>"){
         var bjc=fenxi(bj[i].replace(/^\s+|\s+$/g,""))//分析控件
         if(bjc.length==1){
            zbj.addView(bjc[0])
         }else{
            zbj.addView(bjc[0],bjc[1])
         }
         log(c+"添加"+bj[i])
      }
   }
}
function shuzi(str){
   if(!str){
      return false
   }
   var pp=str.match(/^\d+$/g)
   if(pp){
      return true
   }
   return false;
}
function geshi(nr){
   var pp=nr.match(/<\/|<|\/>|>/g)
   if(pp){
      var str=""
      for(var i=0;i<pp.length;i++){
         str=str+pp[i]+"0"
      }
      return str.replace(/0$/,"");
   }
   return false;
}
function fenxi(str){
   var tou=str.split(" ")[0].match(/\w+/g)[0]
   var wei=str.match(/\w+="(\w|\d|[\u4e00-\u9fa5]|\*)+"/g)
   var dx='{'
   for(var i=0;i<wei.length;i++){
      var fg=wei[i].split("=")
      dx+='"'+fg[0].replace(/^\s+|\s+$/g,"")+'":'+fg[1].replace(/^\s+|\s+$/g,"")+","
   }
   dx=JSON.parse(dx.replace(/.$/g,'}'))
   return bj_linear(tou,dx)//线布局
}
function bj_linear(tou,dx){
   if(tou=="linear"){
      线布局  = new LinearLayout(context);
      if(dx.bg){
         线布局.setBackgroundColor(Color.parseColor(dx.bg));
      }
      if(dx.orientation){
         if(dx.orientation=="vertical"){
            线布局.setOrientation(1);//1.卡片布局
         }else if(dx.orientation=="horizontal"){
            线布局.setOrientation(0);//0.水平布局
         }
      }
      return [线布局,chicun(dx)];
   }else if(tou=="button"){
      var 按钮 = new Button(context);
      if(dx.text){
         按钮.setText(dx.text)
      }
      if(dx.id){
         uii[dx.id]=按钮;
      }
      return [按钮,chicun(dx)];
   }
}
function chicun(dx){
   var w=-2 //适应内容宽度
   var h=-2 //适应内容宽度
   if(dx.w){
      if(shuzi(dx.w)){
         w=dx.w-0 //实际宽度
      }else if(dx.w=="*"){
         w=-1 //适应父控件宽度
      }
   }
   if(dx.h){
      if(shuzi(dx.h)){
         h=dx.h-0 //实际宽度
      }else if(dx.h=="*"){
         h=-1 //适应父控件宽度
      }
   }
   log("适应="+w+","+h)
   return new LinearLayout.LayoutParams(w,h);
}

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值