精华内容
下载资源
问答
  • 互联网商业画布

    2017-12-11 10:44:02
    互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布互联网商业画布...
  • 商业画布模板

    2017-06-14 12:48:01
    商业画布模板
  • 商业画布

    千次阅读 2019-09-03 10:54:22
    什么是商业画布商业模式画布指一种能够帮助团队催生创意、降低猜测、确保他们找对了目标用户、合理解决问题的工具。商业模式画布使得商业模式可视化,使用统一的语言讨论不同商业领域。商业模式画布不仅能够提供更多...
    1. 什么是商业画布
      商业模式画布指一种能够帮助团队催生创意、降低猜测、确保他们找对了目标用户、合理解决问题的工具。商业模式画布使得商业模式可视化,使用统一的语言讨论不同商业领域。商业模式画布不仅能够提供更多灵活多变的计划,而且更容易满足用户的需求。更重要的是,它可以将商业模式中的元素标准化,并强调元素间的相互作用。
      商业画布由九个元素组成:

      商业画布需要从以下九个问题去思考:

      商业画布”也是一样,一个好的商业模式,需要去思考9个方面的问题:

      谁是你的用户?你的用户有什么特点?
      你可以为你的用户提供什么样的产品和服务?
      你通过什么渠道与你的客户接触?
      你与你的客户将建立一种什么样的关系?
      这套商业模式可以有哪些收入来源?
      你已经具有或者需要掌握怎样的核心资源?
      你需要开展哪些核心活动?
      你需要有哪些重要的合作伙伴?
      这套商业模式在哪些地方花钱?成本结构是怎样的?

    2. 对于商业画布的解释:

      价值主张:客户为什么选择了你而不是别人,我们能够为客户提供什么,能为用户创造什么价值?
          1 解决客户问题或者满足客户需要
          2 通过产品或者服务的捆绑迎合了特定客户群的需求
          3 颠覆式创新或者破坏式创新,增加了新特性或者属性
          4 传递给客户的价值是定量或者定性的。
              新颖,性能,定制化,身份定位,设计感等

      客户细分:
          我们的目标用户或者客户是谁?可以从以下几个维度去区分:使用者,影响者,推荐者,购买者,决策者
      客户细分有两个维度,横向和纵向。
          其中横向:用来描述一个企业想要接触和服务的不同人群和组织。客户的类型可以分为大众市场,利基市场,区隔化市场,多元化市场,多边平台或多边市场。
          纵向:从使用纵向维度来区分,又可以从下往上,最低层级到最高层级,依次为使用者,影响者,推荐者,购买者,决策者。


      关键活动:
      为了确保商业模式的可行性,必须采用的一些措施。

      渠道:主要指价值如何传递给客户,如沟通,分销,销售渠道(直接渠道,非直接渠道,销售队伍,自有店铺,合作伙伴店铺,在线销售,批发商等等。)等。
      企业需要关注以下问题:
      1 客户想通过哪些渠道和我们接触
      2 我们目前是怎么跟他们接触的
      3 我们的渠道是如何整合的
      4 哪种方式最好,最高效

      重要资源:
          企业自身所拥有的能力和资源,如技术,人才,知识。核心资源可以分为以下几类:
          1 实体资产 2 知识资产 3 人力资源 4 金融资产

      合作伙伴:企业核心业务所涉及的或者依赖的上下游服务商等。
          一般来说有四种重要的合作伙伴:
          1 非竞争者之间的战略联盟
          2 竞合关系
          3 为开发新业务而构建的合资渠道
          4 购买方和供应方
      成本结构-CS:
      运营一个商业模式所引发的所有成本。
      成本结构里包含固定成本,可变成本,市场费用,生产成本,技术授权,营运维护,财务成本等等。

      收入来源-RS:
      公司从每个客户群体获取的现金收入(包括一次性收入和经常性收入)。
      获取收入的方式包含资产销售,使用收费,订阅收费,租赁收费,授权收费,经纪收费,广告收费等等。

      客户关系:

    3. 九大模块的描述关系:

      九个模块描述的顺序大概是这样的:

      价值主张 → 客户细分 → 关键活动 → 渠道通路 → 客户关系 → 重要资源 → 合作伙伴 → 固定成本 → 收入来源

     

    在上述介绍的基础上补充产品的精益画布,思路基本差不多。

     

     

     

    变化比较大的主要是以下几个部分:

    1 问题==》重要伙伴

    2 解决方案==》关键活动

    3 门槛优势==》客户关系

     

    关于问题部分的陈述:

    提出三个你认为该产品解决的最核心的痛点,从而提出该产品的商业目标。

    例如摩拜解决的主要问题就是近距离的通行问题,打车贵,开车麻烦,走路又远。自己骑自行车维护管理又比较麻烦。

    有一个很有趣的说法是,“一款好的产品,所解决的痛点一定可以迎合人性七宗罪中的一种。”七宗罪指的是:好色、暴食、贪婪、懒惰、愤怒、嫉妒、骄傲。这其中确实有些合理之处,因为贪婪,产生了团购功能,红包功能,秒杀返现等等。因为嫉妒和骄傲,有了会员等级,勋章系统,排名和朋友圈等等。因为好色,有了直播,打赏,摇一摇等等需求。能够满足人性深处最原始的初衷,就不怕没有用户使用。

    按照马斯洛的需求理论同样,痛点需要能够对应到人的当前需求,基于此开发出的产品才是真正能解决用户问题的产品。

     

    展开全文
  • 实现功能:uniapp H5 使用画布,本地图片放到画布里面绘画,网络图片放到画布里面绘画 注:可以把图片转成base64,在线转换 下面看代码: 代码解析:avatar 是头像地址,用pathToBase64 转成Base64 ,base64_aimg...

    实现功能:uniapp  H5 使用画布,绘画完之后保存为图片全屏显示完整实现代码,跨域解决方案。

     

    跨域图片解决方案一:(使用base64编码)网络图片放到画布里面绘画

    跨域图片解决方案二:(使用本地图片)本地图片放到画布里面绘画

    一:网络图片跨域方案

    注:可以把图片转成base64, 在线转换 

    下面看代码:

    代码解析:avatar 是头像地址,用 pathToBase64 转成 Base64 , base64_aimg 是 Base64 数据,注意画布保存成图片的大小要写成屏幕大小,屏幕大小获取方式:

    	onLaunch: function(info) {
    		var that=this;
    		uni.getSystemInfo({
    		    success: function (res) {
    				that.windowWidth =res.windowWidth;
    				that.windowHeight =res.windowHeight;
    				
    		        console.log('----this---www',this.windowWidth);
    		    }
    		});
    		//网络状态监听
    		// network();
    		console.log('App Launch');
    	},

    画布相关代码

    <canvas style="" canvas-id="myCanvas" id="myCanvas"></canvas>
    
    
    	canvas {
    		background-color: #fff;
    		border: 1px solid #d0d0d0;
    		width: 100vw;
    		height: 100vh;
    		position: absolute;
    		left: 100%;
    	}
    <template>
    	<!--pages/poster/poster.wxml-->
    	<view class="page">
    		<canvas style="" canvas-id="myCanvas" id="myCanvas"></canvas>
    		<view class="container">
    			<image :src="tempFilePath" mode="widthFix"></image>
    		</view>
    	</view>
    </template>
    
    <script>
    	import {
    		IMAGES_PATH
    	} from '@/common/const.js';
    	import {
    		getPoster
    	} from '@/common/api.js';
    	import {
    		pathToBase64,
    		base64ToPath
    	} from '../../js_sdk/gsq-image-tools/image-tools/index.js'
    	import base64_img from "./base64_img.js";
    
    	export default {
    		data() {
    			return {
    				tempFilePath: ''
    			};
    		},
    		onLoad: function(options) {
    			var that = this;
    			var context = uni.createCanvasContext('myCanvas');
    			
    			getPoster(options.id)
    				.then(res => {
    					var {
    						img,
    						avatar,
    						nickname,
    						avatar_content,
    						active_describe
    					} = res.data.data || {};
    					var right_bottom_txt_base64 =
    						""
    					pathToBase64(avatar)
    						.then(base64_avatar => {
    							// 背景底图
    							context.drawImage(base64_img[img], 0, 0, 200, 387, 400, 774)
    
    							// 用户昵称
    							context.setFillStyle('#233582');
    							context.fillText(nickname, 90, 132);
    
    							// 文字上面横线 1
    							context.setFillStyle('#233582')
    							context.fillRect(16, 146, 166, 1.2)
    
    							// 文字 判断长度换行处理
    							context.setFontSize(9)
    							if (active_describe.length > 18) {
    								let tt1 = active_describe.substr(0, 17);
    								let tt2 = active_describe.substr(17, active_describe.length - 1);
    								context.fillText(tt1, 16, 166);
    								context.fillText(tt2, 16, 181);
    							} else {
    								context.fillText(active_describe, 20, 166, 320);
    							}
    
    							// 文字下面横线 2
    							context.fillRect(16, 196, 166, 1.2)
    
    							// 右下角的文字用图片,因为在背景图的话会失真模糊
    							context.drawImage(right_bottom_txt_base64, 100, 230, 90, 30)
    
    							// 规定一个圆形的位置,里面放头像图片
    							let avatarurl_width = 40
    							let avatarurl_heigth = 40
    							let avatarurl_x = 80
    							let avatarurl_y = 80
    							context.arc(avatarurl_width / 2 + avatarurl_x, avatarurl_heigth / 2 + avatarurl_y,
    								avatarurl_width / 2,
    								0, Math.PI * 2, false)
    							context.clip()
    							context.drawImage(base64_avatar, avatarurl_x, avatarurl_y, avatarurl_width, avatarurl_heigth)
    							context.restore()
    
    							// 保存画布,生成图片指定大小的图片,并返回图片路径
    							// 有个坑 : H5端 Canvas 内绘制的图像需要支持跨域访问才能成功。(本代码的解决方案:把图片转成base64)
    							context.draw(true, () => {
    								uni.canvasToTempFilePath({
    									x: 0,
    									y: 0,
    									width: 200,
    									height: 387,
    									destWidth: getApp().windowWidth,
    									destHeight: getApp().windowHeight,
    									canvasId: 'myCanvas',
    									fileType: "jpg",
    									quality: 1,
    									success(res) {
    										console.log('绘制成功-------', res)
    										uni.hideLoading();
    										that.tempFilePath = res.tempFilePath;
    									},
    									fail(err) {
    										console.log('绘制失败', err)
    									}
    								});
    							});
    
    						})
    				})
    
    		},
    		methods: {
    			// 小程序的场景使用,小程序支持本地图片
    			getImageInfo(url) {
    				return new Promise(function(resolve, reject) {
    					uni.getImageInfo({
    						src: url,
    						success: function(res) {
    							console.log(res);
    							resolve(res);
    						},
    						fail: function(err) {
    							console.log(err);
    							uni.showToast({
    								title: '生成失败',
    								icon: 'none'
    							});
    						}
    					});
    				});
    			},
    			// 小程序的场景使用,长按保存图片
    			saveImg(e) {
    				let url = this.tempFilePath;
    				uni.saveFile({
    					tempFilePath: url,
    					success: function(res) {
    						var savedFilePath = res.savedFilePath;
    						uni.showToast({
    							title: "图片保存成功",
    							icon: "none"
    						});
    					}
    				});
    
    
    			},
    			// 小程序场景使用,获取图片信息,保存到相册
    			downImage() {
    				const url = this.images1;
    				uni.getImageInfo({
    					src: url,
    					success: res => {
    						let path = res.path;
    						uni.saveImageToPhotosAlbum({
    							filePath: path,
    							success: res => {
    								uni.showToast({
    									title: '保存成功',
    									icon: 'none'
    								});
    							},
    							fail: res => {
    								console.log(res);
    							}
    						});
    					},
    					fail: res => {
    						console.log(res);
    					}
    				});
    			}
    		}
    	};
    </script>
    
    <style>
    	canvas {
    		background-color: #fff;
    		border: 1px solid #d0d0d0;
    		width: 100vw;
    		height: 100vh;
    		position: absolute;
    		left: 100%;
    	}
    
    	.container {
    		width: 100vw;
    		align-items: center;
    		overflow: auto;
    		background: #fefefe;
    	}
    
    	.container image {
    		width: 100%;
    		position: absolute;
    		top: 0;
    	}
    </style>
    

    二:本地图片画布实现代码,画布保存为图片并显示在页面,全屏

    <template>
    	<view class="">
    		<canvas style="" canvas-id="myCanvas" id="myCanvas"></canvas>
    		<view class="container">
    			<image :src="tempFilePath" mode="widthFix"></image>
    		</view>
    	</view>
    
    </template>
    
    <script>
    	var that
    	export default {
    		data() {
    			return {
    				tempFilePath: ''
    			}
    		},
    		onReady(option) {
    			that = this;
    			const ctx = uni.createCanvasContext('myCanvas')
    
    			ctx.drawImage('../../static/sharePoster_bg.png', 0, 0, 200, 387)
    			ctx.draw(true, () => {
    				uni.canvasToTempFilePath({
    					x: 0,
    					y: 0,
    					width: 200,
    					height: 387,
    					destWidth: getApp().windowWidth,
    					destHeight: getApp().windowHeight,
    					canvasId: 'myCanvas',
    					fileType: "jpg",
    					quality: 1,
    					success(res) {
    						console.log('绘制成功-------', res)
    						uni.hideLoading();
    						that.tempFilePath = res.tempFilePath;
    					},
    					fail(err) {
    						console.log('绘制失败', err)
    					}
    				});
    			});
    		},
    		methods: {}
    	}
    </script>
    
    <style lang="scss" scoped>
    	canvas {
    			background-color: #fff;
    			border: 1px solid #d0d0d0;
    			width: 100vw;
    			height: 100vh;
    			position: absolute;
    			left: 100%;
    		}
    	 
    		.container {
    			width: 100vw;
    			align-items: center;
    			overflow: auto;
    			background: #fefefe;
    		}
    	 
    		.container image {
    			width: 100%;
    			position: absolute;
    			top: 0;
    		}
    </style>
    

     

    展开全文
  • android画布_Android画布

    2020-07-10 08:24:52
    android画布In this tutorial, we’ll be discussing a very important part of Android i.e. Canvas. It’s a territory which every developer prefers to stay away from. The reason for this tutorial is to ...

    android画布

    In this tutorial, we’ll be discussing a very important part of Android i.e. Canvas. It’s a territory which every developer prefers to stay away from. The reason for this tutorial is to make you more aware and at ease with the Android Canvas.

    在本教程中,我们将讨论Android的一个非常重要的部分,即Canvas。 这是每个开发人员都希望远离的领域。 本教程的目的是让您更加了解Android画布,并且更加放心。

    Android画布 (Android Canvas)

    Many times you end up in a scenario where you need to implement a custom View and/or animate it. It can happen that the requirements are so specific that you need to implement it from scratch. Canvas plays a vital role in building such Custom Views.

    很多时候,您最终会遇到需要实现自定义视图和/或对其进行动画处理的情况。 需求可能是如此具体,以至于您需要从头开始实施。 画布在构建此类自定义视图中起着至关重要的作用。

    A Canvas is a 2D drawing framework that provides us with methods to draw on the underlying Bitmap. A Bitmap acts as the surface over which the canvas is placed. The Paint class is used to provide colors and styles.

    Canvas是2D绘图框架,为我们提供了在底层位图上进行绘图的方法。 位图充当画布在其上放置的表面。 Paint类用于提供颜色和样式。

    Before we dig deep into Canvas, let’s look at the lifecycle of a Custom View.

    在深入研究Canvas之前,让我们看一下Custom View的生命周期。

    A Custom View consists of the following commonly used methods:

    自定义视图包含以下常用方法:

    onMeasure()
    onLayout()
    onDraw()

    Inside onMeasure we determine the size of the view and its children.

    onMeasure我们确定视图及其子视图的大小。

    Inside onLayout the size is assigned to the view.

    onLayout内部,将大小分配给视图。

    The onDraw method is where the canvas is drawn.

    onDraw方法是绘制画布的位置。

    A Canvas Object basically comes as a parameter inside the onDraw method.

    画布对象基本上是onDraw方法中的一个参数。

    The invalidate() method is used to redraw the view. It calls the onDraw method again. Typically, this is used when the text or color or view needs to be updated based on certain events.

    invalidate()方法用于重绘视图。 它再次调用onDraw方法。 通常,当需要根据某些事件更新文本或颜色或视图时,将使用此选项。

    The Canvas class contains methods to draw certain shapes just as line, arc, circle, over. Moreover, we can draw complex geometry too using Paths.

    Canvas类包含一些方法来绘制某些形状,例如直线,圆弧,圆形,上方。 此外,我们也可以使用Paths绘制复杂的几何图形。

    We can also draw text or just simply Paint color on the canvas too.

    我们也可以在画布上绘制文本或仅绘制颜色。

    Since canvas is drawn on the screen, views that are drawn need to be measured in terms of pixels (px).
    由于画布是在屏幕上绘制的,因此绘制的视图需要以像素(px)进行度量。

    Let’s look at how to draw basic stuff on Canvas through our sample android studio project.

    让我们看看如何通过示例Android Studio项目在Canvas上绘制基本内容。

    Android Canvas示例项目结构 (Android Canvas Example Project Structure)

    Android Canvas Basics Project

    Android Canvas Example Project

    Android Canvas示例项目

    To create a Path, two methods are important: moveTo() and lineTo().

    要创建路径,两个方法很重要: moveTo()lineTo()

    moveTo takes you to the coordinates you specify on the screen.

    moveTo将您带到您在屏幕上指定的坐标。

    lineTo draws a line from the current position to the one specified.

    lineTo从当前位置到指定位置绘制一条线。

    close() is used to close a path.

    close()用于关闭路径。

    画布坐标系如何工作? (How does the Canvas Coordinate System work?)

    In the canvas 0,0 is the top left point. As you move horizontally right the x coordinate increases.
    As you move vertically down the y coordinate increases in pixels.

    在画布中0,0是左上角。 当您向右水平移动时,x坐标会增加。
    当您垂直向下移动时,y坐标以像素为单位增加。

    Following diagram illustrates the same:

    下图说明了相同的内容:

    Android Canvas Coordinate System

    Android Canvas Coordinate System

    Android画布坐标系

    矩形与矩形 (Rect vs RectF)

    Rect object is used to create a rectangle in which each side is specified in integer value.
    RectF does the same but in float values.

    Rect对象用于创建一个矩形,其中每边均以整数值指定。
    RectF进行相同的操作,但使用浮点值。

    In the following example, we’ll see how to draw the various shapes and also use Paint to style them.

    在下面的示例中,我们将看到如何绘制各种形状以及如何使用Paint对其进行样式设置。

    Android Canvas示例代码 (Android Canvas Example Code)

    The code for the activity_main.xml layout is a basic root layout in which we’ll add our Canvas:

    activity_main.xml布局的代码是基本的根布局,我们将在其中添加Canvas:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="https://schemas.android.com/apk/res/android"
        xmlns:app="https://schemas.android.com/apk/res-auto"
        xmlns:tools="https://schemas.android.com/tools"
        android:id="@+id/linearLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity" />

    The code for the MainActivity.java is given below:

    MainActivity.java的代码如下:

    package com.journaldev.androidcanvasbasics;
    
    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    import android.widget.LinearLayout;
    import android.widget.RelativeLayout;
    
    public class MainActivity extends AppCompatActivity {
    
        LinearLayout linearLayout;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            linearLayout = findViewById(R.id.linearLayout);
            MyView myView = new MyView(this);
            linearLayout.addView(myView);
        }
    }

    The MyView class is where we create our Custom View. Let’s finally draw on the Canvas!

    MyView类是我们创建自定义视图的地方。 让我们终于在画布上画画!

    package com.journaldev.androidcanvasbasics;
    
    import android.app.Activity;
    import android.content.Context;
    import android.graphics.Canvas;
    import android.graphics.Color;
    import android.graphics.Paint;
    import android.graphics.Path;
    import android.graphics.Point;
    import android.graphics.RectF;
    import android.graphics.Region;
    import android.util.DisplayMetrics;
    import android.view.View;
    
    public class MyView extends View {
    
        Paint mPaint, otherPaint, outerPaint, mTextPaint;
        RectF mRectF;
        int mPadding;
    
        float arcLeft, arcTop, arcRight, arcBottom;
    
        Path mPath;
    
    
        public MyView(Context context) {
            super(context);
    
            mPaint = new Paint();
            mPaint.setAntiAlias(true);
    
            mPaint.setStyle(Paint.Style.STROKE);
            mPaint.setColor(Color.BLUE);
            mPaint.setStrokeWidth(5);
    
    
            mTextPaint = new Paint(Paint.LINEAR_TEXT_FLAG | Paint.ANTI_ALIAS_FLAG);
            mTextPaint.setColor(Color.BLACK);
            mTextPaint.setTextSize(pxFromDp(context, 24));
    
            otherPaint = new Paint();
    
            outerPaint = new Paint();
            outerPaint.setStyle(Paint.Style.FILL);
            outerPaint.setColor(Color.YELLOW);
    
            mPadding = 100;
    
    
            DisplayMetrics displayMetrics = new DisplayMetrics();
    
            ((Activity) getContext()).getWindowManager()
                    .getDefaultDisplay()
                    .getMetrics(displayMetrics);
    
    
            int screenWidth = displayMetrics.widthPixels;
            int screenHeight = displayMetrics.heightPixels;
    
            arcLeft = pxFromDp(context, 20);
            arcTop = pxFromDp(context, 20);
            arcRight = pxFromDp(context, 100);
            arcBottom = pxFromDp(context, 100);
    
    
            Point p1 = new Point((int) pxFromDp(context, 80) + (screenWidth / 2), (int) pxFromDp(context, 40));
            Point p2 = new Point((int) pxFromDp(context, 40) + (screenWidth / 2), (int) pxFromDp(context, 80));
            Point p3 = new Point((int) pxFromDp(context, 120) + (screenWidth / 2), (int) pxFromDp(context, 80));
    
            mPath = new Path();
            mPath.moveTo(p1.x, p1.y);
            mPath.lineTo(p2.x, p2.y);
            mPath.lineTo(p3.x, p3.y);
            mPath.close();
    
            mRectF = new RectF(screenWidth / 4, screenHeight / 3, screenWidth / 6, screenHeight / 2);
    
        }
    
        @Override
        protected void onDraw(Canvas canvas) {
            super.onDraw(canvas);
    
            canvas.drawRoundRect(mRectF, 10, 10, otherPaint);
            canvas.clipRect(mRectF, Region.Op.DIFFERENCE);
            canvas.drawPaint(outerPaint);
    
            canvas.drawLine(250, 250, 400, 400, mPaint);
            canvas.drawRect(mPadding, mPadding, getWidth() - mPadding, getHeight() - mPadding, mPaint);
            canvas.drawArc(arcLeft, arcTop, arcRight, arcBottom, 75, 45, true, mPaint);
    
    
            otherPaint.setColor(Color.GREEN);
            otherPaint.setStyle(Paint.Style.FILL);
    
            canvas.drawRect(
                    getLeft() + (getRight() - getLeft()) / 3,
                    getTop() + (getBottom() - getTop()) / 3,
                    getRight() - (getRight() - getLeft()) / 3,
                    getBottom() - (getBottom() - getTop()) / 3, otherPaint);
    
    
            canvas.drawPath(mPath, mPaint);
            otherPaint.setColor(Color.BLACK);
            canvas.drawCircle(getWidth() / 2, getHeight() / 2, arcLeft, otherPaint);
    
            canvas.drawText("Canvas basics", (float) (getWidth() * 0.3), (float) (getHeight() * 0.8), mTextPaint);
    
        }
    
    
        public static float pxFromDp(final Context context, final float dp) {
            return dp * context.getResources().getDisplayMetrics().density;
        }
    
    }

    pxFromDp method is used to get the pixel equivalent of the dp value passed.

    pxFromDp方法用于获取与传递的dp值等效的像素。

    canvas.drawLine(250, 250, 400, 400, mPaint); simply draws a line from x1 y1 to x2 y2.

    canvas.drawLine(250, 250, 400, 400, mPaint); 只需从x1 y1到x2 y2画一条线。

    The following code is used to draw a rectangle at the center of the screen.

    以下代码用于在屏幕中心绘制一个矩形。

    canvas.drawRect(
                    getLeft() + (getRight() - getLeft()) / 3,
                    getTop() + (getBottom() - getTop()) / 3,
                    getRight() - (getRight() - getLeft()) / 3,
                    getBottom() - (getBottom() - getTop()) / 3, otherPaint);

    Inside the drawCircle method, the first two parameters passed are the coordinates of the center of the circle. The third parameter sets the radius for the circle.

    drawCircle方法内部,传递的前两个参数是圆心的坐标。 第三个参数设置圆的半径。

    clipRect clips the canvas with the rectangle. The last parameter sets the clipping region style.

    clipRect用矩形clipRect画布。 最后一个参数设置裁剪区域样式。

    Region.Op.DIFFERENCE sets the Paint on the region between the canvas and the rectangle specified in the clipRect method.

    Region.Op.DIFFERENCE将Paint设置在clipRect方法中指定的画布和矩形之间的区域上。

    Inside the drawText method the two float values set the origin position of the text. We’ve set it at 30 percent from the left and 80 % from the top of the screen.

    drawText方法内部,两个float值设置文本的原点位置。 我们将其设置为屏幕左侧的30%和屏幕顶部的80%。

    Why is Anti Alias flag needed in Paint?为什么在Paint中需要使用抗别名标志?
    An Anti alias flag ensures that the shape is smooth.
    反别名标志可确保形状平滑。

    How are the different shapes drawn on the canvas positioned relative to each other?

    画布上绘制的不同形状如何相对定位?

    画布Z顺序 (Canvas Z-Order)

    Elements are arranged on top of each other in the order in which they are drawn. Similar to a frame layout based on the z-order.

    元素按绘制顺序彼此排列。 类似于基于z顺序的框架布局。

    The output of the above application is given below:

    以上应用程序的输出如下:

    Android Canvas Basics Output 1

    Android Canvas Basics Output 1

    Android Canvas基础输出1

    Android Canvas Basics Output 2

    Android Canvas Basics Output 2

    Android Canvas基础输出2

    That brings an end to this tutorial. You can download the project from the link below:

    这样就结束了本教程。 您可以从下面的链接下载项目:

    翻译自: https://www.journaldev.com/25182/android-canvas

    android画布

    展开全文
  • Canvas画布

    2017-08-08 23:02:52
    Canvas画布

    Canvas画布

    展开全文
  • 商业模式画布 https://wiki.mbalib.com/wiki/%E5%95%86%E4%B8%9A%E6%A8%A1%E5%BC%8F%E7%94%BB%E5%B8%83 精益画布 https://wiki.mbalib.com/wiki/%E7%B2%BE%E7%9B%8A%E7%94%BB%E5%B8%83 使用场合 ...
  • 前端使用uniapp制作H5自定义海报,本来以为挺简单的一常用功能画布,因为之前也在 H5 和小程序做过类似功能,所以直接上手干了,没想到还是遇到了一些坑,特此记录希望能够帮到大家。 实现功能讲解: 海报实现的...
  • mxgraph 画布

    2019-09-27 09:01:15
    画布自动扩大/缩小计算: //得到所拖拽图形相对于画布的位置(-880,-100) var x = Math.ceil(bounds.x / this.view.scale - this.view.translate.x); var y = Math.ceil(bounds.y / this.view.scale - this....
  • 商业模式画布.pdf

    2019-11-27 18:23:42
    商业模式画布的培训材料,PPT转的PDF文档。非常详细的商业模式画布的介绍材料,含详细的制图、定义说明、示例。内部培训参考。
  • 精益画布和商业模式画布

    千次阅读 2018-05-16 22:05:24
    1 商业模式画布,关心的: 1) 重要伙伴 2)关键业务 3)核心资源 4)价值主张 5)客户关系 6)渠道通路 7)客户细分 8)成本结构 9)收入来源 2) 精益画布 1)问题 2) 解决方案 3)...
  • TAB画布开发

    2020-12-18 10:16:23
    TAB画布开发 1、TAB画布与其他的画布开发相似,使用Layout Wizard 新建一个TAB画布,并修改TAB_DEMO的子类属性tab_canvases,TAB_Pages的子类属性为tab_page 2、将所需要展示的ITEM放置到page中,实际上item只能...
  • 商业模式画布

    万次阅读 多人点赞 2018-07-22 18:52:11
    周四周五机缘巧合参加了一场关于商业模式画布的培训,第一次参加趋向于商业方向的培训,一开始并没有抱太大的期望。但是听完两天的课之后,第一次给培训的老师全是满分的评价,因为确实内容非常受用,两天的课程中即...
  • word绘图教程:画布、图形的关系和隐藏画布一、画布和图形的关系选择了一个具体图形工具后,word会弹出一个与页面各分栏宽度(除去上下左右边框、栏间距后剩余的空间)基本等宽的长方形画布(宽高比约为1.7:1),以及...
  • canvas 清除画布

    千次阅读 2019-09-19 17:16:39
    clearRect() 方法清空指定矩形内的canvas画布。 <!DOCTYPEHTML> <html> <head><title>canvas清空画布</title><metacharset="utf-8"/></head> <body> <div...
  • unity3d画布切换 了解Unity 3D画布 (Understanding the Unity 3D Canvas) The Canvas in Unity isn't a big painting board on a wooden frame. The Canvas is actually an area in the game where you can draw UI...
  • 创建画布

    千次阅读 2016-05-16 18:00:54
    在开发Web项目时,图片是前台页面不可缺少的组成部分,传统...创建画布  GD2函数库在图形图像绘制方面功能非常强大,开发人员即可以在已有的图片的基础上经行绘制,也可以在没有任何素材的基础上绘制,在这种情况下
  • visio调整画布大小和旋转画布

    千次阅读 2015-11-30 23:16:43
    1.调整画布大小: 鼠标移至画布边界(注意不能是顶点附近),按下ctrl,就会出现双向箭头,拖动鼠标即能调整画布大小。 2.旋转画布: 鼠标移至画布顶点或附近,按下ctrl, 出现单箭头优弧,移动鼠标...
  • 了解canvas画布

    千次阅读 2020-09-27 23:57:10
    画布是一个矩形区域,可以控制其每一像素 canvas 拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法 二、canvas基本使用 添加canvas元素(创建画布) <canvas id="myCanvas" width="300" height="300"> ...
  • 在PS中,我们有时候会遇到扩展画布的场景,但是扩展完画布之后我们发现不能改变颜色,这可怎么办。 首先来看一下是什么样的问题: 这个背景是不能选择的。 问题分析:这是因为你创建的画布的时候颜色是透明...
  • Qt 高级画布

    2017-07-29 10:27:02
    Qt 高级画布实现功能实现方法 实现功能在画布的指定区域可绘,而不是对整块画布可以做绘图操作。 实现方法实现对整块画布可以绘制 加入条件,当鼠标在制定区域才会触发鼠标事件,否则不会记录鼠标轨迹 额外扩展画布...
  • Android 自定义画布 绘制 撤销 清空 ssssssssssssss
  • canvas 清空画布

    千次阅读 2019-10-23 16:17:30
    画布重用的时候,使用clearRect可以清空画布,我当时想,这样可以接着在画布上处理。 然而,在nw.js上做的时候,却有上次的残余。 影响用户体验度, 我是用的直接删除当前canvas然后新建的方式来达到擦出效果,...
  • echarts清理画布

    2020-05-07 13:44:50
    项目中有时候使用选择下拉框在同一个画布中显示不同的图表,这时候需要使用到echarts清理画布然后在重新设置数据,清除画布代码如下: echarts.init(document.getElementById(divId)).dispose(); 更多内容请扫码...
  • python创建画布_在空白画布上创建

    千次阅读 2020-07-24 10:24:16
    python创建画布Hackathons are one of the most unique and rewarding parts of working in creative technology. At their most rewarding, hackathons can be an experience that sees teams go from a completely...
  • vue 结合 fabric.js 用canvas画布画底图 实现鼠标拖动画布底图 实现鼠标滚动对画布底图进行放大缩小 2. 引入 fabric.js 2.1 npm 安装 npm install fabric --save 2.2 main.js 导入 import { fabric } from '...
  • HTML5 保存画布

    2018-04-25 22:00:37
    保存画布好不容易在画布中绘制出酷炫的图形,应该把它保存起来吧。但不幸的是,画布中的这些图形本身不是真正的图片,不能直接保存。不幸中的万幸,Canvas API提供了toDataURL()方法,可以把画布中的图形转换为图片...
  • css画布

    2016-07-21 13:07:13
    canvas 本意则就是画布的意思, 我们来看一看 canvas的属性 和方法 属性 描述 fillStyle 设置或返回用于填充绘画的颜色、渐变或模式 strokeStyle 设置或返回用于...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 138,095
精华内容 55,238
关键字:

如何画布